MongoDB-Async
view release on metacpan or search on metacpan
MODULE = MongoDB::Async::BSON PACKAGE = MongoDB::Async::BSON
PROTOTYPES: DISABLE
void
decode_bson(sv)
SV *sv
PREINIT:
buffer buf;
PPCODE:
buf.start = SvPV_nolen(sv);
buf.pos = buf.start;
buf.end = buf.start + SvCUR(sv);
while(buf.pos < buf.end) {
XPUSHs(sv_2mortal(perl_mongo_bson_to_sv(&buf, newSV(0) )));
}
void
encode_bson(obj)
SV *obj
PREINIT:
buffer buf;
PPCODE:
CREATE_BUF(INITIAL_BUF_SIZE);
perl_mongo_sv_to_bson(&buf, obj, NO_PREP);
perl_mongo_serialize_size(buf.start, &buf);
XPUSHs(sv_2mortal(newSVpvn(buf.start, buf.pos-buf.start)));
Safefree(buf.start);
void
read_flags()
PPCODE:
read_flags();
xs/Cursor.xs view on Meta::CPAN
RETVAL = SvREFCNT_inc(self);
OUTPUT:
RETVAL
SV *
data (self)
SV *self
PREINIT:
SV* nextval;
PPCODE:
mongo_cursor *cursor = get_cursor(self);
int limit = SvIV( perl_mongo_call_reader(self, "_limit") );
AV *ret = newAV();
SV *client_sv = perl_mongo_call_reader( self, "_client" );
while(nextval = next(self, cursor, limit, client_sv) ){
av_push(ret, nextval);
xs/Mongo.xs view on Meta::CPAN
int opts
int skip
int limit
SV *query
SV *fields
PREINIT:
buffer buf;
mongo_msg_header header;
HV *info = newHV();
SV **heval, *request_id;
PPCODE:
request_id = get_sv("MongoDB::Async::Cursor::_request_id", GV_ADD);
heval = hv_store(info, "ns", strlen("ns"), newSVpv(ns, strlen(ns)), 0);
heval = hv_store(info, "opts", strlen("opts"), newSViv(opts), 0);
heval = hv_store(info, "skip", strlen("skip"), newSViv(skip), 0);
heval = hv_store(info, "limit", strlen("limit"), newSViv(limit), 0);
heval = hv_store(info, "request_id", strlen("request_id"), SvREFCNT_inc(request_id), 0);
CREATE_BUF(INITIAL_BUF_SIZE);
CREATE_HEADER_WITH_OPTS(buf, ns, OP_QUERY, opts);
xs/Mongo.xs view on Meta::CPAN
PREINIT:
buffer buf;
mongo_msg_header header;
int i;
AV *ids = 0;
SV *request_id;
INIT:
if (add_ids) {
ids = newAV();
}
PPCODE:
request_id = get_sv("MongoDB::Async::Cursor::_request_id", GV_ADD);
CREATE_BUF(INITIAL_BUF_SIZE);
CREATE_HEADER(buf, ns, OP_INSERT);
for (i=0; i<=av_len(a); i++) {
int start = buf.pos-buf.start;
SV **obj = av_fetch(a, i, 0);
perl_mongo_sv_to_bson(&buf, *obj, ids);
}
xs/Mongo.xs view on Meta::CPAN
void
write_remove(ns, criteria, flags)
char *ns
SV *criteria
int flags
PREINIT:
buffer buf;
mongo_msg_header header;
SV *request_id;
PPCODE:
request_id = get_sv("MongoDB::Async::Cursor::_request_id", GV_ADD);
CREATE_BUF(INITIAL_BUF_SIZE);
CREATE_HEADER(buf, ns, OP_DELETE);
perl_mongo_serialize_int(&buf, flags);
perl_mongo_sv_to_bson(&buf, criteria, NO_PREP);
perl_mongo_serialize_size(buf.start, &buf);
XPUSHs(sv_2mortal(newSVpvn(buf.start, buf.pos-buf.start)));
Safefree(buf.start);
xs/Mongo.xs view on Meta::CPAN
void
write_update(ns, criteria, obj, flags)
char *ns
SV *criteria
SV *obj
int flags
PREINIT:
buffer buf;
mongo_msg_header header;
SV *request_id;
PPCODE:
request_id = get_sv("MongoDB::Async::Cursor::_request_id", GV_ADD);
CREATE_BUF(INITIAL_BUF_SIZE);
CREATE_HEADER(buf, ns, OP_UPDATE);
perl_mongo_serialize_int(&buf, flags);
perl_mongo_sv_to_bson(&buf, criteria, NO_PREP);
perl_mongo_sv_to_bson(&buf, obj, NO_PREP);
perl_mongo_serialize_size(buf.start, &buf);
XPUSHs(sv_2mortal(newSVpvn(buf.start, buf.pos-buf.start)));
Safefree(buf.start);
void
read_documents(sv)
SV *sv
PREINIT:
buffer buf;
PPCODE:
buf.start = SvPV_nolen(sv);
buf.pos = buf.start;
buf.end = buf.start + SvCUR(sv);
while(buf.pos < buf.end) {
XPUSHs(sv_2mortal(perl_mongo_bson_to_sv(&buf, newSV(0) )));
}
void
( run in 0.760 second using v1.01-cache-2.11-cpan-5511b514fd6 )