/* begincopyright
Copyright (c) 1988 Xerox Corporation. All rights reserved.
Use and copying of this software and preparation of derivative works based
upon this software are permitted. Any distribution of this software or
derivative works must comply with all applicable United States export
control laws. This software is made available AS IS, and Xerox Corporation
makes no warranty about the software, its performance or its conformity to
any specification. Any person obtaining a copy of this software is requested
to send their name and post office or electronic mail address to:
PCR Coordinator
Xerox PARC
3333 Coyote Hill Rd.
Palo Alto, CA 94304
endcopyright */
/*
* CommandLoop.h
*
* PCR command line and read-eval-print.
*
* Demers April 15, 1990 11:43:47 am PDT
*/
#ifndef ←XR←COMMAND←LOOP←
#define ←XR←COMMAND←LOOP← 1
#ifndef ←XR←BASIC←TYPES←
# include "xr/BasicTypes.h"
#endif
#ifndef ←XR←COMMAND←LINE←
# include "xr/CommandLine.h"
#endif
/*
* The global handles ...
*/
extern XR←CLHandle
XR←globalCLHandle;
/*
Starts out as handle on original PCR command line arguments.
Gets modified as result of package setup code.
*/
extern XR←CLProcsHandle
XR←globalCLProcsHandle;
/*
Procs for sequentially-executed command-line or command-file
argument groups.
PCR components (GC, IL, ...) register procs here during setup.
*/
extern XR←MesaProc XR←stdOutCLMsgSink;
/*
Closure for void (*sink)(char *buf, int nBytes, XR←MesaProc self)
A message sink for stdout.
Used in initial call to CLApply on global handles.
Monitored, so it may also be used by clients.
*/
/*
* Global state for command proc execution ... may be used by procs
* that don't get the call environment passed to them, provided
* they expect to be invoked only thru the global commander thread.
*/
extern XR←CLCallEnv
XR←GetTopLevelCLCallEnv();
extern XR←CLCallEnv
XR←SetTopLevelCLCallEnv(/* XR←CLCallEnv clce */);
/*
Call environment at top of command stack.
*/
extern XR←JmpBuf
XR←GetTopLevelJumpBuf();
/*
An XR←longjmp here simulates return from current command line proc.
*/
extern void
XR←StoreTopLevelCLErrorHandler(/* XR←MesaProc handler */);
/*
A CLProc may store a handler for command errors.
The handler is a closure for
(int) (*handler)(int prevResult, XR←MesaProc self)
The result returned by the handler is returned from
the enclosing call to CommandLine.h.XR←CLApply.
A NIL handler just propagates the error result.
*/
/*
* Some global PCR state
* (possibly this doesn`t belong here, but ...)
*/
extern int
XR←SetPCRFileName(/* char *fn */);
/*
Set name of PCR symbols file.
Setting it to NIL turns of symbol table initialization
and thus disables dynamic loading.
*/
extern char *
XR←GetPCRFileName();
/*
Get name of PCR symbols file.
*/
extern int
XR←SetTmpDirectory(/* char *dirName */);
/*
Set name for tmp file directory.
*/
extern char *
XR←GetTmpDirectory();
/*
Get name for tmp file directory.
*/
extern int
XR←SetDBXScriptName(/* char *n */);
/*
Set name for dbx script.
Setting to NIL turns it off.
*/
extern char *
XR←GetDBXScriptName();
/*
Get name of dbx script.
*/
/*
* Utilities ...
*/
extern int
XR←CLCallProc(/*
XR←UntypedProc proc,
int argc,
XR←Pointer *argv,
XR←Pointer *resultP
*/);
/*
Call proc with args.
If resultP != NIL, store result (assumed to be 1 word) in *resultP.
Return
0 (success)
-1 (argc too big -- promise to support argc <= 6)
< -1 (other failure).
*/
/*
* OBSOLETE, but still in use as of April 9, 1990, sigh ...
*/
typedef XR←Pointer (**CommandProc)(/*
char *cmd,
XR←Pointer clientData,
CommandProc self
*/);
/*
Called with entire arg group as a string ... so it has to reparse it!
*/
extern void
XR←register(/*
char *key,
CommandProc proc,
char *doc,
XR←Pointer clientData
*/);
/*
Register given command proc as processor for given command.
*/
extern char *
XR←get←loader←directory();
/*
Return immutable string = name of loader temp directory.
Equivalent to XR←GetTmpDirectory().
*/
extern char *
XR←GetCurrentCommand();
/*
Return command currently being executed by a CommandProc,
or set by SetCurrentCommand.
*/
extern void
XR←SetCurrentCommand(/* char *c */);
/*
Set command to be returned by GetCurrentCommand.
*/
#endif /* ←XR←COMMAND←LOOP← */