source: util.c @ 10b866d

barnowl_perlaimdebianowlrelease-1.10release-1.4release-1.5release-1.6release-1.7release-1.8release-1.9
Last change on this file since 10b866d was 10b866d, checked in by Erik Nygren <nygren@mit.edu>, 22 years ago
* Fixed preservation of e->dotsend across owl_editwin_clear(). * Added history for multiline edit windows (eg, for zephyr composition). The M-n and M-p keys will cycle through the history ring. In particular, it is now possible to edit the command line of a zephyr being composed: C-c it and restart it and then M-p to get the aborted composition back.
  • Property mode set to 100644
File size: 9.6 KB
Line 
1#include "owl.h"
2#include <stdlib.h>
3#include <string.h>
4#include <malloc.h>
5#include <ctype.h>
6
7static const char fileIdent[] = "$Id$";
8
9void sepbar(char *in) {
10  char buff[1024];
11  WINDOW *sepwin;
12  owl_messagelist *ml;
13  owl_view *v;
14  int x, y, i;
15  char *foo, *appendtosepbar;
16
17  sepwin=owl_global_get_curs_sepwin(&g);
18  ml=owl_global_get_msglist(&g);
19  v=owl_global_get_current_view(&g);
20
21  werase(sepwin);
22  wattron(sepwin, A_REVERSE);
23  whline(sepwin, ACS_HLINE, owl_global_get_cols(&g));
24
25  wmove(sepwin, 0, 2); 
26
27  if (owl_messagelist_get_size(ml)==0) {
28    strcpy(buff, " (-/-) ");
29  } else {
30    snprintf(buff, 1024, " (%i/%i/%i) ", owl_global_get_curmsg(&g)+1,
31            owl_view_get_size(v),
32            owl_messagelist_get_size(ml));
33  }
34  waddstr(sepwin, buff);
35
36  foo=owl_view_get_filtname(v);
37  if (strcmp(foo, "all")) wattroff(sepwin, A_REVERSE);
38  waddstr(sepwin, " ");
39  waddstr(sepwin, owl_view_get_filtname(v));
40  waddstr(sepwin, " ");
41  if (strcmp(foo, "all")) wattron(sepwin, A_REVERSE);
42
43  if (owl_mainwin_is_curmsg_truncated(owl_global_get_mainwin(&g))) {
44    getyx(sepwin, y, x);
45    wmove(sepwin, y, x+2);
46    wattron(sepwin, A_BOLD);
47    waddstr(sepwin, " <truncated> ");
48    wattroff(sepwin, A_BOLD);
49  }
50
51  i=owl_mainwin_get_last_msg(owl_global_get_mainwin(&g));
52  if ((i != -1) &&
53      (i < owl_view_get_size(v)-1)) {
54    getyx(sepwin, y, x);
55    wmove(sepwin, y, x+2);
56    wattron(sepwin, A_BOLD);
57    waddstr(sepwin, " <more> ");
58    wattroff(sepwin, A_BOLD);
59  }
60
61  if (owl_global_get_rightshift(&g)>0) {
62    getyx(sepwin, y, x);
63    wmove(sepwin, y, x+2);
64    snprintf(buff, 1024, " right: %i ", owl_global_get_rightshift(&g));
65    waddstr(sepwin, buff);
66  }
67
68  if (owl_global_is_zaway(&g)) {
69    getyx(sepwin, y, x);
70    wmove(sepwin, y, x+2);
71    wattron(sepwin, A_BOLD);
72    wattroff(sepwin, A_REVERSE);
73    waddstr(sepwin, " ZAWAY ");
74    wattron(sepwin, A_REVERSE);
75    wattroff(sepwin, A_BOLD);
76  }
77
78  if (owl_global_get_curmsg_vert_offset(&g)) {
79    getyx(sepwin, y, x);
80    wmove(sepwin, y, x+2);
81    wattron(sepwin, A_BOLD);
82    wattroff(sepwin, A_REVERSE);
83    waddstr(sepwin, " SCROLL ");
84    wattron(sepwin, A_REVERSE);
85    wattroff(sepwin, A_BOLD);
86  }
87 
88  if (in) {
89    getyx(sepwin, y, x);
90    wmove(sepwin, y, x+2);
91    waddstr(sepwin, in);
92  }
93
94  appendtosepbar = owl_global_get_appendtosepbar(&g);
95  if (appendtosepbar && *appendtosepbar) {
96    getyx(sepwin, y, x);
97    wmove(sepwin, y, x+2);
98    waddstr(sepwin, " ");
99    waddstr(sepwin, owl_global_get_appendtosepbar(&g));
100    waddstr(sepwin, " ");
101  }
102
103  getyx(sepwin, y, x);
104  wmove(sepwin, y, owl_global_get_cols(&g)-1);
105   
106  wattroff(sepwin, A_BOLD);
107  wattroff(sepwin, A_REVERSE);
108  wnoutrefresh(sepwin);
109}
110
111
112void pophandler_quit(int ch) {
113  if (ch=='q') {
114    owl_popwin_close(owl_global_get_popwin(&g));
115  }
116}
117
118char **atokenize(char *buffer, char *sep, int *i) {
119  /* each element of return must be freed by user */
120  char **args;
121  char *workbuff, *foo;
122  int done=0, first=1, count=0;
123
124  workbuff=owl_malloc(strlen(buffer)+1);
125  memcpy(workbuff, buffer, strlen(buffer)+1);
126
127  args=NULL;
128  while (!done) {
129    if (first) {
130      first=0;
131      foo=(char *)strtok(workbuff, sep);
132    } else {
133      foo=(char *)strtok(NULL, sep);
134    }
135    if (foo==NULL) {
136      done=1;
137    } else {
138      args=(char **)owl_realloc(args, sizeof(char *) * (count+1));
139      args[count]=owl_malloc(strlen(foo)+1);
140      strcpy(args[count], foo);
141      count++;
142    }
143  }
144  *i=count;
145  owl_free(workbuff);
146  return(args);
147}
148
149/* skips n tokens and returns where that would be.
150 * TODO: handle quotes. */
151char *skiptokens(char *buff, int n) {
152  int inquotes=0;
153  while (*buff && n>0) {
154      while (*buff == ' ') buff++;
155      while (*buff && (inquotes || *buff != ' ')) { 
156        if (*buff == '"') inquotes=!inquotes;
157        buff++;
158      }
159      while (*buff == ' ') buff++;
160      n--;
161  }
162  return buff;
163}
164
165void atokenize_free(char **tok, int nels) {
166  int i;
167  for (i=0; i<nels; i++) {
168    owl_free(tok[i]);
169  }
170  owl_free(tok);
171}
172
173
174void owl_parsefree(char **argv, int argc) {
175  int i;
176
177  if (!argv) return;
178 
179  for (i=0; i<argc; i++) {
180    if (argv[i]) owl_free(argv[i]);
181  }
182  owl_free(argv);
183}
184
185char **owl_parseline(char *line, int *argc) {
186  /* break a command line up into argv, argc.  The caller must free
187     the returned values.  If there is an error argc will be set to
188     -1, argv will be NULL and the caller does not need to free
189     anything */
190
191  char **argv;
192  int i, len, between=1;
193  char *curarg;
194  char quote;
195
196  argv=owl_malloc(sizeof(char *));
197  len=strlen(line);
198  curarg=owl_malloc(len+10);
199  strcpy(curarg, "");
200  quote='\0';
201  *argc=0;
202  for (i=0; i<len+1; i++) {
203    /* find the first real character */
204    if (between) {
205      if (line[i]==' ' || line[i]=='\t' || line[i]=='\0') {
206        continue;
207      } else {
208        between=0;
209        i--;
210        continue;
211      }
212    }
213
214    /* deal with a quote character */
215    if (line[i]=='"' || line[i]=="'"[0]) {
216      /* if this type of quote is open, close it */
217      if (quote==line[i]) {
218        quote='\0';
219        continue;
220      }
221
222      /* if no quoting is open then open with this */
223      if (quote=='\0') {
224        quote=line[i];
225        continue;
226      }
227
228      /* if another type of quote is open then treat this as a literal */
229      curarg[strlen(curarg)+1]='\0';
230      curarg[strlen(curarg)]=line[i];
231      continue;
232    }
233
234    /* if it's not a space or end of command, then use it */
235    if (line[i]!=' ' && line[i]!='\t' && line[i]!='\n' && line[i]!='\0') {
236      curarg[strlen(curarg)+1]='\0';
237      curarg[strlen(curarg)]=line[i];
238      continue;
239    }
240
241    /* otherwise, if we're not in quotes, add the whole argument */
242    if (quote=='\0') {
243      /* add the argument */
244      argv=owl_realloc(argv, sizeof(char *)*((*argc)+1));
245      argv[*argc]=owl_malloc(strlen(curarg)+2);
246      strcpy(argv[*argc], curarg);
247      *argc=*argc+1;
248      strcpy(curarg, "");
249      between=1;
250      continue;
251    }
252
253    /* if it is a space and we're in quotes, then use it */
254    curarg[strlen(curarg)+1]='\0';
255    curarg[strlen(curarg)]=line[i];
256  }
257
258  /* check for unbalanced quotes */
259  if (quote!='\0') {
260    owl_parsefree(argv, *argc);
261    *argc=-1;
262    return(NULL);
263  }
264
265  return(argv);
266}
267
268
269
270int owl_util_find_trans(char *in, int len) {
271  /* return the index of the last char before a change from the first
272     one */
273  int i;
274  for (i=1; i<len; i++) {
275    if (in[i] != in[0]) return(i-1);
276  }
277  return(i);
278}
279
280
281void downstr(char *foo) {
282  int i;
283  for (i=0; foo[i]!='\0'; i++) {
284    foo[i]=tolower(foo[i]);
285  }
286}
287
288char *stristr(char *a, char *b) {
289  char *x, *y, *ret;
290
291  if ((x=owl_strdup(a))==NULL) return(NULL);
292  if ((y=owl_strdup(b))==NULL) return(NULL);
293  downstr(x);
294  downstr(y);
295  ret=strstr(x, y);
296  owl_free(x);
297  owl_free(y);
298  return(ret);
299}
300
301/* returns if a string is only whitespace */
302int only_whitespace(char *s) {
303  int i;
304  for (i=0; s[i]; i++) {
305    if (!isspace(s[i])) return(0);
306  }
307  return(1);
308}
309
310void *owl_malloc(size_t size) {
311  return(malloc(size));
312}
313
314void owl_free(void *ptr) {
315  free(ptr);
316}
317
318char *owl_strdup(const char *s1) {
319  return(strdup(s1));
320}
321
322void *owl_realloc(void *ptr, size_t size) {
323  return(realloc(ptr, size));
324}
325
326/* allocates memory and returns the string or null.
327 * caller must free the string.
328 * from Linux sprintf man page.
329 */
330char *owl_sprintf(const char *fmt, ...) {
331  int n, size = 100;
332  char *p;
333  va_list ap;
334  if ((p = owl_malloc (size)) == NULL)
335    return NULL;
336  while (1) {
337    /* Try to print in the allocated space. */
338    va_start(ap, fmt);
339    n = vsnprintf (p, size, fmt, ap);
340    va_end(ap);
341    /* If that worked, return the string. */
342    if (n > -1 && n < size)
343      return p;
344    /* Else try again with more space. */
345    if (n > -1)    /* glibc 2.1 */
346      size = n+1; /* precisely what is needed */
347    else           /* glibc 2.0 */
348      size *= 2;  /* twice the old size */
349    if ((p = owl_realloc (p, size)) == NULL)
350      return NULL;
351  }
352}
353
354char *pretty_sender(char *in) {
355  char *out, *ptr;
356 
357  /* the caller must free the return */
358  out=owl_strdup(in);
359  ptr=strchr(out, '@');
360  if (ptr) {
361    if (!strcasecmp(ptr+1, ZGetRealm())) {
362      *ptr='\0';
363    }
364  }
365  return(out);
366}
367
368char *long_sender(char *in) {
369  char *ptr;
370
371  /* the caller must free the return */
372  if (NULL != (ptr=strchr(in, '@'))) {
373    return owl_strdup(in);
374  } else {
375    return owl_sprintf("%s@%s", in, ZGetRealm());
376  }
377}
378                 
379
380char *owl_getquoting(char *line) {
381  if (line[0]=='\0') return("'");
382  if (strchr(line, '\'')) return("\"");
383  if (strchr(line, '"')) return("'");
384  if (strchr(line, ' ')) return("'");
385  return("");
386}
387
388
389int owl_util_string_to_color(char *color) {
390  if (!strcasecmp(color, "black")) {
391    return(OWL_COLOR_BLACK);
392  } else if (!strcasecmp(color, "red")) {
393    return(OWL_COLOR_RED);
394  } else if (!strcasecmp(color, "green")) {
395    return(OWL_COLOR_GREEN);
396  } else if (!strcasecmp(color, "yellow")) {
397    return(OWL_COLOR_YELLOW);
398  } else if (!strcasecmp(color, "blue")) {
399    return(OWL_COLOR_BLUE);
400  } else if (!strcasecmp(color, "magenta")) {
401    return(OWL_COLOR_MAGENTA);
402  } else if (!strcasecmp(color, "cyan")) {
403    return(OWL_COLOR_CYAN);
404  } else if (!strcasecmp(color, "white")) {
405    return(OWL_COLOR_WHITE);
406  } else if (!strcasecmp(color, "default")) {
407    return(OWL_COLOR_DEFAULT);
408  }
409  return(OWL_COLOR_DEFAULT);
410}
411
412char *owl_util_color_to_string(int color) {
413  if (color==OWL_COLOR_BLACK)   return("black");
414  if (color==OWL_COLOR_RED)     return("red");
415  if (color==OWL_COLOR_GREEN)   return("green");
416  if (color==OWL_COLOR_YELLOW)  return("yellow");
417  if (color==OWL_COLOR_BLUE)    return("blue");
418  if (color==OWL_COLOR_MAGENTA) return("magenta");
419  if (color==OWL_COLOR_CYAN)    return("cyan");
420  if (color==OWL_COLOR_WHITE)   return("white");
421  if (color==OWL_COLOR_DEFAULT) return("default");
422  return("Unknown color");
423}
Note: See TracBrowser for help on using the repository browser.