diff options
author | Eliot Horowitz <eliot@10gen.com> | 2011-06-26 18:11:45 -0400 |
---|---|---|
committer | Eliot Horowitz <eliot@10gen.com> | 2011-06-26 18:11:45 -0400 |
commit | 3a77049fda79bb8a5ddf240d3f871eaf6025c7b1 (patch) | |
tree | be14c4874004842732ce829ecf42ee313519b65f /db/dbmessage.cpp | |
parent | 0594b8a6ab5ba1561e1fe760e755f2a055beb699 (diff) | |
download | mongo-3a77049fda79bb8a5ddf240d3f871eaf6025c7b1.tar.gz |
net cleaning: message split checkpoint where everything works
Diffstat (limited to 'db/dbmessage.cpp')
-rw-r--r-- | db/dbmessage.cpp | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/db/dbmessage.cpp b/db/dbmessage.cpp new file mode 100644 index 00000000000..b652dc9739a --- /dev/null +++ b/db/dbmessage.cpp @@ -0,0 +1,75 @@ +// dbmessage.cpp + +/** +* Copyright (C) 2008 10gen Inc. +* +* This program is free software: you can redistribute it and/or modify +* it under the terms of the GNU Affero General Public License, version 3, +* as published by the Free Software Foundation. +* +* This program is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +* GNU Affero General Public License for more details. +* +* You should have received a copy of the GNU Affero General Public License +* along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +#include "../pch.h" +#include "dbmessage.h" +#include "../client/dbclient.h" + +namespace mongo { + + void replyToQuery(int queryResultFlags, + AbstractMessagingPort* p, Message& requestMsg, + void *data, int size, + int nReturned, int startingFrom, + long long cursorId + ) { + BufBuilder b(32768); + b.skip(sizeof(QueryResult)); + b.appendBuf(data, size); + QueryResult *qr = (QueryResult *) b.buf(); + qr->_resultFlags() = queryResultFlags; + qr->len = b.len(); + qr->setOperation(opReply); + qr->cursorId = cursorId; + qr->startingFrom = startingFrom; + qr->nReturned = nReturned; + b.decouple(); + Message resp(qr, true); + p->reply(requestMsg, resp, requestMsg.header()->id); + } + + void replyToQuery(int queryResultFlags, + AbstractMessagingPort* p, Message& requestMsg, + BSONObj& responseObj) { + replyToQuery(queryResultFlags, + p, requestMsg, + (void *) responseObj.objdata(), responseObj.objsize(), 1); + } + + void replyToQuery(int queryResultFlags, Message &m, DbResponse &dbresponse, BSONObj obj) { + BufBuilder b; + b.skip(sizeof(QueryResult)); + b.appendBuf((void*) obj.objdata(), obj.objsize()); + QueryResult* msgdata = (QueryResult *) b.buf(); + b.decouple(); + QueryResult *qr = msgdata; + qr->_resultFlags() = queryResultFlags; + qr->len = b.len(); + qr->setOperation(opReply); + qr->cursorId = 0; + qr->startingFrom = 0; + qr->nReturned = 1; + Message *resp = new Message(); + resp->setData(msgdata, true); // transport will free + dbresponse.response = resp; + dbresponse.responseTo = m.header()->id; + } + + + +} |