2008-11-30 02:01:58 +01:00
|
|
|
// util.cpp
|
|
|
|
|
2009-10-27 20:58:27 +01:00
|
|
|
/* Copyright 2009 10gen Inc.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2008-07-20 23:37:33 +02:00
|
|
|
|
2008-06-06 15:43:15 +02:00
|
|
|
#include "stdafx.h"
|
|
|
|
#include "goodies.h"
|
2008-09-09 20:30:22 +02:00
|
|
|
#include "unittest.h"
|
2009-04-15 22:10:21 +02:00
|
|
|
#include "file_allocator.h"
|
2009-04-24 00:01:24 +02:00
|
|
|
#include "optime.h"
|
2008-09-09 20:30:22 +02:00
|
|
|
|
2009-01-14 23:09:51 +01:00
|
|
|
namespace mongo {
|
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
vector<UnitTest*> *UnitTest::tests = 0;
|
2009-02-13 17:25:52 +01:00
|
|
|
bool UnitTest::running = false;
|
2008-06-06 15:43:15 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
Nullstream nullstream;
|
2009-09-03 20:58:05 +02:00
|
|
|
|
|
|
|
thread_specific_ptr<Logstream> Logstream::tsp;
|
|
|
|
|
2009-10-13 22:01:02 +02:00
|
|
|
const char *default_getcurns() { return ""; }
|
|
|
|
const char * (*getcurns)() = default_getcurns;
|
|
|
|
|
2009-01-20 20:30:59 +01:00
|
|
|
int logLevel = 0;
|
2009-05-22 00:20:07 +02:00
|
|
|
boost::mutex &Logstream::mutex = *( new boost::mutex );
|
2009-10-21 22:40:31 +02:00
|
|
|
int Logstream::doneSetup = Logstream::magicNumber();
|
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
bool goingAway = false;
|
2008-06-06 15:43:15 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
bool isPrime(int n) {
|
|
|
|
int z = 2;
|
|
|
|
while ( 1 ) {
|
|
|
|
if ( z*z > n )
|
|
|
|
break;
|
|
|
|
if ( n % z == 0 )
|
|
|
|
return false;
|
|
|
|
z++;
|
|
|
|
}
|
|
|
|
return true;
|
2008-12-29 02:28:49 +01:00
|
|
|
}
|
2008-06-06 15:43:15 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
int nextPrime(int n) {
|
|
|
|
n |= 1; // 2 goes to 3...don't care...
|
|
|
|
while ( !isPrime(n) )
|
|
|
|
n += 2;
|
|
|
|
return n;
|
|
|
|
}
|
2008-06-06 15:43:15 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
struct UtilTest : public UnitTest {
|
|
|
|
void run() {
|
|
|
|
assert( WrappingInt(0) <= WrappingInt(0) );
|
|
|
|
assert( WrappingInt(0) <= WrappingInt(1) );
|
|
|
|
assert( !(WrappingInt(1) <= WrappingInt(0)) );
|
|
|
|
assert( (WrappingInt(0xf0000000) <= WrappingInt(0)) );
|
|
|
|
assert( (WrappingInt(0xf0000000) <= WrappingInt(9000)) );
|
|
|
|
assert( !(WrappingInt(300) <= WrappingInt(0xe0000000)) );
|
2008-06-06 15:43:15 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
assert( tdiff(3, 4) == 1 );
|
|
|
|
assert( tdiff(4, 3) == -1 );
|
|
|
|
assert( tdiff(0xffffffff, 0) == 1 );
|
2008-06-06 15:43:15 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
assert( isPrime(3) );
|
|
|
|
assert( isPrime(2) );
|
|
|
|
assert( isPrime(13) );
|
|
|
|
assert( isPrime(17) );
|
|
|
|
assert( !isPrime(9) );
|
|
|
|
assert( !isPrime(6) );
|
|
|
|
assert( nextPrime(4) == 5 );
|
|
|
|
assert( nextPrime(8) == 11 );
|
2008-09-03 22:43:00 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
assert( endsWith("abcde", "de") );
|
|
|
|
assert( !endsWith("abcde", "dasdfasdfashkfde") );
|
2008-09-03 22:43:00 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
assert( swapEndian(0x01020304) == 0x04030201 );
|
2008-09-04 16:33:56 +02:00
|
|
|
|
2009-01-15 16:17:11 +01:00
|
|
|
}
|
|
|
|
} utilTest;
|
2009-02-09 21:57:30 +01:00
|
|
|
|
2009-04-15 22:10:21 +02:00
|
|
|
// The mutex contained in this object may be held on shutdown.
|
|
|
|
FileAllocator &theFileAllocator_ = *(new FileAllocator());
|
|
|
|
FileAllocator &theFileAllocator() { return theFileAllocator_; }
|
2009-04-24 00:01:24 +02:00
|
|
|
|
|
|
|
OpTime OpTime::last(0, 0);
|
|
|
|
|
2009-06-04 13:25:58 +02:00
|
|
|
/* this is a good place to set a breakpoint when debugging, as lots of warning things
|
|
|
|
(assert, wassert) call it.
|
|
|
|
*/
|
|
|
|
void sayDbContext(const char *errmsg) {
|
|
|
|
if ( errmsg ) {
|
|
|
|
problem() << errmsg << endl;
|
|
|
|
}
|
|
|
|
printStackTrace();
|
|
|
|
}
|
|
|
|
|
|
|
|
void rawOut( const string &s ) {
|
|
|
|
if( s.empty() ) return;
|
|
|
|
char now[64];
|
|
|
|
time_t_to_String(time(0), now);
|
|
|
|
now[20] = 0;
|
|
|
|
#if defined(_WIN32)
|
|
|
|
(std::cout << now << " " << s).flush();
|
|
|
|
#else
|
2010-01-24 17:05:45 +01:00
|
|
|
write( STDOUT_FILENO, now, 20 );
|
|
|
|
write( STDOUT_FILENO, " ", 1 );
|
|
|
|
write( STDOUT_FILENO, s.c_str(), s.length() );
|
2009-06-04 13:25:58 +02:00
|
|
|
fsync( STDOUT_FILENO );
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef _SCONS
|
|
|
|
// only works in scons
|
|
|
|
const char * gitVersion(){ return ""; }
|
|
|
|
const char * sysInfo(){ return ""; }
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void printGitVersion() { log() << "git version: " << gitVersion() << endl; }
|
|
|
|
void printSysInfo() { log() << "sys info: " << sysInfo() << endl; }
|
|
|
|
string mongodVersion() {
|
|
|
|
stringstream ss;
|
|
|
|
ss << "db version v" << versionString << ", pdfile version " << VERSION << "." << VERSION_MINOR;
|
|
|
|
return ss.str();
|
|
|
|
}
|
2010-02-26 17:33:20 +01:00
|
|
|
|
|
|
|
ostream& operator<<( ostream &s, const ThreadSafeString &o ){
|
|
|
|
s << (string)o;
|
|
|
|
return s;
|
|
|
|
}
|
2009-10-13 22:01:02 +02:00
|
|
|
|
2009-01-14 23:09:51 +01:00
|
|
|
} // namespace mongo
|