X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/9a33ff618b5901a3af815650d4b84d39ee96e529..26cad4056c927e609753103897a60d00611ac9f7:/sbr/seq_read.c?ds=sidebyside diff --git a/sbr/seq_read.c b/sbr/seq_read.c index c18d1dae..831efd28 100644 --- a/sbr/seq_read.c +++ b/sbr/seq_read.c @@ -3,8 +3,6 @@ * seq_read.c -- read the .mh_sequence file and * -- initialize sequence information * - * $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. @@ -17,7 +15,7 @@ * static prototypes */ static int seq_init (struct msgs *, char *, char *); -static void seq_public (struct msgs *); +static void seq_public (struct msgs *, int); static void seq_private (struct msgs *); @@ -28,7 +26,7 @@ static void seq_private (struct msgs *); */ void -seq_read (struct msgs *mp) +seq_read (struct msgs *mp, int lockflag) { /* * Initialize the list of sequence names. Go ahead and @@ -43,7 +41,7 @@ seq_read (struct msgs *mp) return; /* Initialize the public sequences */ - seq_public (mp); + seq_public (mp, lockflag); /* Initialize the private sequences */ seq_private (mp); @@ -55,12 +53,13 @@ seq_read (struct msgs *mp) */ static void -seq_public (struct msgs *mp) +seq_public (struct msgs *mp, int lockflag) { int state; char *cp, seqfile[PATH_MAX]; char name[NAMESZ], field[BUFSIZ]; FILE *fp; + m_getfld_state_t gstate = 0; /* * If mh_seq == NULL (such as if nmh been compiled with @@ -74,19 +73,20 @@ seq_public (struct msgs *mp) /* get filename of sequence file */ snprintf (seqfile, sizeof(seqfile), "%s/%s", mp->foldpath, mh_seq); - if ((fp = lkfopen (seqfile, "r")) == NULL) + if ((fp = lkfopendata (seqfile, lockflag ? "r+" : "r")) == NULL) return; /* Use m_getfld to scan sequence file */ - for (state = FLD;;) { - switch (state = m_getfld (state, name, field, sizeof(field), fp)) { + for (;;) { + int fieldsz = sizeof field; + switch (state = m_getfld (&gstate, name, field, &fieldsz, fp)) { case FLD: case FLDPLUS: - case FLDEOF: if (state == FLDPLUS) { cp = getcpy (field); while (state == FLDPLUS) { - state = m_getfld (state, name, field, sizeof(field), fp); + fieldsz = sizeof field; + state = m_getfld (&gstate, name, field, &fieldsz, fp); cp = add (field, cp); } seq_init (mp, getcpy (name), trimcpy (cp)); @@ -94,12 +94,10 @@ seq_public (struct msgs *mp) } else { seq_init (mp, getcpy (name), trimcpy (field)); } - if (state == FLDEOF) - break; continue; - case BODY: - case BODYEOF: + case BODY: + lkfclosedata (fp, seqfile); adios (NULL, "no blank lines are permitted in %s", seqfile); /* fall */ @@ -107,12 +105,19 @@ seq_public (struct msgs *mp) break; default: + lkfclosedata (fp, seqfile); adios (NULL, "%s is poorly formatted", seqfile); } break; /* break from for loop */ } + m_getfld_state_destroy (&gstate); - lkfclose (fp, seqfile); + if (lockflag) { + mp->seqhandle = fp; + mp->seqname = getcpy(seqfile); + } else { + lkfclosedata (fp, seqfile); + } } @@ -160,7 +165,8 @@ seq_private (struct msgs *mp) static int seq_init (struct msgs *mp, char *name, char *field) { - int i, j, k, is_current; + unsigned int i; + int j, k, is_current; char *cp, **ap; /* @@ -185,6 +191,7 @@ seq_init (struct msgs *mp, char *name, char *field) /* Return error, if too many sequences */ if (i >= NUMATTRS) { + admonish (NULL, "Too many sequences, sequence %s ignored", name); free (name); free (field); return -1;