b670d9b8f8763568ae67335b86675a97e7c8a263
[xfstests-dev.git] / dmapi / src / common / cmd / set_return_on_destroy.c
1 /*
2  * Copyright (c) 2000 Silicon Graphics, Inc.  All Rights Reserved.
3  * 
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.
7  * 
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.
11  * 
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.
18  * 
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.
22  * 
23  * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
24  * Mountain View, CA  94043, or:
25  * 
26  * http://www.sgi.com 
27  * 
28  * For further information regarding this notice, see: 
29  * 
30  * http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
31  */
32
33 #include <lib/hsm.h>
34
35 #ifdef linux
36 #include <string.h>
37 #endif
38
39 /*---------------------------------------------------------------------------
40
41 Test program used to test the DMAPI function dm_set_return_on_destroy().  The
42 command line is:
43
44         set_return_on_destroy [-s sid] pathname [attr]
45
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.
50
51 ----------------------------------------------------------------------------*/
52
53 #ifndef linux
54 extern  char    *sys_errlist[];
55 #endif
56 extern  int     optind;
57 extern  char    *optarg;
58
59
60 char    *Progname;
61
62 static void
63 usage(void)
64 {
65         int     i;
66
67         fprintf(stderr, "usage:\t%s [-s sid] pathname [attr]\n", Progname);
68         exit(1);
69 }
70
71
72 int
73 main(
74         int     argc, 
75         char    **argv)
76 {
77         dm_sessid_t     sid = DM_NO_SESSION;
78         char            *pathname;
79         dm_attrname_t   *attrnamep = NULL;
80         dm_boolean_t    enable = DM_FALSE;
81         void            *hanp;
82         size_t          hlen;
83         char            *name;
84         int             opt;
85         int             i;
86
87         if (Progname = strrchr(argv[0], '/')) {
88                 Progname++;
89         } else {
90                 Progname = argv[0];
91         }
92
93         /* Crack and validate the command line options. */
94
95         while ((opt = getopt(argc, argv, "s:")) != EOF) {
96                 switch (opt) {
97                 case 's':
98                         sid = atol(optarg);
99                         break;
100                 case '?':
101                         usage();
102                 }
103         }
104         if (optind == argc || optind + 2 < argc)
105                 usage();
106         pathname = argv[optind++];
107         if (optind < argc) {
108                 enable = DM_TRUE;
109                 attrnamep = (dm_attrname_t *)argv[optind++];
110         }
111
112         if (dm_init_service(&name) == -1)  {
113                 fprintf(stderr, "Can't inititalize the DMAPI\n");
114                 exit(1);
115         }
116         if (sid == DM_NO_SESSION)
117                 find_test_session(&sid);
118
119         /* Get the file's handle. */
120
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));
124                 exit(1);
125         }
126
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",
130                         strerror(errno));
131                 exit(1);
132         }
133
134         dm_handle_free(hanp, hlen);
135         exit(0);
136 }