]> arthur.barton.de Git - netatalk.git/blob - bin/afile/common.h
call readt with ONE_DELAY = 5 s
[netatalk.git] / bin / afile / common.h
1 /*
2  * $Id: common.h,v 1.2 2001-06-29 14:14:46 rufustfirefly Exp $
3  *
4     common functions, defines, and structures for afile, achfile, and acleandir
5
6     Copyright (C) 2001 Sebastian Rittau.
7     All rights reserved.
8
9     This file may be distributed and/or modfied under the terms of the
10     following license:
11
12     Redistribution and use in source and binary forms, with or without
13     modification, are permitted provided that the following conditions
14     are met:
15     1. Redistributions of source code must retain the above copyright
16        notice, this list of conditions and the following disclaimer.
17     2. Redistributions in binary form must reproduce the above copyright
18        notice, this list of conditions and the following disclaimer in the
19        documentation and/or other materials provided with the distribution.
20     3. Neither the name of the author nor the names of its contributors
21        may be used to endorse or promote products derived from this software
22        without specific prior written permission.
23
24     THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
25     ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26     IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27     ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
28     FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29     DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30     OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31     HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32     LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33     OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34     SUCH DAMAGE.
35 */
36
37 #include <stdlib.h>
38
39
40 char *dataname_to_adname(const char *dataname);
41 char *adname_to_dataname(const char *adname);
42
43 /* Class for handling data and AppleDouble files. Don't access directly.
44  * Instead, use the methods provided below.
45  */
46 struct AFile {
47   const char *filename;
48   int fd;
49   mode_t mode;
50   unsigned short flags;
51   char creator[4], type[4];
52 };
53
54
55 /* Constructor */
56 struct AFile *afile_new(const char *filename);
57 /* Destructor */
58 void afile_delete(struct AFile *afile);
59 /* Accessor Methods */
60 const char *afile_filename(struct AFile *afile);
61 int afile_is_ad(struct AFile *afile);
62 int afile_is_dir(struct AFile *afile);
63 mode_t afile_mode(struct AFile *afile);
64 /* The following two methods are only valid if afile_is_ad yields true. */
65 const char *afile_creator(const struct AFile *afile);
66 const char *afile_type(const struct AFile *afile);