File: addfname.c

package info (click to toggle)
zoo 2.10-27
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd, wheezy
  • size: 1,444 kB
  • ctags: 2,007
  • sloc: ansic: 18,494; asm: 793; makefile: 698
file content (135 lines) | stat: -rw-r--r-- 3,872 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
#ifndef LINT
static char sccsid[]="@(#) addfname.c 2.11 88/02/06 20:17:17";
#endif /* LINT */

/*
Copyright (C) 1986, 1987 Rahul Dhesi -- All rights reserved
(C) Copyright 1988 Rahul Dhesi -- All rights reserved
*/
#include "options.h"

/* Adds a filename to global list.  (This global list will eventually
be searched by the inlist() function.)  The second and subsequent
parameters suppplied are stored with the name of the file and 
returned by inlist. */

#include "zooio.h"
#include "various.h"
#include "zoo.h"
#include "zoofns.h"
#include "zoomem.h" /* to get LIST_SIZE */

#define FENTRY_BSIZE		80		/* allocation granularity for fentry below */
static struct item **fentry;	/* array of ptrs to file information structs */
static unsigned sz_fentry;		/* its current size */
static int lastname = 0;                  /* index of last name */

struct item {              /* global filename list entry */
   char *fname;
   long position;
   unsigned int date;
   unsigned int time;
	unsigned vflag;
	unsigned version_no;
};

void addfname(fname, position, date, time, vflag, version_no)
char *fname;
long position;
unsigned int date, time;
unsigned vflag;
unsigned version_no;
{
   if (lastname == 0) {
		sz_fentry = FENTRY_BSIZE;
		fentry = (struct item **) ealloc(sizeof(struct item *) * sz_fentry);
      fentry[0] = (struct item *) ealloc (sizeof(struct item));
	}

	/* allocated more memory if needed */
   if (lastname >= sz_fentry - 3) {
		sz_fentry += FENTRY_BSIZE;
		fentry = (struct item **) 
			erealloc(fentry, sizeof(struct item *) * sz_fentry);
	}

   fentry[lastname]->fname = str_dup(fname);
   fentry[lastname]->position = position;
   fentry[lastname]->date = date;
   fentry[lastname]->time = time;
	fentry[lastname]->vflag = vflag;
	fentry[lastname]->version_no = version_no;
   lastname++;
   /* allocate memory for empty entry at end */
   fentry[lastname] = (struct item *) ealloc (sizeof(struct item)); 
} /* addfname */

/* inlist() */
/* Examines global list built by addfname() to see if supplied filename
is in the list.  

If found, returns the file's position within the archive as the function 
value and the date, time, version flag, and version number as parameters.
If not found, returns -1.  Also returns the highest version no. seen
for this filename and the vflag associated with that version.

A simple sequential search is done.

If justname is nonzero, then the search is for the filename only
without the directory prefix;  else it is for the full
pathname.
*/

long inlist (fname, date, time, this_version_no, high_vflag, 
					high_version_no, high_pos, justname)
char *fname;
unsigned int *date, *time;
unsigned *high_vflag;
unsigned *this_version_no;
unsigned *high_version_no;
long *high_pos;
int justname;
{
   register int i = 0;

	*high_version_no = 0;
	if (justname)
		fname = nameptr (fname);					/* if directory wanted */
   fentry[lastname]->fname = fname;          /* sentinel */
	fentry[lastname]->version_no = 0;

#ifdef IGNORECASE
#define	COMPARE	str_icmp
#else
#define	COMPARE	strcmp
#endif

   while (COMPARE(fname,
			(justname ? nameptr (fentry[i]->fname) : fentry[i]->fname)) != 0) {
      i++;
   }

   if (i == lastname)
      return (-1L);
   else {
		int j;
		*date = fentry[i]->date;
		*time = fentry[i]->time;
		*high_pos = fentry[i]->position;
		*high_vflag = fentry[i]->vflag;
		for (j = i; j < lastname; j++) {	/* find highest version no. for file */
			if (COMPARE(fname,
				(justname ? nameptr (fentry[j]->fname) : fentry[j]->fname)) == 0) {
				if (*high_version_no < fentry[j]->version_no) {
					*high_version_no = fentry[j]->version_no;
					*high_vflag = fentry[j]->vflag;
					*high_pos = fentry[j]->position;
					*date = fentry[j]->date;
					*time = fentry[j]->time;
				}
			}
		}
		*this_version_no = fentry[i]->version_no;
      return (fentry[i]->position);
   }
} /* inlist() */