2 * Copyright (c) 2000-2002 Silicon Graphics, Inc. All Rights Reserved.
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of version 2 of the GNU General Public License as
6 * published by the Free Software Foundation.
8 * This program is distributed in the hope that it would be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
12 * Further, this software is distributed without any warranty that it is
13 * free of the rightful claim of any third person regarding infringement
14 * or the like. Any license provided herein, whether implied or
15 * otherwise, applies only to this software file. Patent licenses, if
16 * any, provided herein do not apply to combinations of this program with
17 * other software, or any other product whatsoever.
19 * You should have received a copy of the GNU General Public License along
20 * with this program; if not, write the Free Software Foundation, Inc., 59
21 * Temple Place - Suite 330, Boston MA 02111-1307, USA.
23 * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
24 * Mountain View, CA 94043, or:
28 * For further information regarding this notice, see:
30 * http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
38 /*---------------------------------------------------------------------------
40 Test program used to test the DMAPI function dm_set_return_on_destroy(). The
43 set_return_on_destroy [-F] [-s sid] [-t token] {pathname|fshandle} [attr]
45 where pathname is the name of a file which resides in the filesystem of
46 interest. attr is the name of the DMAPI attribute; if none is specified,
47 then set-return-on-destroy will be disabled for the filesystem.
48 sid is the session ID whose attribute you are interested in setting.
50 Use -F if you want the program to find the fshandle based on the pathname.
52 ----------------------------------------------------------------------------*/
55 extern char *sys_errlist[];
66 fprintf(stderr, "usage:\t%s [-F] [-s sid] [-t token] {pathname|fshandle} [attr]\n", Progname);
76 dm_sessid_t sid = DM_NO_SESSION;
77 dm_token_t token = DM_NO_TOKEN;
79 dm_attrname_t *attrnamep = NULL;
80 dm_boolean_t enable = DM_FALSE;
87 if (Progname = strrchr(argv[0], '/')) {
93 /* Crack and validate the command line options. */
95 while ((opt = getopt(argc, argv, "Fs:t:")) != EOF) {
101 token = atol(optarg);
110 if (optind == argc || optind + 2 < argc)
112 pathname = argv[optind++];
115 attrnamep = (dm_attrname_t *)argv[optind++];
118 if (dm_init_service(&name) == -1) {
119 fprintf(stderr, "Can't initialize the DMAPI\n");
122 if (sid == DM_NO_SESSION)
123 find_test_session(&sid);
125 if (opaque_to_handle(pathname, &hanp, &hlen)) {
126 fprintf(stderr, "can't get handle for %s\n", pathname);
130 /* Get the file's handle. */
136 if (dm_handle_to_fshandle(hanp, hlen, &fshanp, &fshlen)) {
137 fprintf(stderr, "can't get filesystem handle for file %s, %s\n",
138 pathname, strerror(errno));
141 dm_handle_free(hanp, hlen);
146 if (dm_set_return_on_destroy(sid, hanp, hlen, token,
147 attrnamep, enable)) {
148 fprintf(stderr, "dm_set_return_on_destroy failed, %s\n",
153 dm_handle_free(hanp, hlen);