2 * Copyright (c) 2000 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 [-s sid] pathname [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 ----------------------------------------------------------------------------*/
53 extern char *sys_errlist[];
64 fprintf(stderr, "usage:\t%s [-s sid] pathname [attr]\n", Progname);
74 dm_sessid_t sid = DM_NO_SESSION;
76 dm_attrname_t *attrnamep = NULL;
77 dm_boolean_t enable = DM_FALSE;
83 if (Progname = strrchr(argv[0], '/')) {
89 /* Crack and validate the command line options. */
91 while ((opt = getopt(argc, argv, "s:")) != EOF) {
100 if (optind == argc || optind + 2 < argc)
102 pathname = argv[optind++];
105 attrnamep = (dm_attrname_t *)argv[optind++];
108 if (dm_init_service(&name) == -1) {
109 fprintf(stderr, "Can't inititalize the DMAPI\n");
112 if (sid == DM_NO_SESSION)
113 find_test_session(&sid);
115 /* Get the file's handle. */
117 if (dm_path_to_fshandle(pathname, &hanp, &hlen)) {
118 fprintf(stderr, "can't get filesystem handle for file %s, %s\n",
119 pathname, strerror(errno));
123 if (dm_set_return_on_destroy(sid, hanp, hlen, DM_NO_TOKEN,
124 attrnamep, enable)) {
125 fprintf(stderr, "dm_set_return_on_destroy failed, %s\n",
130 dm_handle_free(hanp, hlen);