0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-30 09:06:21 +01:00
mongodb/db/lasterror.h

131 lines
3.8 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 */
2010-02-03 18:03:33 +01:00
long long nObjects;
int nPrev;
bool valid;
bool overridenById;
bool disabled;
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;
}
2010-02-03 18:03:33 +01:00
void recordUpdate( bool _updatedExisting, long long nChanged ) {
reset( true );
nObjects = nChanged;
updatedExisting = _updatedExisting ? True : False;
}
2010-02-03 18:03:33 +01:00
void recordDelete( long long 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;
disabled = false;
}
void appendSelf( BSONObjBuilder &b );
static LastError noError;
};
extern class LastErrorHolder {
public:
LastErrorHolder() : _id( 0 ) {}
LastError * get( bool create = false );
LastError * _get( bool create = false ); // may return a disabled LastError
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!
private:
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;
} lastError;
2009-12-28 23:12:49 +01:00
inline void raiseError(int code , const char *msg) {
LastError *le = lastError.get();
if ( le == 0 ) {
DEV log() << "warning: lastError==0 can't report:" << msg << '\n';
} else if ( le->disabled ) {
log() << "lastError disabled, can't report: " << msg << endl;
} else {
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