summaryrefslogtreecommitdiffstats
path: root/tools/aidl/generate_java_rpc.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tools/aidl/generate_java_rpc.cpp')
-rw-r--r--tools/aidl/generate_java_rpc.cpp81
1 files changed, 40 insertions, 41 deletions
diff --git a/tools/aidl/generate_java_rpc.cpp b/tools/aidl/generate_java_rpc.cpp
index 8353c45..a770380 100644
--- a/tools/aidl/generate_java_rpc.cpp
+++ b/tools/aidl/generate_java_rpc.cpp
@@ -11,12 +11,15 @@ Type* PRESENTER_BASE_TYPE = new Type("com.android.athome.service",
"AndroidAtHomePresenter", Type::BUILT_IN, false, false, false);
Type* PRESENTER_LISTENER_BASE_TYPE = new Type("com.android.athome.service",
"AndroidAtHomePresenter.Listener", Type::BUILT_IN, false, false, false);
-Type* RPC_BROKER_TYPE = new Type("com.android.athome.utils", "AndroidAtHomeBroker",
+Type* RPC_BROKER_TYPE = new Type("com.android.athome.connector", "Broker",
Type::BUILT_IN, false, false, false);
-Type* RPC_SERVICE_BASE_TYPE = new Type("com.android.athome.service", "AndroidAtHomeService",
+Type* RPC_CONTAINER_TYPE = new Type("com.android.athome.connector", "ConnectorContainer",
Type::BUILT_IN, false, false, false);
-Type* RPC_SERVICE_INFO_TYPE = new ParcelableType("com.android.athome.stubs",
- "AndroidAtHomeServiceInfo", true, __FILE__, __LINE__);
+// TODO: Just use Endpoint, so this works for all endpoints.
+Type* RPC_CONNECTOR_TYPE = new Type("com.android.athome.connector", "Connector",
+ Type::BUILT_IN, false, false, false);
+Type* RPC_ENDPOINT_INFO_TYPE = new ParcelableType("com.android.athome.rpc",
+ "EndpointInfo", true, __FILE__, __LINE__);
Type* RPC_RESULT_HANDLER_TYPE = new ParcelableType("com.android.athome.rpc", "RpcResultHandler",
true, __FILE__, __LINE__);
Type* RPC_ERROR_LISTENER_TYPE = new Type("com.android.athome.rpc", "RpcErrorHandler",
@@ -286,7 +289,7 @@ public:
virtual ~RpcProxyClass();
Variable* endpoint;
- Variable* context;
+ Variable* broker;
private:
void generate_ctor();
@@ -300,11 +303,11 @@ RpcProxyClass::RpcProxyClass(const interface_type* iface, InterfaceType* interfa
this->what = Class::CLASS;
this->type = interfaceType;
- // context
- this->context = new Variable(CONTEXT_TYPE, "_context");
- this->elements.push_back(new Field(PRIVATE, this->context));
+ // broker
+ this->broker = new Variable(RPC_BROKER_TYPE, "_broker");
+ this->elements.push_back(new Field(PRIVATE, this->broker));
// endpoint
- this->endpoint = new Variable(RPC_SERVICE_INFO_TYPE, "_endpoint");
+ this->endpoint = new Variable(RPC_ENDPOINT_INFO_TYPE, "_endpoint");
this->elements.push_back(new Field(PRIVATE, this->endpoint));
// methods
@@ -318,17 +321,17 @@ RpcProxyClass::~RpcProxyClass()
void
RpcProxyClass::generate_ctor()
{
- Variable* context = new Variable(CONTEXT_TYPE, "context");
- Variable* endpoint = new Variable(RPC_SERVICE_INFO_TYPE, "endpoint");
+ Variable* broker = new Variable(RPC_BROKER_TYPE, "broker");
+ Variable* endpoint = new Variable(RPC_ENDPOINT_INFO_TYPE, "endpoint");
Method* ctor = new Method;
ctor->modifiers = PUBLIC;
ctor->name = class_name_leaf(this->type->Name());
ctor->statements = new StatementBlock;
- ctor->parameters.push_back(context);
+ ctor->parameters.push_back(broker);
ctor->parameters.push_back(endpoint);
this->elements.push_back(ctor);
- ctor->statements->Add(new Assignment(this->context, context));
+ ctor->statements->Add(new Assignment(this->broker, broker));
ctor->statements->Add(new Assignment(this->endpoint, endpoint));
}
@@ -375,19 +378,19 @@ PresenterClass::~PresenterClass()
void
PresenterClass::generate_ctor()
{
- Variable* context = new Variable(CONTEXT_TYPE, "context");
- Variable* endpoint = new Variable(RPC_SERVICE_INFO_TYPE, "endpoint");
+ Variable* broker = new Variable(RPC_BROKER_TYPE, "broker");
+ Variable* endpoint = new Variable(RPC_ENDPOINT_INFO_TYPE, "endpoint");
Variable* listener = new Variable(this->_listener->type, "listener");
Method* ctor = new Method;
ctor->modifiers = PUBLIC;
ctor->name = class_name_leaf(this->type->Name());
ctor->statements = new StatementBlock;
- ctor->parameters.push_back(context);
+ ctor->parameters.push_back(broker);
ctor->parameters.push_back(endpoint);
ctor->parameters.push_back(listener);
this->elements.push_back(ctor);
- ctor->statements->Add(new MethodCall("super", 3, context, endpoint, listener));
+ ctor->statements->Add(new MethodCall("super", 3, broker, endpoint, listener));
ctor->statements->Add(new Assignment(this->_listener, listener));
}
@@ -422,11 +425,11 @@ ListenerClass::~ListenerClass()
}
// =================================================
-class ServiceBaseClass : public DispatcherClass
+class EndpointBaseClass : public DispatcherClass
{
public:
- ServiceBaseClass(const interface_type* iface);
- virtual ~ServiceBaseClass();
+ EndpointBaseClass(const interface_type* iface);
+ virtual ~EndpointBaseClass();
bool needed;
@@ -434,7 +437,7 @@ private:
void generate_ctor();
};
-ServiceBaseClass::ServiceBaseClass(const interface_type* iface)
+EndpointBaseClass::EndpointBaseClass(const interface_type* iface)
:DispatcherClass(iface, THIS_VALUE),
needed(false)
{
@@ -442,36 +445,32 @@ ServiceBaseClass::ServiceBaseClass(const interface_type* iface)
this->modifiers = STATIC | PUBLIC | ABSTRACT;
this->what = Class::CLASS;
this->type = new Type(iface->package ? iface->package : "",
- append(iface->name.data, ".ServiceBase"),
+ append(iface->name.data, ".EndpointBase"),
Type::GENERATED, false, false, false);
- this->extends = RPC_SERVICE_BASE_TYPE;
+ this->extends = RPC_CONNECTOR_TYPE;
// methods
generate_ctor();
}
-ServiceBaseClass::~ServiceBaseClass()
+EndpointBaseClass::~EndpointBaseClass()
{
}
void
-ServiceBaseClass::generate_ctor()
+EndpointBaseClass::generate_ctor()
{
- Variable* context = new Variable(SERVICE_CONTEXT_TYPE, "context");
- Variable* name = new Variable(STRING_TYPE, "name");
- Variable* type = new Variable(STRING_TYPE, "type");
- Variable* version = new Variable(INT_TYPE, "version");
+ Variable* container = new Variable(RPC_CONTAINER_TYPE, "container");
+ Variable* broker = new Variable(RPC_BROKER_TYPE, "broker");
Method* ctor = new Method;
ctor->modifiers = PUBLIC;
ctor->name = class_name_leaf(this->type->Name());
ctor->statements = new StatementBlock;
- ctor->parameters.push_back(context);
- ctor->parameters.push_back(name);
- ctor->parameters.push_back(type);
- ctor->parameters.push_back(version);
+ ctor->parameters.push_back(container);
+ ctor->parameters.push_back(broker);
this->elements.push_back(ctor);
- ctor->statements->Add(new MethodCall("super", 4, context, name, type, version));
+ ctor->statements->Add(new MethodCall("super", 2, container, broker));
}
// =================================================
@@ -711,10 +710,10 @@ generate_proxy_method(const method_type* method, RpcProxyClass* proxyClass,
proxyMethod->parameters.push_back(errorListener);
// Call the broker
- proxyMethod->statements->Add(new MethodCall(RPC_BROKER_TYPE, "sendRequest", 6,
- new FieldVariable(THIS_VALUE, "_context"),
- new StringLiteralExpression(method->name.data),
+ proxyMethod->statements->Add(new MethodCall(new FieldVariable(THIS_VALUE, "_broker"),
+ "sendRpc", 5,
proxyClass->endpoint,
+ new StringLiteralExpression(method->name.data),
new MethodCall(_data, "serialize"),
resultParameter,
errorListener));
@@ -773,7 +772,7 @@ generate_result_dispatcher_method(const method_type* method,
static void
generate_regular_method(const method_type* method, RpcProxyClass* proxyClass,
- ServiceBaseClass* serviceBaseClass, ResultDispatcherClass* resultsDispatcherClass,
+ EndpointBaseClass* serviceBaseClass, ResultDispatcherClass* resultsDispatcherClass,
int index)
{
arg_type* arg;
@@ -818,7 +817,7 @@ generate_regular_method(const method_type* method, RpcProxyClass* proxyClass,
static void
generate_event_method(const method_type* method, RpcProxyClass* proxyClass,
- ServiceBaseClass* serviceBaseClass, ListenerClass* listenerClass,
+ EndpointBaseClass* serviceBaseClass, ListenerClass* listenerClass,
PresenterClass* presenterClass, int index)
{
arg_type* arg;
@@ -909,7 +908,7 @@ generate_listener_methods(RpcProxyClass* proxyClass, Type* presenterType, Type*
registerMethod->statements->Add(new MethodCall(THIS_VALUE, "unregisterListener"));
registerMethod->statements->Add(new Assignment(_presenter, new NewExpression(presenterType,
- 3, proxyClass->context, proxyClass->endpoint, listener)));
+ 3, proxyClass->broker, proxyClass->endpoint, listener)));
registerMethod->statements->Add(new MethodCall(_presenter, "attachToModel"));
Method* unregisterMethod = new Method;
@@ -942,7 +941,7 @@ generate_rpc_interface_class(const interface_type* iface)
PresenterClass* presenter = new PresenterClass(iface, listener->type);
// the service base class
- ServiceBaseClass* base = new ServiceBaseClass(iface);
+ EndpointBaseClass* base = new EndpointBaseClass(iface);
proxy->elements.push_back(base);
// the result dispatcher