2 Copyright (c) 2010 Frank Lahm <franklahm@gmail.com>
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
17 #endif /* HAVE_CONFIG_H */
20 #include <sys/types.h>
28 #include <atalk/adouble.h>
29 #include <atalk/cnid.h>
30 #include <atalk/cnid_dbd_private.h>
31 #include <atalk/volinfo.h>
32 #include <atalk/bstrlib.h>
33 #include <atalk/bstradd.h>
34 #include <atalk/directory.h>
35 #include <atalk/util.h>
36 #include <atalk/unicode.h>
39 static volatile sig_atomic_t alarmed;
43 catch SIGINT and SIGTERM which cause clean exit. Ignore anything else.
46 static void sig_handler(int signo)
52 static void set_signal(void)
56 sv.sa_handler = sig_handler;
57 sv.sa_flags = SA_RESTART;
58 sigemptyset(&sv.sa_mask);
59 if (sigaction(SIGTERM, &sv, NULL) < 0)
60 ERROR("error in sigaction(SIGTERM): %s", strerror(errno));
62 if (sigaction(SIGINT, &sv, NULL) < 0)
63 ERROR("error in sigaction(SIGINT): %s", strerror(errno));
65 memset(&sv, 0, sizeof(struct sigaction));
66 sv.sa_handler = SIG_IGN;
67 sigemptyset(&sv.sa_mask);
69 if (sigaction(SIGABRT, &sv, NULL) < 0)
70 ERROR("error in sigaction(SIGABRT): %s", strerror(errno));
72 if (sigaction(SIGHUP, &sv, NULL) < 0)
73 ERROR("error in sigaction(SIGHUP): %s", strerror(errno));
75 if (sigaction(SIGQUIT, &sv, NULL) < 0)
76 ERROR("error in sigaction(SIGQUIT): %s", strerror(errno));
79 static void usage_find(void)
82 "Usage: ad find [-v VOLUME_PATH] NAME\n"
86 int ad_find(int argc, char **argv)
90 const char *srchvol = getcwdpath();
92 while ((c = getopt(argc-1, &argv[1], ":v:")) != -1) {
95 srchvol = strdup(optarg);
107 if ((argc - optind) != 1) {
115 if (openvol(srchvol, &vol) != 0)
116 ERROR("Cant open volume \"%s\"", srchvol);
118 uint16_t flags = CONV_TOLOWER;
119 char namebuf[MAXPATHLEN + 1];
120 if (convert_charset(vol.volinfo.v_volcharset,
121 vol.volinfo.v_volcharset,
122 vol.volinfo.v_maccharset,
124 strlen(argv[optind]),
127 &flags) == (size_t)-1) {
128 ERROR("conversion error");
132 char resbuf[DBD_MAX_SRCH_RSLTS * sizeof(cnid_t)];
133 if ((count = cnid_find(vol.volume.v_cdb,
137 sizeof(resbuf))) < 1) {
143 bstring sep = bfromcstr("/");
145 memcpy(&cnid, bufp, sizeof(cnid_t));
146 bufp += sizeof(cnid_t);
149 bstring volpath = bfromcstr(vol.volinfo.v_path);
150 BSTRING_STRIP_SLASH(volpath);
151 char buffer[12 + MAXPATHLEN + 1];
152 int buflen = 12 + MAXPATHLEN + 1;
155 struct bstrList *pathlist = bstrListCreateMin(32);
157 while (did != DIRDID_ROOT) {
158 if ((name = cnid_resolve(vol.volume.v_cdb, &did, buffer, buflen)) == NULL)
160 bstrListPush(pathlist, bfromcstr(name));
162 bstrListPush(pathlist, volpath);
163 path = bjoinInv(pathlist, sep);
165 printf("%s\n", cfrombstr(path));
168 bstrListDestroy(pathlist);