source: perlglue.xs @ 8203afd

barnowl_perlaimdebianrelease-1.4release-1.5release-1.6release-1.7release-1.8release-1.9
Last change on this file since 8203afd was 8203afd, checked in by Nelson Elhage <nelhage@mit.edu>, 14 years ago
* Renaming package owl to BarnOwl:: * Moving hooks into the BarnOwl::Hooks package, and restoring support for .owlconf files that use sub startup {} and so on.
  • Property mode set to 100644
File size: 4.9 KB
Line 
1/* -*- mode: c; indent-tabs-mode: t; c-basic-offset: 8 -*- */
2static const char fileIdent[] = "$Id$";
3
4#ifdef HAVE_LIBZEPHYR
5#include <zephyr/zephyr.h>
6#endif
7#include <EXTERN.h>
8
9#define OWL_PERL
10#include "owl.h"
11SV *owl_perlconfig_curmessage2hashref(void);
12
13#define SV_IS_CODEREF(sv) (SvROK((sv)) && SvTYPE(SvRV((sv))) == SVt_PVCV)
14
15MODULE = BarnOwl                PACKAGE = BarnOwl               
16
17char *
18command(cmd)
19        char *cmd
20        PREINIT:
21                char *rv = NULL;
22        CODE:
23                rv = owl_function_command(cmd);
24                RETVAL = rv;   
25        OUTPUT:
26                RETVAL
27        CLEANUP:
28                if (rv) owl_free(rv);
29
30SV *
31getcurmsg()
32        CODE:
33                ST(0) = owl_perlconfig_curmessage2hashref();
34
35int
36getnumcols()
37        CODE:
38                RETVAL = owl_global_get_cols(&g);
39        OUTPUT:
40                RETVAL
41
42char *
43zephyr_getrealm()
44        CODE:
45                RETVAL = owl_zephyr_get_realm();
46        OUTPUT:
47                RETVAL
48
49char *
50zephyr_getsender()
51        CODE:
52                RETVAL = owl_zephyr_get_sender();
53        OUTPUT:
54                RETVAL
55
56void
57zephyr_zwrite(cmd,msg)
58        char *cmd
59        char *msg
60        PREINIT:
61                int i;
62        CODE:
63                i = owl_zwrite_create_and_send_from_line(cmd, msg);
64
65char *
66ztext_stylestrip(ztext)
67        char *ztext
68        PREINIT:
69                char *rv = NULL;
70        CODE:
71                rv = owl_function_ztext_stylestrip(ztext);
72                RETVAL = rv;
73        OUTPUT:
74                RETVAL
75        CLEANUP:
76                if (rv) owl_free(rv);
77
78void
79new_command_internal(name, func, summary, usage, description)
80        char *name
81        SV *func
82        char *summary
83        char *usage
84        char *description
85        PREINIT:
86                owl_cmd cmd;
87        CODE:
88        {
89                if(!SV_IS_CODEREF(func)) {
90                        croak("Command function must be a coderef!");
91                }
92                SvREFCNT_inc(func);
93                cmd.name = name;
94                cmd.cmd_perl = func;
95                cmd.summary = summary;
96                cmd.usage = usage;
97                cmd.description = description;
98                cmd.validctx = OWL_CTX_ANY;
99                cmd.cmd_aliased_to = NULL;
100                cmd.cmd_args_fn = NULL;
101                cmd.cmd_v_fn = NULL;
102                cmd.cmd_i_fn = NULL;
103                cmd.cmd_ctxargs_fn = NULL;
104                cmd.cmd_ctxv_fn = NULL;
105                cmd.cmd_ctxi_fn = NULL;
106                owl_cmddict_add_cmd(owl_global_get_cmddict(&g), &cmd);
107           }
108
109void queue_message(msg) 
110        SV *msg
111        PREINIT:
112                char * key;
113                char * val;
114                owl_message *m;
115                HV * hash;
116                HE * ent;
117                I32 count;
118                I32 len;
119        CODE:
120        {
121                if(!SvROK(msg) || SvTYPE(SvRV(msg)) != SVt_PVHV) {
122                        croak("Usage: owl::queue_message($message)");
123                }
124
125                hash = (HV*)SvRV(msg);
126                m = owl_malloc(sizeof(owl_message));
127                owl_message_init(m);
128
129                count = hv_iterinit(hash);
130                while((ent = hv_iternext(hash))) {
131                        key = hv_iterkey(ent, &len);
132                        val = SvPV_nolen(hv_iterval(hash, ent));
133                        if(!strcmp(key, "type")) {
134                                owl_message_set_type(m, owl_message_parse_type(val));
135                        } else if(!strcmp(key, "direction")) {
136                                owl_message_set_direction(m, owl_message_parse_direction(val));
137                        } else if(!strcmp(key, "private")) {
138                                SV * v = hv_iterval(hash, ent);
139                                if(SvTRUE(v)) {
140                                        owl_message_set_isprivate(m);
141                                }
142                        } else if (!strcmp(key, "hostname")) {
143                                owl_message_set_hostname(m, val);
144                        } else if (!strcmp(key, "zwriteline")) {
145                                owl_message_set_zwriteline(m, val);
146                        } else if (!strcmp(key, "time")) {
147                                m->timestr = owl_strdup(val);
148                                struct tm tm;
149                                strptime(val, "%a %b %d %T %Y", &tm);
150                                m->time = mktime(&tm);
151                        } else {
152                                owl_message_set_attribute(m, key, val);
153                        }
154                }
155                if(owl_message_is_type_admin(m)) {
156                        if(!owl_message_get_attribute_value(m, "adminheader"))
157                                owl_message_set_attribute(m, "adminheader", "");
158                } 
159
160                owl_global_messagequeue_addmsg(&g, m);
161        }
162
163void start_question(line, callback)
164        char *line
165        SV *callback
166        PREINIT:
167        CODE:
168        {
169                if(!SV_IS_CODEREF(callback))
170                        croak("Callback must be a subref");
171
172                owl_function_start_question(line);
173
174                SvREFCNT_inc(callback);
175                owl_editwin_set_cbdata(owl_global_get_typwin(&g), callback);
176                owl_editwin_set_callback(owl_global_get_typwin(&g), owl_perlconfig_edit_callback);
177        }
178
179void start_password(line, callback)
180        char *line
181        SV *callback
182        PREINIT:
183        CODE:
184        {
185                if(!SV_IS_CODEREF(callback))
186                        croak("Callback must be a subref");
187
188                owl_function_start_password(line);
189
190                SvREFCNT_inc(callback);
191                owl_editwin_set_cbdata(owl_global_get_typwin(&g), callback);
192                owl_editwin_set_callback(owl_global_get_typwin(&g), owl_perlconfig_edit_callback);
193        }
194
195void start_edit_win(line, callback)
196        char *line
197        SV *callback
198        PREINIT:
199                owl_editwin * e;
200                char buff[1024];
201        CODE:
202        {
203                if(!SV_IS_CODEREF(callback))
204                        croak("Callback must be a subref");
205
206                e = owl_global_get_typwin(&g);
207                owl_editwin_new_style(e, OWL_EDITWIN_STYLE_MULTILINE,
208                                      owl_global_get_msg_history(&g));
209                owl_editwin_clear(e);
210                owl_editwin_set_dotsend(e);
211                snprintf(buff, 1023, "----> %s\n", line);
212                owl_editwin_set_locktext(e, buff);
213
214                owl_global_set_typwin_active(&g);
215
216                SvREFCNT_inc(callback);
217                owl_editwin_set_cbdata(owl_global_get_typwin(&g), callback);
218                owl_editwin_set_callback(owl_global_get_typwin(&g), owl_perlconfig_edit_callback);
219        }
220
221
222char * 
223get_data_dir ()
224        CODE:
225                RETVAL = (char *) DATADIR;
226        OUTPUT:
227        RETVAL
228
229void
230popless_text(text) 
231        char *text
232        CODE:
233        {
234                owl_function_popless_text(text);
235        }
236
237void
238popless_ztext(text) 
239        char *text
240        CODE:
241        {
242                owl_fmtext fm;
243                owl_fmtext_init_null(&fm);
244                owl_fmtext_append_ztext(&fm, text);
245                owl_function_popless_fmtext(&fm);
246                owl_fmtext_free(&fm);
247        }
Note: See TracBrowser for help on using the repository browser.