home *** CD-ROM | disk | FTP | other *** search
-
- /*
- * SUB.C
- *
- * $Header: Beta:src/uucp/src/dmail/RCS/sub.c,v 1.1 90/02/02 12:03:38 dillon Exp Locker: dillon $
- *
- * (C) Copyright 1985-1990 by Matthew Dillon, All Rights Reserved.
- *
- * Global Routines: INDEXOF()
- * SIG()
- * POSITION_CURRENT()
- * SKIP_TO_DATE()
- * GET_FIELD()
- * COMPILE_FIELD()
- * ISFROM()
- * XSTRNCMP()
- * NEXT_WORD()
- * DONE()
- *
- */
-
- #include <signal.h>
- #include <stdio.h>
- #include "dmail.h"
- #include "config.h"
-
- #ifdef UNIX
- extern FILE *popen();
- #endif
-
- xfree(ptr)
- char *ptr;
- {
- static char *sptr;
-
- if (sptr)
- free (sptr);
- sptr = ptr;
- return (1);
- }
-
-
- indexof(num)
- register int num;
- {
- register int i, last;
-
- if (num < 1)
- num = -1;
- for (last = -1, i = 0; i < Entries; ++i) {
- if (Entry[i].no) {
- last = i;
- if (Entry[i].no == num)
- return (i);
- }
- }
- if (num == -1 && last >= 0)
- return (last);
- return (-1);
- }
-
- void
- null()
- {
- }
-
-
- position_current()
- {
- int pos;
-
- if (!m_fi)
- return(0);
- if (Current >= 0) {
- pos = Entry[Current].fpos;
- if (fseek (m_fi, pos, 0) < 0 || ftell(m_fi) != pos)
- puts ("ERROR: Cannot position file to message");
- } else {
- fseek (m_fi, 0, 0);
- }
- }
-
-
- skip_to_data(fi)
- FILE *fi;
- {
- static char buf[MAXFIELDSIZE];
-
- while (fgets (buf, MAXFIELDSIZE, fi) != NULL) {
- if (*buf == '\n')
- return (1);
- }
- return (-1);
- }
-
-
- char *
- get_field(str)
- char *str;
- {
- int i, entry = Current;
- int len = strlen(str);
-
- if (Current < 0)
- return("");
- i = get_extra (str);
- if (i >= 0)
- return (Entry[entry].fields[i]);
- if (m_fi == NULL)
- return ("");
- fseek (m_fi, Entry[entry].fpos, 0);
- while (fgets (Buf, MAXFIELDSIZE, m_fi) != NULL) {
- if (isfrom (Buf))
- break;
- if (strncmp (Buf, str, len) == 0) {
- Buf[strlen(Buf) - 1] = '\0';
- compile_field(Buf, m_fi);
- return (next_word (Buf));
- }
- }
- return ("");
- }
-
-
- compile_field(buf, fi)
- char *buf;
- FILE *fi;
- {
- int len, acc, pos;
-
- acc = 0;
- buf += strlen (buf) + 1;
- pos = ftell (fi);
- while (fgets (buf, MAXFIELDSIZE - acc, fi) != NULL) {
- if (*buf == ' ' || *buf == 9) {
- *(buf - 1) = '\n';
- len = strlen (buf) - 1;
- *(buf + len) = '\0';
- buf += len;
- acc += len + 2;
- if (acc > MAXFIELDSIZE - 10) {
- printf ("Warning: Field size beyond %d bytes\n", MAXFIELDSIZE);
- sleep (2);
- return (1);
- }
- } else {
- *buf = '\0';
- fseek (fi, pos, 0);
- return (1);
- }
- pos = ftell (fi);
- }
- fseek (fi, pos, 0);
- }
-
-
- isfrom(str)
- register char *str;
- {
- static char from[] = {"From "};
- register int i = 0;
-
- while (i < 5) {
- if (*str++ != from[i++])
- return (0);
- }
- return (1);
- }
-
-
- xstrncmp (src, dest, len)
- register char *src, *dest;
- register int len;
- {
- while (--len >= 0) {
- if ((*src & 0x1f) != (*dest & 0x1f)) {
- if ((*src & 0x1f) < (*dest & 0x1f))
- return (-1);
- return (1);
- }
- ++src; ++dest;
- }
- return (0);
- }
-
-
-
- char *
- next_word(str)
- register char *str;
- {
- while (*str && *str != ' ' && *str != 9)
- ++str;
- while (*str && (*str == ' ' || *str == 9))
- ++str;
- return (str);
- }
-
- void
- done(n)
- {
- char scr[64];
-
- push_break();
- sprintf (scr, "t:dmail%d", getpid());
- unlink (scr);
- sprintf (scr, "t:dmt%d", getpid());
- unlink (scr);
- unlink ("#");
- exit (n);
- }
-
- void
- fix_globals()
- {
- char *ptr;
-
- push_break();
- S_page = (ptr = get_var (LEVEL_SET, "page")) ?
- ((*ptr) ? atoi (ptr) : 24) : -1;
- if (S_page > 0 && (S_page -= 4) < 0)
- S_page = 1;
-
- S_sendmail = (ptr = get_var (LEVEL_SET, "sendmail")) ? ptr : GetConfigProgram(SENDMAIL);
- S_novibreak= (ptr = get_var (LEVEL_SET, "vibreak")) ? 0 : 1;
- S_verbose = (ptr = get_var (LEVEL_SET, "verbose")) ? 1 : 0;
- S_ask = (ptr = get_var (LEVEL_SET, "ask")) ? 1 : 0;
- S_archive = (ptr = get_var (LEVEL_SET, "archive")) ? 1 : 0;
- if (S_archive && *ptr == '\0')
- S_archive = 0;
- pop_break();
- }
-
-
- _pager(str, nl)
- char *str;
- int nl;
- {
- static int count;
- static FILE *fi;
- static char buf[1024];
- #ifdef UNIX
- char *ptr;
- #endif
-
- if (str == 0) {
- switch (S_page) {
- case -1:
- count = 0;
- return (1);
- case 0:
- #ifdef UNIX
- ptr = get_var (LEVEL_SET, "page");
- fi = popen (ptr, "w");
- if (fi == NULL) {
- count = 0;
- printf ("CANNOT RUN PAGER PROGRAM: %s\n", ptr);
- } else {
- count = -1;
- }
- #else
- count = 0;
- fi = stdout;
- #endif
- return (1);
- default:
- count = 0;
- return (1);
- }
- }
- if ((long)str == -1) {
- #ifdef UNIX
- if (fi != NULL) {
- pclose (fi);
- fi = NULL;
- }
- #else
- fi = NULL;
- #endif
- return (1);
- }
- if (count < 0) {
- fputs (str, fi);
- while (nl--)
- fputs ("\n", fi);
- } else {
- fputs (str, stdout);
- while (nl--) {
- fputs ("\n", stdout);
- ++count;
- }
- #ifdef AMIGA
- fflush(stdout);
- #endif
- while (*str) {
- if (*str++ == '\n')
- ++count;
- }
- if (S_page > 0 && S_page <= count) {
- count = 0;
- puts ("\n-- more --");
- gets(buf);
- }
- }
- }
-
-