xref: /freebsd/lib/libfetch/file.c (revision 7a5b4b1ba626eb086c127279f31d2f6e76a8db53)
14ca1ab94SDag-Erling Smørgrav /*-
24ca1ab94SDag-Erling Smørgrav  * Copyright (c) 1998 Dag-Erling Co�dan Sm�rgrav
34ca1ab94SDag-Erling Smørgrav  * All rights reserved.
44ca1ab94SDag-Erling Smørgrav  *
54ca1ab94SDag-Erling Smørgrav  * Redistribution and use in source and binary forms, with or without
64ca1ab94SDag-Erling Smørgrav  * modification, are permitted provided that the following conditions
74ca1ab94SDag-Erling Smørgrav  * are met:
84ca1ab94SDag-Erling Smørgrav  * 1. Redistributions of source code must retain the above copyright
94ca1ab94SDag-Erling Smørgrav  *    notice, this list of conditions and the following disclaimer
104ca1ab94SDag-Erling Smørgrav  *    in this position and unchanged.
114ca1ab94SDag-Erling Smørgrav  * 2. Redistributions in binary form must reproduce the above copyright
124ca1ab94SDag-Erling Smørgrav  *    notice, this list of conditions and the following disclaimer in the
134ca1ab94SDag-Erling Smørgrav  *    documentation and/or other materials provided with the distribution.
144ca1ab94SDag-Erling Smørgrav  * 3. The name of the author may not be used to endorse or promote products
154ca1ab94SDag-Erling Smørgrav  *    derived from this software without specific prior written permission
164ca1ab94SDag-Erling Smørgrav  *
174ca1ab94SDag-Erling Smørgrav  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
184ca1ab94SDag-Erling Smørgrav  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
194ca1ab94SDag-Erling Smørgrav  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
204ca1ab94SDag-Erling Smørgrav  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
214ca1ab94SDag-Erling Smørgrav  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
224ca1ab94SDag-Erling Smørgrav  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
234ca1ab94SDag-Erling Smørgrav  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
244ca1ab94SDag-Erling Smørgrav  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
254ca1ab94SDag-Erling Smørgrav  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
264ca1ab94SDag-Erling Smørgrav  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
274ca1ab94SDag-Erling Smørgrav  *
287f3dea24SPeter Wemm  * $FreeBSD$
294ca1ab94SDag-Erling Smørgrav  */
304ca1ab94SDag-Erling Smørgrav 
310fba3a00SDag-Erling Smørgrav #include <sys/param.h>
32d8acd8dcSDag-Erling Smørgrav #include <sys/stat.h>
33ce71b736SDag-Erling Smørgrav 
34ce71b736SDag-Erling Smørgrav #include <dirent.h>
354ca1ab94SDag-Erling Smørgrav #include <stdio.h>
364ca1ab94SDag-Erling Smørgrav #include <string.h>
374ca1ab94SDag-Erling Smørgrav 
384ca1ab94SDag-Erling Smørgrav #include "fetch.h"
39d8acd8dcSDag-Erling Smørgrav #include "common.h"
404ca1ab94SDag-Erling Smørgrav 
414ca1ab94SDag-Erling Smørgrav FILE *
42d8acd8dcSDag-Erling Smørgrav fetchGetFile(struct url *u, char *flags)
434ca1ab94SDag-Erling Smørgrav {
44d8acd8dcSDag-Erling Smørgrav     FILE *f;
45d8acd8dcSDag-Erling Smørgrav 
46d8acd8dcSDag-Erling Smørgrav     f = fopen(u->doc, "r");
47d8acd8dcSDag-Erling Smørgrav 
48d8acd8dcSDag-Erling Smørgrav     if (f == NULL)
49d8acd8dcSDag-Erling Smørgrav 	_fetch_syserr();
505ff28c82SDag-Erling Smørgrav 
515ff28c82SDag-Erling Smørgrav     if (u->offset && fseek(f, u->offset, SEEK_SET) == -1) {
525ff28c82SDag-Erling Smørgrav 	fclose(f);
535ff28c82SDag-Erling Smørgrav 	_fetch_syserr();
545ff28c82SDag-Erling Smørgrav     }
555ff28c82SDag-Erling Smørgrav 
56d8acd8dcSDag-Erling Smørgrav     return f;
574ca1ab94SDag-Erling Smørgrav }
584ca1ab94SDag-Erling Smørgrav 
594ca1ab94SDag-Erling Smørgrav FILE *
60d8acd8dcSDag-Erling Smørgrav fetchPutFile(struct url *u, char *flags)
614ca1ab94SDag-Erling Smørgrav {
62d8acd8dcSDag-Erling Smørgrav     FILE *f;
63d8acd8dcSDag-Erling Smørgrav 
64f5f109a0SDag-Erling Smørgrav     if (flags && strchr(flags, 'a'))
65d8acd8dcSDag-Erling Smørgrav 	f = fopen(u->doc, "a");
66d8acd8dcSDag-Erling Smørgrav     else
675ff28c82SDag-Erling Smørgrav 	f = fopen(u->doc, "w+");
68d8acd8dcSDag-Erling Smørgrav 
69d8acd8dcSDag-Erling Smørgrav     if (f == NULL)
70d8acd8dcSDag-Erling Smørgrav 	_fetch_syserr();
715ff28c82SDag-Erling Smørgrav 
725ff28c82SDag-Erling Smørgrav     if (u->offset && fseek(f, u->offset, SEEK_SET) == -1) {
735ff28c82SDag-Erling Smørgrav 	fclose(f);
745ff28c82SDag-Erling Smørgrav 	_fetch_syserr();
755ff28c82SDag-Erling Smørgrav     }
765ff28c82SDag-Erling Smørgrav 
77d8acd8dcSDag-Erling Smørgrav     return f;
78d8acd8dcSDag-Erling Smørgrav }
79d8acd8dcSDag-Erling Smørgrav 
80ce71b736SDag-Erling Smørgrav static int
81ce71b736SDag-Erling Smørgrav _fetch_stat_file(char *fn, struct url_stat *us)
82d8acd8dcSDag-Erling Smørgrav {
83d8acd8dcSDag-Erling Smørgrav     struct stat sb;
84d8acd8dcSDag-Erling Smørgrav 
857a5b4b1bSDag-Erling Smørgrav     us->size = -1;
867a5b4b1bSDag-Erling Smørgrav     us->atime = us->mtime = 0;
87ce71b736SDag-Erling Smørgrav     if (stat(fn, &sb) == -1) {
88d8acd8dcSDag-Erling Smørgrav 	_fetch_syserr();
89d8acd8dcSDag-Erling Smørgrav 	return -1;
90d8acd8dcSDag-Erling Smørgrav     }
91d8acd8dcSDag-Erling Smørgrav     us->size = sb.st_size;
920fba3a00SDag-Erling Smørgrav     us->atime = sb.st_atime;
930fba3a00SDag-Erling Smørgrav     us->mtime = sb.st_mtime;
94d8acd8dcSDag-Erling Smørgrav     return 0;
954ca1ab94SDag-Erling Smørgrav }
96ce71b736SDag-Erling Smørgrav 
97ce71b736SDag-Erling Smørgrav int
98ce71b736SDag-Erling Smørgrav fetchStatFile(struct url *u, struct url_stat *us, char *flags)
99ce71b736SDag-Erling Smørgrav {
100ce71b736SDag-Erling Smørgrav     return _fetch_stat_file(u->doc, us);
101ce71b736SDag-Erling Smørgrav }
102ce71b736SDag-Erling Smørgrav 
103ce71b736SDag-Erling Smørgrav struct url_ent *
104ce71b736SDag-Erling Smørgrav fetchListFile(struct url *u, char *flags)
105ce71b736SDag-Erling Smørgrav {
106ce71b736SDag-Erling Smørgrav     DIR *dir;
107ce71b736SDag-Erling Smørgrav     struct dirent *de;
108ce71b736SDag-Erling Smørgrav     struct url_stat us;
109ce71b736SDag-Erling Smørgrav     struct url_ent *ue;
110ce71b736SDag-Erling Smørgrav     int size, len;
111ce71b736SDag-Erling Smørgrav     char fn[MAXPATHLEN], *p;
112ce71b736SDag-Erling Smørgrav     int l;
113ce71b736SDag-Erling Smørgrav 
114ce71b736SDag-Erling Smørgrav     if ((dir = opendir(u->doc)) == NULL) {
115ce71b736SDag-Erling Smørgrav 	_fetch_syserr();
116ce71b736SDag-Erling Smørgrav 	return NULL;
117ce71b736SDag-Erling Smørgrav     }
118ce71b736SDag-Erling Smørgrav 
119ce71b736SDag-Erling Smørgrav     ue = NULL;
120ce71b736SDag-Erling Smørgrav     strncpy(fn, u->doc, sizeof fn - 2);
121ce71b736SDag-Erling Smørgrav     fn[sizeof fn - 2] = 0;
122ce71b736SDag-Erling Smørgrav     strcat(fn, "/");
123ce71b736SDag-Erling Smørgrav     p = strchr(fn, 0);
124ce71b736SDag-Erling Smørgrav     l = sizeof fn - strlen(fn) - 1;
125ce71b736SDag-Erling Smørgrav 
126ce71b736SDag-Erling Smørgrav     while ((de = readdir(dir)) != NULL) {
127ce71b736SDag-Erling Smørgrav 	strncpy(p, de->d_name, l - 1);
128ce71b736SDag-Erling Smørgrav 	p[l - 1] = 0;
129ce71b736SDag-Erling Smørgrav 	if (_fetch_stat_file(fn, &us) == -1)
130ce71b736SDag-Erling Smørgrav 	    /* should I return a partial result, or abort? */
131ce71b736SDag-Erling Smørgrav 	    break;
132ce71b736SDag-Erling Smørgrav 	_fetch_add_entry(&ue, &size, &len, de->d_name, &us);
133ce71b736SDag-Erling Smørgrav     }
134ce71b736SDag-Erling Smørgrav 
135ce71b736SDag-Erling Smørgrav     return ue;
136ce71b736SDag-Erling Smørgrav }
137