Ecore con client: Add support for some eo events.
authorTom Hacohen <tom@stosb.com>
Fri, 22 Aug 2014 13:33:26 +0000 (14:33 +0100)
committerTom Hacohen <tom@stosb.com>
Fri, 22 Aug 2014 16:11:54 +0000 (17:11 +0100)
src/lib/ecore_con/ecore_con.c
src/lib/ecore_con/ecore_con.eo

index aa52712c8933130809445147aa7070a037748f3a..9432c670e9117746e595774c0bbf19a6650c8d64 100644 (file)
@@ -1083,6 +1083,7 @@ ecore_con_event_client_add(Ecore_Con_Client *obj)
    if (cl->upgrade) ev = ECORE_CON_EVENT_CLIENT_UPGRADE;
    ecore_event_add(ev, e,
                    (Ecore_End_Cb)_ecore_con_event_client_add_free, cl->host_server);
+   eo_do(obj, eo_event_callback_call(ECORE_CON_EVENT_CONNECTION_UPGRADED, NULL));
    _ecore_con_event_count++;
 }
 
@@ -1154,6 +1155,12 @@ ecore_con_event_client_data(Ecore_Con_Client *obj, unsigned char *buf, int num,
    e->size = num;
    ecore_event_add(ECORE_CON_EVENT_CLIENT_DATA, e,
                    (Ecore_End_Cb)_ecore_con_event_client_data_free, cl->host_server);
+     {
+        Ecore_Con_Event_Data_Received event_info = { 0 };
+        event_info.data = e->data;
+        event_info.size = e->size;
+        eo_do(obj, eo_event_callback_call(ECORE_CON_EVENT_DATA_RECEIVED, &event_info));
+     }
    _ecore_con_event_count++;
 }
 
@@ -1194,6 +1201,7 @@ ecore_con_event_client_error(Ecore_Con_Client *obj, const char *error)
    cl->event_count = eina_list_append(cl->event_count, e);
    cl->host_server->event_count = eina_list_append(cl->host_server->event_count, e);
    ecore_event_add(ECORE_CON_EVENT_CLIENT_ERROR, e, (Ecore_End_Cb)_ecore_con_event_client_error_free, cl->host_server);
+   eo_do(obj, eo_event_callback_call(ECORE_CON_EVENT_CONNECTION_ERROR, e->error));
    _ecore_con_event_count++;
 }
 
index 8fe53c358080c72afb911bef1aeff87b5e0af01c..e53ae7142342fececc38855a4fb398f08eb664c8 100644 (file)
@@ -163,8 +163,19 @@ abstract Ecore.Con (Eo.Base) {
       virtual.flush;
       virtual.send;
    }
+   events {
+        data,received: Ecore_Con_Event_Data_Received;
+        connection,upgraded;
+        connection,error: const(char) *;
+   }
 }
 
+/* FIXME: Should actually be a binbuf. */
+type Ecore_Con_Event_Data_Received: struct {
+    data: void *; /*@ The data thet got sent. */
+    size: int; /*@ The length of the data sent. */
+};
+
 type Ecore_Con_Dns_Cb: func void (const(char) *,
                                  const(char) *,
                                  struct sockaddr *,