diff nodejs/X_supp_njs.c @ 550:127499ab2412 Android_Skia

Upgrade ndoejs plugin to level of a new runtime. Original, nodejs plugin is a variant of X runtime. But, now, I think it had better a new runtime that reuse code of X runtime. It would be easier to maintain.
author Thinker K.F. Li <thinker@branda.to>
date Sun, 06 Jun 2010 13:58:01 +0800
parents 249bcbf07eb0
children 9e69c4a0f565
line wrap: on
line diff
--- a/nodejs/X_supp_njs.c	Sun Jun 06 13:48:13 2010 +0800
+++ b/nodejs/X_supp_njs.c	Sun Jun 06 13:58:01 2010 +0800
@@ -51,7 +51,7 @@
 x_conn_cb(EV_P_ ev_io *iowatcher, int revent) {
     njs_ev_data_t *ev_data = MEM2OBJ(iowatcher, njs_ev_data_t, iowatcher);
     redraw_man_t *rdman;
-    extern void _X_MB_handle_x_event_for_nodejs(X_MB_runtime_t *rt);
+    extern void _X_MB_handle_x_event_for_nodejs(void *rt);
 
     rdman = X_MB_rdman(ev_data->rt);
     _X_MB_handle_x_event_for_nodejs(ev_data->rt);
@@ -67,7 +67,7 @@
     mb_tman_t *tman;
     redraw_man_t *rdman;
     mb_timeval_t now;
-    extern int _X_MB_flush_x_conn_nodejs(X_MB_runtime_t *rt);
+    extern int _X_MB_flush_x_conn_nodejs(void *rt);
     
     tman = X_MB_tman(ev_data->rt);
     get_now(&now);
@@ -84,39 +84,30 @@
  *
  * \param rt is a runtime object for X.
  */
-void X_MB_handle_connection_njs(void *rt) {
-    X_MB_runtime_t *_rt = (X_MB_runtime_t *)rt;
-    njs_ev_data_t *ev_data;
+void
+X_njs_MB_handle_connection(njs_ev_data_t *ev_data) {
+    void *rt = ev_data->rt;
     mb_tman_t *tman;
     mb_timeval_t now, tmo;
     ev_tstamp tout;
     int fd;
     int r;
-    extern int _X_MB_get_x_conn_for_nodejs(X_MB_runtime_t *rt);
+    extern int _X_MB_get_x_conn_for_nodejs(void *rt);
 
-    ev_data = (njs_ev_data_t *)malloc(sizeof(njs_ev_data_t));
-    ASSERT(ev_data != NULL);
-    
-    _X_MB_set_data_nodejs(_rt, ev_data);
-    ev_data->rt = _rt;
-    ev_default_loop(0);
-    
     /*
      * Setup watcher for X connection.
      */
-    fd = _X_MB_get_x_conn_for_nodejs(_rt);
+    fd = _X_MB_get_x_conn_for_nodejs(rt);
     ev_io_init(&ev_data->iowatcher, x_conn_cb, fd, EV_READ);
     ev_io_start(&ev_data->iowatcher);
 
     set_next_timeout(ev_data);
 }
 
-void X_MB_stop_njs(void *rt) {
-    X_MB_runtime_t *_rt = (X_MB_runtime_t *)rt;
-    njs_ev_data_t *ev_data;
-
-    ev_data = (njs_ev_data_t *)_X_MB_get_x_conn_for_nodejs(_rt);
-    
+/*! \brief Free njs_ev_data_t.
+ */
+void
+X_njs_MB_free(njs_ev_data_t *ev_data) {
     /*
      * stop IO and timer watcher
      */
@@ -124,3 +115,24 @@
     if(ev_data->enable_timer)
 	ev_timer_stop(&ev_data->tmwatcher);
 }
+
+njs_ev_data_t *
+X_njs_MB_new(char *display_name, int w, int h) {
+    njs_ev_data_t *ev_data;
+    void *rt;
+    
+    ev_data = (njs_ev_data_t *)malloc(sizeof(njs_ev_data_t));
+    ASSERT(ev_data != NULL);
+
+    rt = X_MB_new(display_name, w, h);
+
+    ev_data->rt = rt;
+    ev_data->enable_timer = 0;	/* no timer, now */
+    
+    return ev_data;
+}
+
+void *
+_X_njs_MB_get_runtime(nsj_ev_data_t *ev_data) {
+    return ev_data->rt;
+}