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