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/
39 /*---------------------------------------------------------------------------
41 Test program used to test the DMAPI function dm_set_return_on_destroy(). The
44 set_return_on_destroy [-s sid] pathname [attr]
46 where pathname is the name of a file which resides in the filesystem of
47 interest. attr is the name of the DMAPI attribute; if none is specified,
48 then set-return-on-destroy will be disabled for the filesystem.
49 sid is the session ID whose attribute you are interested in setting.
51 ----------------------------------------------------------------------------*/
54 extern char *sys_errlist[];
67 fprintf(stderr, "usage:\t%s [-s sid] pathname [attr]\n", Progname);
77 dm_sessid_t sid = DM_NO_SESSION;
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, "s:")) != EOF) {
104 if (optind == argc || optind + 2 < argc)
106 pathname = argv[optind++];
109 attrnamep = (dm_attrname_t *)argv[optind++];
112 if (dm_init_service(&name) == -1) {
113 fprintf(stderr, "Can't inititalize the DMAPI\n");
116 if (sid == DM_NO_SESSION)
117 find_test_session(&sid);
119 /* Get the file's handle. */
121 if (dm_path_to_fshandle(pathname, &hanp, &hlen)) {
122 fprintf(stderr, "can't get filesystem handle for file %s, %s\n",
123 pathname, strerror(errno));
127 if (dm_set_return_on_destroy(sid, hanp, hlen, DM_NO_TOKEN,
128 attrnamep, enable)) {
129 fprintf(stderr, "dm_set_return_on_destroy failed, %s\n",
134 dm_handle_free(hanp, hlen);