0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-30 17:10:48 +01:00
mongodb/db/lasterror.h

133 lines
3.9 KiB
C
Raw Normal View History

2009-02-05 17:51:51 +01:00
// lasterror.h
/* 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.
*/
2009-01-14 23:17:24 +01:00
#pragma once
#include <boost/thread/tss.hpp>
#undef assert
#define assert xassert
2009-01-14 23:09:51 +01:00
namespace mongo {
class BSONObjBuilder;
class Message;
struct LastError {
2009-12-28 23:12:49 +01:00
int code;
string msg;
enum UpdatedExistingType { NotUpdate, True, False } updatedExisting;
/* todo: nObjects should be 64 bit */
int nObjects;
int nPrev;
bool valid;
bool overridenById;
2009-12-28 23:12:49 +01:00
void raiseError(int _code , const char *_msg) {
reset( true );
2009-12-28 23:12:49 +01:00
code = _code;
msg = _msg;
}
void recordUpdate( bool _updatedExisting, int nChanged ) {
reset( true );
nObjects = nChanged;
updatedExisting = _updatedExisting ? True : False;
}
void recordDelete( int nDeleted ) {
reset( true );
nObjects = nDeleted;
}
LastError() {
overridenById = false;
reset();
}
void reset( bool _valid = false ) {
2009-12-28 23:12:49 +01:00
code = 0;
msg.clear();
updatedExisting = NotUpdate;
nObjects = 0;
nPrev = 1;
valid = _valid;
}
void appendSelf( BSONObjBuilder &b );
static LastError noError;
};
extern class LastErrorHolder {
public:
LastErrorHolder() : _id( 0 ), _disabled() {}
LastError * get( bool create = false );
void reset( LastError * le );
/**
* id of 0 means should use thread local management
*/
void setID( int id );
int getID();
void remove( int id );
void release();
/** when db receives a message/request, call this */
void startRequest( Message& m , LastError * connectionOwned );
void startRequest( Message& m );
// used to disable lastError reporting while processing a killCursors message
// disable causes get() to return 0.
LastError *disableForCommand(); // only call once per command invocation!
void enable() { _disabled = false; }
bool disabled() { return _disabled; }
private:
void disable() { _disabled = true; }
2009-10-13 18:55:23 +02:00
ThreadLocalValue<int> _id;
boost::thread_specific_ptr<LastError> _tl;
struct Status {
time_t time;
LastError *lerr;
};
static boost::mutex _idsmutex;
map<int,Status> _ids;
bool _disabled;
} lastError;
2009-12-28 23:12:49 +01:00
inline void raiseError(int code , const char *msg) {
LastError *le = lastError.get();
if ( le == 0 ) {
if ( lastError.disabled() ) {
log() << "lastError disabled, can't report: " << msg << endl;
} else {
DEV log() << "warning: lastError==0 can't report:" << msg << '\n';
}
return;
}
2009-12-28 23:12:49 +01:00
le->raiseError(code, msg);
2009-01-14 23:17:24 +01:00
}
inline void recordUpdate( bool updatedExisting, int nChanged ) {
LastError *le = lastError.get();
if ( le )
le->recordUpdate( updatedExisting, nChanged );
}
inline void recordDelete( int nDeleted ) {
LastError *le = lastError.get();
if ( le )
le->recordDelete( nDeleted );
}
} // namespace mongo