X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/9dcfb0e00efe340dda3234940cf27cf691b055e9..3910a511d4d9ad19e5eeff769881f4e52f498947:/sbr/seq_read.c?ds=sidebyside diff --git a/sbr/seq_read.c b/sbr/seq_read.c index aeb76fc1..759dba49 100644 --- a/sbr/seq_read.c +++ b/sbr/seq_read.c @@ -15,7 +15,7 @@ * static prototypes */ static int seq_init (struct msgs *, char *, char *); -static void seq_public (struct msgs *, int); +static int seq_public (struct msgs *, int, int *); static void seq_private (struct msgs *); @@ -25,9 +25,11 @@ static void seq_private (struct msgs *); * or context file (for private sequences). */ -void +int seq_read (struct msgs *mp, int lockflag) { + int failed_to_lock = 0; + /* * Initialize the list of sequence names. Go ahead and * add the "cur" sequence to the list of sequences. @@ -37,13 +39,17 @@ seq_read (struct msgs *mp, int lockflag) /* If folder is empty, don't scan for sequence information */ if (mp->nummsg == 0) - return; + return OK; /* Initialize the public sequences */ - seq_public (mp, lockflag); + if (seq_public (mp, lockflag, &failed_to_lock) == NOTOK) { + if (failed_to_lock) return NOTOK; + } /* Initialize the private sequences */ seq_private (mp); + + return OK; } @@ -51,8 +57,8 @@ seq_read (struct msgs *mp, int lockflag) * read folder's sequences file for public sequences */ -static void -seq_public (struct msgs *mp, int lockflag) +static int +seq_public (struct msgs *mp, int lockflag, int *failed_to_lock) { int state; char *cp, seqfile[PATH_MAX]; @@ -66,13 +72,14 @@ seq_public (struct msgs *mp, int lockflag) * then just return, and do not initialize any public sequences. */ if (mh_seq == NULL || *mh_seq == '\0') - return; + return OK; /* get filename of sequence file */ snprintf (seqfile, sizeof(seqfile), "%s/%s", mp->foldpath, mh_seq); - if ((fp = lkfopendata (seqfile, lockflag ? "r+" : "r")) == NULL) - return; + if ((fp = lkfopendata (seqfile, lockflag ? "r+" : "r", failed_to_lock)) + == NULL) + return NOTOK; /* Use m_getfld to scan sequence file */ for (;;) { @@ -116,6 +123,8 @@ seq_public (struct msgs *mp, int lockflag) } else { lkfclosedata (fp, seqfile); } + + return OK; } @@ -177,7 +186,7 @@ seq_init (struct msgs *mp, char *name, char *field) * Search for this sequence name to see if we've seen * it already. If we've seen this sequence before, * then clear the bit for this sequence from all the - * mesages in this folder. + * messages in this folder. */ for (i = 0; i < svector_size (mp->msgattrs); i++) { if (!strcmp (svector_at (mp->msgattrs, i), name)) {