aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar murgatroid99 <mlumish@google.com>2015-02-13 10:19:10 -0800
committerGravatar murgatroid99 <mlumish@google.com>2015-02-13 10:19:10 -0800
commit17be589de0c41807b14fe47165e165c7d64deb9c (patch)
treea0826aac15686b5ca275ac959e2731a1f9bc002b
parent44dd2f33679e1b8a35d7c3f37a719279988419a7 (diff)
Made changes based on comments
-rw-r--r--src/node/ext/call.cc86
-rw-r--r--src/node/ext/call.h15
-rw-r--r--src/node/ext/server.cc6
3 files changed, 46 insertions, 61 deletions
diff --git a/src/node/ext/call.cc b/src/node/ext/call.cc
index 4401698b1e..18f40f2488 100644
--- a/src/node/ext/call.cc
+++ b/src/node/ext/call.cc
@@ -48,6 +48,7 @@
#include "timeval.h"
using std::unique_ptr;
+using std::shared_ptr;
namespace grpc {
namespace node {
@@ -76,10 +77,8 @@ Persistent<Function> Call::constructor;
Persistent<FunctionTemplate> Call::fun_tpl;
-bool CreateMetadataArray(
- Handle<Object> metadata, grpc_metadata_array *array,
- std::vector<unique_ptr<NanUtf8String> > *string_handles,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+bool CreateMetadataArray(Handle<Object> metadata, grpc_metadata_array *array,
+ shared_ptr<Resources> resources) {
NanScope();
grpc_metadata_array_init(array);
Handle<Array> keys(metadata->GetOwnPropertyNames());
@@ -95,7 +94,7 @@ bool CreateMetadataArray(
for (unsigned int i = 0; i < keys->Length(); i++) {
Handle<String> current_key(keys->Get(i)->ToString());
NanUtf8String *utf8_key = new NanUtf8String(current_key);
- string_handles->push_back(unique_ptr<NanUtf8String>(utf8_key));
+ resources->strings.push_back(unique_ptr<NanUtf8String>(utf8_key));
Handle<Array> values = Local<Array>::Cast(metadata->Get(current_key));
for (unsigned int j = 0; j < values->Length(); j++) {
Handle<Value> value = values->Get(j);
@@ -106,12 +105,12 @@ bool CreateMetadataArray(
current->value_length = Buffer::Length(value);
Persistent<Value> handle;
NanAssignPersistent(handle, value);
- handles->push_back(unique_ptr<PersistentHolder>(
+ resources->handles.push_back(unique_ptr<PersistentHolder>(
new PersistentHolder(handle)));
} else if (value->IsString()) {
Handle<String> string_value = value->ToString();
NanUtf8String *utf8_value = new NanUtf8String(string_value);
- string_handles->push_back(unique_ptr<NanUtf8String>(utf8_value));
+ resources->strings.push_back(unique_ptr<NanUtf8String>(utf8_value));
current->value = **utf8_value;
current->value_length = string_value->Length();
} else {
@@ -168,13 +167,12 @@ class SendMetadataOp : public Op {
return NanEscapeScope(NanTrue());
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
if (!value->IsObject()) {
return false;
}
grpc_metadata_array array;
- if (!CreateMetadataArray(value->ToObject(), &array, strings, handles)) {
+ if (!CreateMetadataArray(value->ToObject(), &array, resources)) {
return false;
}
out->data.send_initial_metadata.count = array.count;
@@ -194,8 +192,7 @@ class SendMessageOp : public Op {
return NanEscapeScope(NanTrue());
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
if (!Buffer::HasInstance(value)) {
return false;
}
@@ -204,7 +201,7 @@ class SendMessageOp : public Op {
Handle<Value> temp = NanNew<Object>();
NanAssignPersistent(handle, temp);
NanAssignPersistent(handle, value);
- handles->push_back(unique_ptr<PersistentHolder>(
+ resources->handles.push_back(unique_ptr<PersistentHolder>(
new PersistentHolder(handle)));
return true;
}
@@ -221,8 +218,7 @@ class SendClientCloseOp : public Op {
return NanEscapeScope(NanTrue());
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
return true;
}
protected:
@@ -238,8 +234,7 @@ class SendServerStatusOp : public Op {
return NanEscapeScope(NanTrue());
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
if (!value->IsObject()) {
return false;
}
@@ -256,7 +251,7 @@ class SendServerStatusOp : public Op {
grpc_metadata_array array;
if (!CreateMetadataArray(server_status->Get(NanNew("metadata"))->
ToObject(),
- &array, strings, handles)) {
+ &array, resources)) {
return false;
}
out->data.send_status_from_server.trailing_metadata_count = array.count;
@@ -266,7 +261,7 @@ class SendServerStatusOp : public Op {
server_status->Get(NanNew("code"))->Uint32Value());
NanUtf8String *str = new NanUtf8String(
server_status->Get(NanNew("details")));
- strings->push_back(unique_ptr<NanUtf8String>(str));
+ resources->strings.push_back(unique_ptr<NanUtf8String>(str));
out->data.send_status_from_server.status_details = **str;
return true;
}
@@ -292,8 +287,7 @@ class GetMetadataOp : public Op {
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
out->data.recv_initial_metadata = &recv_metadata;
return true;
}
@@ -323,8 +317,7 @@ class ReadMessageOp : public Op {
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
out->data.recv_message = &recv_message;
return true;
}
@@ -352,8 +345,7 @@ class ClientStatusOp : public Op {
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
out->data.recv_status_on_client.trailing_metadata = &metadata_array;
out->data.recv_status_on_client.status = &status;
out->data.recv_status_on_client.status_details = &status_details;
@@ -390,8 +382,7 @@ class ServerCloseResponseOp : public Op {
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
out->data.recv_close_on_server.cancelled = &cancelled;
return true;
}
@@ -406,19 +397,13 @@ class ServerCloseResponseOp : public Op {
};
tag::tag(NanCallback *callback, std::vector<unique_ptr<Op> > *ops,
- std::vector<unique_ptr<PersistentHolder> > *handles,
- std::vector<unique_ptr<NanUtf8String> > *strings) :
- callback(callback), ops(ops), handles(handles), strings(strings){
+ shared_ptr<Resources> resources) :
+ callback(callback), ops(ops), resources(resources){
}
+
tag::~tag() {
delete callback;
delete ops;
- if (handles != NULL) {
- delete handles;
- }
- if (strings != NULL) {
- delete strings;
- }
}
Handle<Value> GetTagNodeValue(void *tag) {
@@ -542,17 +527,14 @@ NAN_METHOD(Call::StartBatch) {
Handle<Function> callback_func = args[1].As<Function>();
NanCallback *callback = new NanCallback(callback_func);
Call *call = ObjectWrap::Unwrap<Call>(args.This());
- std::vector<unique_ptr<PersistentHolder> > *handles =
- new std::vector<unique_ptr<PersistentHolder> >();
- std::vector<unique_ptr<NanUtf8String> > *strings =
- new std::vector<unique_ptr<NanUtf8String> >();
+ shared_ptr<Resources> resources(new Resources);
Handle<Object> obj = args[0]->ToObject();
Handle<Array> keys = obj->GetOwnPropertyNames();
size_t nops = keys->Length();
grpc_op *ops = new grpc_op[nops];
std::vector<unique_ptr<Op> > *op_vector = new std::vector<unique_ptr<Op> >();
for (unsigned int i = 0; i < nops; i++) {
- Op *op;
+ unique_ptr<Op> op;
if (!keys->Get(i)->IsUint32()) {
return NanThrowError(
"startBatch's first argument's keys must be integers");
@@ -561,40 +543,40 @@ NAN_METHOD(Call::StartBatch) {
ops[i].op = static_cast<grpc_op_type>(type);
switch (type) {
case GRPC_OP_SEND_INITIAL_METADATA:
- op = new SendMetadataOp();
+ op.reset(new SendMetadataOp());
break;
case GRPC_OP_SEND_MESSAGE:
- op = new SendMessageOp();
+ op.reset(new SendMessageOp());
break;
case GRPC_OP_SEND_CLOSE_FROM_CLIENT:
- op = new SendClientCloseOp();
+ op.reset(new SendClientCloseOp());
break;
case GRPC_OP_SEND_STATUS_FROM_SERVER:
- op = new SendServerStatusOp();
+ op.reset(new SendServerStatusOp());
break;
case GRPC_OP_RECV_INITIAL_METADATA:
- op = new GetMetadataOp();
+ op.reset(new GetMetadataOp());
break;
case GRPC_OP_RECV_MESSAGE:
- op = new ReadMessageOp();
+ op.reset(new ReadMessageOp());
break;
case GRPC_OP_RECV_STATUS_ON_CLIENT:
- op = new ClientStatusOp();
+ op.reset(new ClientStatusOp());
break;
case GRPC_OP_RECV_CLOSE_ON_SERVER:
- op = new ServerCloseResponseOp();
+ op.reset(new ServerCloseResponseOp());
break;
default:
return NanThrowError("Argument object had an unrecognized key");
}
- if (!op->ParseOp(obj->Get(type), &ops[i], strings, handles)) {
+ if (!op->ParseOp(obj->Get(type), &ops[i], resources)) {
return NanThrowTypeError("Incorrectly typed arguments to startBatch");
}
- op_vector->push_back(unique_ptr<Op>(op));
+ op_vector->push_back(std::move(op));
}
grpc_call_error error = grpc_call_start_batch(
call->wrapped_call, ops, nops, new struct tag(
- callback, op_vector, handles, strings));
+ callback, op_vector, resources));
delete ops;
if (error != GRPC_CALL_OK) {
return NanThrowError("startBatch failed", error);
diff --git a/src/node/ext/call.h b/src/node/ext/call.h
index f443a04637..4074f1509b 100644
--- a/src/node/ext/call.h
+++ b/src/node/ext/call.h
@@ -47,6 +47,7 @@ namespace grpc {
namespace node {
using std::unique_ptr;
+using std::shared_ptr;
v8::Handle<v8::Value> ParseMetadata(const grpc_metadata_array *metadata_array);
@@ -64,12 +65,16 @@ class PersistentHolder {
v8::Persistent<v8::Value> persist;
};
+struct Resources {
+ std::vector<unique_ptr<NanUtf8String> > strings;
+ std::vector<unique_ptr<PersistentHolder> > handles;
+};
+
class Op {
public:
virtual v8::Handle<v8::Value> GetNodeValue() const = 0;
virtual bool ParseOp(v8::Handle<v8::Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) = 0;
+ shared_ptr<Resources> resources) = 0;
v8::Handle<v8::Value> GetOpType() const;
protected:
@@ -78,13 +83,11 @@ class Op {
struct tag {
tag(NanCallback *callback, std::vector<unique_ptr<Op> > *ops,
- std::vector<unique_ptr<PersistentHolder> > *handles,
- std::vector<unique_ptr<NanUtf8String> > *strings);
+ shared_ptr<Resources> resources);
~tag();
NanCallback *callback;
std::vector<unique_ptr<Op> > *ops;
- std::vector<unique_ptr<PersistentHolder> > *handles;
- std::vector<unique_ptr<NanUtf8String> > *strings;
+ shared_ptr<Resources> resources;
};
v8::Handle<v8::Value> GetTagNodeValue(void *tag);
diff --git a/src/node/ext/server.cc b/src/node/ext/server.cc
index 51904479a9..6a4a951121 100644
--- a/src/node/ext/server.cc
+++ b/src/node/ext/server.cc
@@ -101,8 +101,7 @@ class NewCallOp : public Op {
}
bool ParseOp(Handle<Value> value, grpc_op *out,
- std::vector<unique_ptr<NanUtf8String> > *strings,
- std::vector<unique_ptr<PersistentHolder> > *handles) {
+ shared_ptr<Resources> resources) {
return true;
}
@@ -230,7 +229,8 @@ NAN_METHOD(Server::RequestCall) {
grpc_call_error error = grpc_server_request_call(
server->wrapped_server, &op->call, &op->details, &op->request_metadata,
CompletionQueueAsyncWorker::GetQueue(),
- new struct tag(new NanCallback(args[0].As<Function>()), ops, NULL, NULL));
+ new struct tag(new NanCallback(args[0].As<Function>()), ops,
+ shared_ptr<Resources>(nullptr)));
if (error != GRPC_CALL_OK) {
return NanThrowError("requestCall failed", error);
}