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_obj_ref_query(). The
44 obj_ref_query {-F} [-s sid] token {pathname|handle}
48 when a pathname is specified, -F indicates that its filesystem handle
49 should be used rather than its file object handle.
51 is the dm_sessid_t to use rather than the default test session.
53 is the dm_token_t to use.
55 is either a handle, or is the pathname of a file whose handle is
58 ----------------------------------------------------------------------------*/
61 extern char *sys_errlist[];
73 fprintf(stderr, "usage:\t%s [-F] [-s sid] token {pathname|handle}\n",
84 dm_sessid_t sid = DM_NO_SESSION;
94 if (Progname = strrchr(argv[0], '/')) {
100 /* Crack and validate the command line options. */
102 while ((opt = getopt(argc, argv, "Fs:")) != EOF) {
114 if (optind + 2 != argc)
116 token = atol(argv[optind++]);
117 object = argv[optind];
119 if (dm_init_service(&name) == -1) {
120 fprintf(stderr, "Can't initialize the DMAPI\n");
123 if (sid == DM_NO_SESSION)
124 find_test_session(&sid);
126 /* Get the file or filesystem's handle. */
128 if (opaque_to_handle(object, &hanp, &hlen)) {
129 fprintf(stderr, "can't get handle from %s\n", object);
136 if (dm_handle_to_fshandle(hanp, hlen, &fshanp, &fshlen)) {
137 fprintf(stderr, "can't get filesystem handle from %s\n",
141 dm_handle_free(hanp, hlen);
146 if ((error = dm_obj_ref_query(sid, token, hanp, hlen)) < 0) {
147 fprintf(stderr, "dm_obj_ref_query failed, %s\n",
153 fprintf(stdout, "there is a hold\n");
155 fprintf(stdout, "there is no hold\n");
157 dm_handle_free(hanp, hlen);