From: jsancho Date: Thu, 25 Aug 2011 18:43:22 +0000 (+0000) Subject: (no commit message) X-Git-Url: https://git.jsancho.org/?p=gacela.git;a=commitdiff_plain;h=4e40519197d7b6e04e0d73204447bb9ed01ff3b1 --- diff --git a/emacs/emacs.conf b/emacs/emacs.conf new file mode 100644 index 0000000..65645a5 --- /dev/null +++ b/emacs/emacs.conf @@ -0,0 +1,21 @@ +;;; Gacela configuration + +(defun launch-gacela () + (interactive) + (start-process "gacela" "gacela" "/home/jsancho/proyectos/gacela/trunk/src/gacela" "--dev")) + +(defun send-to-gacela () + (interactive) + (cond ((not (get-process "gacela")) + (launch-gacela))) + (cond ((use-region-p) + (process-send-region "gacela" (region-beginning) (region-end))) + (t + (process-send-region "gacela" (point-min-marker) (point-max-marker))))) + +(define-key global-map [(ctrl x) (ctrl g)] 'send-to-gacela) + +(define-key-after global-map [menu-bar tools gacela] (cons "Gacela" (make-sparse-keymap "hoot hoot")) 'games) +(define-key global-map [menu-bar tools gacela send] '("Send to Gacela" . send-to-gacela)) +(define-key global-map [menu-bar tools gacela launch] '("Launch Gacela" . launch-gacela)) + diff --git a/src/gacela.c b/src/gacela.c index ef4ca1d..b2fe671 100644 --- a/src/gacela.c +++ b/src/gacela.c @@ -30,9 +30,11 @@ #include "gacela_GL.h" #include "gacela_FTGL.h" -// Generic variables +// Global variables int ctrl_c = 0; int pid = 0; +char *history_path = NULL; + static int find_matching_paren (int k) @@ -117,15 +119,16 @@ ctrl_c_handler (int signum) } void -look_child_handler (int signum) +child_dies_handler (int signum) { - printf ("Hola\n"); + write_history (history_path); + exit (0); } static void init_gacela_client () { - struct sigaction ctrl_c_action, look_child_action; + struct sigaction ctrl_c_action, child_dies_action; // init bouncing parens rl_bind_key (')', match_paren); @@ -141,11 +144,11 @@ init_gacela_client () // SIGALRM if (pid != 0) { - look_child_action.sa_handler = look_child_handler; - sigemptyset (&look_child_action.sa_mask); - look_child_action.sa_flags = 0; + child_dies_action.sa_handler = child_dies_handler; + sigemptyset (&child_dies_action.sa_mask); + child_dies_action.sa_flags = 0; - sigaction (SIGALRM, &look_child_action, NULL); + sigaction (SIGALRM, &child_dies_action, NULL); } } @@ -190,7 +193,6 @@ gacela_client (SCM rec_channel, SCM send_channel) int n; SCM buffer; char *line = NULL, *line_for_sending = NULL; - char *history_path; int opened = 0; // Command line @@ -359,6 +361,7 @@ main (int argc, char *argv[]) scm_close (SCM_CDR (fd2)); init_gacela (dirname (argv[0])); start_local_server (scm_cons (SCM_CAR (fd2), SCM_CDR (fd1))); + kill (getppid (), SIGALRM); } else { scm_close (SCM_CDR (fd1));