/*
* dp.c -- parse dates 822-style
*
- * $Id$
+ * This code is Copyright (c) 2002, by the authors of nmh. See the
+ * COPYRIGHT file in the root directory of the nmh distribution for
+ * complete copyright information.
*/
#include <h/mh.h>
+#include <h/utils.h>
#include <h/fmt_scan.h>
-#include <zotnet/tws/tws.h>
+#include <h/tws.h>
#define NDATES 100
#define WIDTH 78
-#define WBUFSIZ BUFSIZ
#define FORMAT "%<(nodate{text})error: %{text}%|%(putstr(pretty{text}))%>"
-static struct swit switches[] = {
-#define FORMSW 0
- { "form formatfile", 0 },
-#define FMTSW 1
- { "format string", 5 },
-#define WIDTHSW 2
- { "width columns", 0 },
-#define VERSIONSW 3
- { "version", 0 },
-#define HELPSW 4
- { "help", 0 },
- { NULL, 0 }
-};
+#define DP_SWITCHES \
+ X("form formatfile", 0, FORMSW) \
+ X("format string", 5, FMTSW) \
+ X("width columns", 0, WIDTHSW) \
+ X("version", 0, VERSIONSW) \
+ X("help", 0, HELPSW) \
+
+#define X(sw, minchars, id) id,
+DEFINE_SWITCH_ENUM(DP);
+#undef X
+
+#define X(sw, minchars, id) { sw, minchars, id },
+DEFINE_SWITCH_ARRAY(DP, switches);
+#undef X
static struct format *fmt;
static int dat[5];
-/*
- * prototypes
- */
-int sc_width (void); /* from termsbr.c */
-
/*
* static prototypes
*/
int
main (int argc, char **argv)
{
- int datep = 0, width = 0, status = 0;
+ int datep = 0, width = -1, status = 0;
char *cp, *form = NULL, *format = NULL, *nfs;
- char buf[BUFSIZ], **argp, **arguments;
- char *dates[NDATES];
-
-#ifdef LOCALE
- setlocale(LC_ALL, "");
-#endif
- invo_name = r1bindex (argv[0], '/');
+ char buf[BUFSIZ], **argp;
+ char *dates[NDATES + 1]; /* Includes terminating NULL. */
- /* read user profile/context */
- context_read();
-
- arguments = getarguments (invo_name, argc, argv, 1);
- argp = arguments;
+ if (nmh_init(argv[0], 2)) { return 1; }
+ argp = getarguments (invo_name, argc, argv, 1);
while ((cp = *argp++)) {
if (*cp == '-') {
switch (smatch (++cp, switches)) {
snprintf (buf, sizeof(buf), "%s [switches] dates ...",
invo_name);
print_help (buf, switches, 1);
- done (1);
+ done (0);
case VERSIONSW:
print_version(invo_name);
- done (1);
+ done (0);
case FORMSW:
if (!(form = *argp++) || *form == '-')
continue;
}
}
- if (datep > NDATES)
+ if (datep == NDATES)
adios (NULL, "more than %d dates", NDATES);
else
dates[datep++] = cp;
/* get new format string */
nfs = new_fs (form, format, FORMAT);
- if (width == 0) {
- if ((width = sc_width ()) < WIDTH / 2)
+ if (width == -1) {
+ if ((width = sc_width ()) < WIDTH / 2) {
+ /* Default: width of the terminal, but at least WIDTH/2. */
width = WIDTH / 2;
+ }
width -= 2;
+ } else if (width == 0) {
+ /* Unlimited width. */
+ width = INT_MAX;
}
- if (width > WBUFSIZ)
- width = WBUFSIZ;
- fmt_compile (nfs, &fmt);
+ fmt_compile (nfs, &fmt, 1);
dat[0] = 0;
dat[1] = 0;
status += process (dates[datep], width);
context_save (); /* save the context file */
- return done (status);
+ fmt_free (fmt, 1);
+ done (status);
+ return 1;
}
process (char *date, int length)
{
int status = 0;
- char buffer[WBUFSIZ + 1];
- register struct comp *cptr;
-
- FINDCOMP (cptr, "text");
- if (cptr)
- cptr->c_text = date;
- fmt_scan (fmt, buffer, length, dat);
- fputs (buffer, stdout);
+ charstring_t scanl =
+ charstring_create (length < NMH_BUFSIZ ? length : NMH_BUFSIZ);
+ struct comp *cptr;
+
+ cptr = fmt_findcomp ("text");
+ if (cptr) {
+ mh_xfree(cptr->c_text);
+ cptr->c_text = mh_xstrdup(date);
+ }
+ fmt_scan (fmt, scanl, length, dat, NULL);
+ fputs (charstring_buffer (scanl), stdout);
+ charstring_free (scanl);
return status;
}