Mercurial > illumos > onarm
view usr/src/cmd/fmli/wish/browse.c @ 4:1a15d5aaf794
synchronized with onnv_86 (6202) in onnv-gate
author | Koji Uno <koji.uno@sun.com> |
---|---|
date | Mon, 31 Aug 2009 14:38:03 +0900 |
parents | c9caec207d52 |
children |
line wrap: on
line source
/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright 2005 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ /* Copyright (c) 1984, 1985, 1986, 1987, 1988, 1989 AT&T */ /* All Rights Reserved */ #pragma ident "%Z%%M% %I% %E% SMI" #include <stdio.h> #include "wish.h" #include "token.h" #include "slk.h" #include "actrec.h" #include "terror.h" #include "ctl.h" #include "moremacros.h" #define BROWSE 1 #define PROMPT 2 /* * Caution: MAX_ARGS is defined in other files and should ultimately reside * in wish.h */ #define MAX_ARGS 25 extern int Arg_count; extern char *Args[]; extern char *tok_to_cmd(); /* abs k16 */ char *Pending_op, *Pending_objtype, *Pending_argv[MAX_ARGS+2]; struct slk *Pending_slks; int Pending_type; static void save_browse(); static token namevalid(char *s, token t); static char name_string[] = "Enter the new object name: "; static char desc_string[] = "Enter the new description: "; int Browse_mode = 0; int enter_browse(op, objtype, argv) char *op, *objtype, *argv[]; { extern struct slk Browslk[], Defslk[]; Browse_mode++; save_browse(op, objtype, argv); setslks(NULL, 0); mess_temp("Open or navigate to the destination folder and press SELECT"); Pending_type = BROWSE; return (0); } int enter_getname(op, objtype, argv) char *op, *objtype, *argv[]; { save_browse(op, objtype, argv); Pending_type = PROMPT; get_string(namevalid, strCcmp(Pending_op, "redescribe") ? name_string : desc_string, "", 0, FALSE, Pending_op, Pending_op); return (0); } static token namevalid(char *s, token t) { register int i; char *errstr; if (t == TOK_CANCEL) { if ( Browse_mode ) glob_browse_cancel(); else Pending_op = NULL; return TOK_NOP; } if (strCcmp(Pending_op, "create") == 0) { if (namecheck(Pending_argv[0], s, NULL, &errstr, TRUE) == FALSE) { get_string(namevalid, name_string, "", 0, FALSE, Pending_op, Pending_op); mess_temp(errstr); return TOK_NOP; } } else if (strCcmp(Pending_op, "redescribe") != 0) { if (namecheck(Pending_argv[1], s, Pending_objtype, &errstr, TRUE)==FALSE) { get_string(namevalid, name_string, "", 0, FALSE, Pending_op, Pending_op); mess_temp(errstr); return TOK_NOP; } } /* * Notice that redescribe falls thru the above if block without ever * calling namecheck! */ for (i = 0; Pending_argv[i]; i++) ; Pending_argv[i] = strsave(s); Pending_argv[i+1] = NULL; glob_select(); return(TOK_NOP); } int glob_select(void) { register int i, prevtype = Pending_type; bool canselect; if (Pending_type == BROWSE) { if (ar_ctl(ar_get_current(), CTISDEST, &canselect, NULL, NULL, NULL, NULL, NULL) == FAIL || !canselect) { mess_temp("This frame can not be used as a destination"); return (0); } for (i = 0; Pending_argv[i]; i++) ; Pending_argv[i] = strsave(ar_get_current()->path); Pending_argv[i+1] = NULL; } if (strcmp(Pending_op, "redescribe") == 0) { working(TRUE); redescribe(&Pending_argv[0]); } else if (strcmp(Pending_op, "create") == 0) { working(TRUE); Create_create(&Pending_argv[0]); } else { mess_perm(NULL); working(TRUE); (void) objopv(Pending_op, Pending_objtype, Pending_argv); } if (Pending_type == prevtype) glob_browse_cancel(); ar_checkworld(TRUE); return (0); } int glob_browse_cancel() { Browse_mode = 0; ar_setslks(ar_get_current()->slks, 0); if (Pending_op) { register int i; free(Pending_op); Pending_op = NULL; if (Pending_objtype) { free(Pending_objtype); Pending_objtype = NULL; } for (i = 0; Pending_argv[i]; i++) { free(Pending_argv[i]); Pending_argv[i] = NULL; } } return (0); } token glob_mess_nosrc(t) token t; { char *cmd_name = tok_to_cmd(t); /* abs k16 */ if (cmd_name) /* abs k16 */ mess_temp(nstrcat("Can't ", cmd_name, " from this frame", NULL)); else beep(); /* abs k16 */ return(t); } static void save_browse(op, objtype, argv) char *op, *objtype, *argv[]; { register int i; Pending_op = strsave(op); Pending_objtype = strsave(objtype); Pending_slks = ar_get_current()->slks; for (i = 0; argv[i]; i++) Pending_argv[i] = strsave(argv[i]); Pending_argv[i] = NULL; }