952 lines
41 KiB
Plaintext
952 lines
41 KiB
Plaintext
_______________________________________________________________________________
|
|
|
|
INTRODUCTION TO THE PRIMOS OPERATING SYSTEM
|
|
Part III (Useful PRIMOS Applications)
|
|
|
|
Written by Violence
|
|
Copyright (C) 1989 The VOID Hackers
|
|
_______________________________________________________________________________
|
|
|
|
|
|
Welcome to Part III of my series on the PRIMOS operating system. In this part
|
|
I will detail the several useful appliactions you are likely to find on Prime
|
|
computers. You will learn about the DSM (Distributed System Management) util-
|
|
ities, the EDIT_PROFILE utility (the PRIMOS user editor), and several others.
|
|
|
|
_______________________________________________________________________________
|
|
|
|
EDIT_PROFILE
|
|
|
|
|
|
EDIT_PROFILE is the utility that is used to add, delete, and modify users on a
|
|
Prime computer running PRIMOS. It is similar to the VAX/VMS AUTHORIZE utility.
|
|
There are three modes of EDIT_PROFILE access, and these are:
|
|
|
|
o System Initialization (SI) mode
|
|
o System Administrator (SA) mode
|
|
o Project Administrator (PA) mode
|
|
|
|
You will probably never be using EDIT_PROFILE in System Initialization mode as
|
|
that mode is used for initial system user setup). SA mode will allow to perf-
|
|
orm wholesale user modifications, whereas PA mode will only allow you to perf-
|
|
orm modifications to users in the same project as you. When you decided to try
|
|
out EDIT_PROFILE on the system that you have hacked into, type this:
|
|
|
|
OK, edit_profile
|
|
|
|
If it gives you an error message then you obviously don't have good enough pri-
|
|
vileges. Don't give up hope, however, as there are ways around this. Unfort-
|
|
unantly, though, the methods which you must use are beyond the scope of this
|
|
tutorial. It involves programming in a high level language (FORTRAN IV, FORTR-
|
|
AN-77, PL/1 Subset G, et. al.) as well as knowledge of the appropriate system
|
|
calls to make. Do lots of research and experiment. You might just get lucky.
|
|
|
|
If, on the other hand, it allows you to invoke EDIT_PROFILE then it will disp-
|
|
lay the utility's herald (revision number, serial number and copyright inform-
|
|
ation) and a message stating what mode you are in. The mode message will be
|
|
one of these:
|
|
|
|
In system administrator mode
|
|
In project administrator mode
|
|
|
|
If you are in SA mode then the account you are using has SYS1 privileges (thats
|
|
the best you can do from a remote standpoint). Before I get deep in how to use
|
|
EDIT_PROFILE properly I should mention that I have the source code to this won-
|
|
derfully useful program and a security audit feature was added in during the
|
|
last few years (circa 1986). It will log all successful and failed commands.
|
|
The only ways I have discovered around this is to remove the logging procedures
|
|
from the code and recompile it online, but that's pretty advanced stuff and not
|
|
advised at any rate. The best you can do at maintaining your presence on the
|
|
system is not to use EDIT_PROFILE overly much. In fact, don't use it unless
|
|
you must. I generally use EDIT_PROFILE once per hack, and that is after I get
|
|
in. What do I do? I obtain a full user/project listing for future hacking
|
|
purposes. You can't obtain an account's password from within EDIT_PROFILE, but
|
|
you can obtain a full user and project listing, as well as add, modify and
|
|
delete users. If you get a user list, try and hack at those accounts before
|
|
wontonly adding user accounts. Be sensible. Get all that you can before add-
|
|
ing a user. And if you must add a user, just add one. There is no need to add
|
|
3 or 4 users. No need at all. One user is easier to hide than 3+. Use common
|
|
sense here, guys.
|
|
|
|
Once EDIT_PROFILE has been invoked you will be dispatched mercilessly to the
|
|
">" prompt. To obtain help, just type HELP and press RETURN. Before I get in-
|
|
to adding users, I'll discuss the procedures for pulling user lists and similar
|
|
information.
|
|
|
|
To get full information about the system you are on (projects, users, etc) you
|
|
simply need to type:
|
|
|
|
>list_system -all
|
|
|
|
You can abbreviate the LIST_SYSTEM command with LS. You can list individual
|
|
system attributes by substituting new arguments in place of the -ALL argument.
|
|
To see what LS arguments are available, type HELP. You should experiment with
|
|
the available "LIST_" commands in EDIT_PROFILE.
|
|
|
|
Before attempting to add a user on any Prime system you should always list the
|
|
system attributes so that you will know what projects and groups are in use.
|
|
When you decide to add a super-user, make sure that you add yourself to the
|
|
common project (usually DEFAULT) and all of the high-access groups (examples I
|
|
have seen are: .ADMINISTRATORS$, .PROJECT_ADMINISTRATORS$, .OPERATORS$,
|
|
.NET_MGT$, etc). Adding super-users is not always a good idea. Never add
|
|
more than 1 or 2 users on a system. Also, try to follow the naming convent-
|
|
ions used on the system. If users have their first name as a User ID, then
|
|
when you add a user make sure that your new user's User ID is a first name.
|
|
Likewise, if all users have their initials as their User ID then make sure
|
|
that your new user has a User ID with initials. Now, to add a user, type:
|
|
|
|
>add_user username
|
|
|
|
Where "username" is the User ID you wish to use. After you type this you will
|
|
be asked for your password. Enter the password that you wish to use. Then you
|
|
will be asked for your group(s) and your default login project. Like I said,
|
|
you should use the "LIST_" commands to see what group(s) are in use. Groups
|
|
always start with a period (.). Give yourself the administrator groups and you
|
|
will be doing good. As for project, an entry of DEFAULT will usually suffice.
|
|
|
|
An easier method to add users is to use the -LIKE argument. Try this:
|
|
|
|
>add_user username -like system
|
|
|
|
Again, "username" is the name of the User ID that you wish to use. This arg-
|
|
ument of the ADD_USER command will make a copy of the user called SYSTEM (found
|
|
on all Primes that I have seen; also a user of the super-user class) and add
|
|
the copy as a new user but with a different name. Now, set your password with
|
|
the CHANGE_USER command. Type:
|
|
|
|
>change_user username -pw
|
|
|
|
You will be prompted for your new password. Ta da. You now have a User ID
|
|
with the same stats as the User ID "SYSTEM". Occasionally upon adding a user
|
|
you may have to add your User ID to a file called LOGUFD located in one of the
|
|
UFD's off of MFD 0. This will generally not happen. If it does, then simply
|
|
correct it with one of your other accounts.
|
|
|
|
You are advised not to wontonly delete users or edit them. Also try not to use
|
|
the CHANGE_SYSTEM_ADMINISTRATOR command. In basis, type HELP and start to exp-
|
|
eriment (but be careful of what you do). Make sure that you keep track of the
|
|
changes that you make so that in the case you mess something up you can fix it.
|
|
Get your feet wet.
|
|
|
|
If you find yourself in PA mode you can do most of the above, but only regard-
|
|
ing the project that you are administrating. Thus you can only add users to
|
|
that project, only delete users from that project, etc. This means no adding
|
|
of super-users, etc.
|
|
|
|
_______________________________________________________________________________
|
|
|
|
THE DISTRIBUTED SYSTEM MANAGEMENT (DSM) UTILITIES
|
|
|
|
|
|
The DSM utilities is a set of commands and services that help with the admini-
|
|
stration and day-to-day operation of Prime computer systems. It is intended
|
|
primarily for use with networked systems, but can also be used on single Prime
|
|
systems (those lacking networking capability).
|
|
|
|
The DSM utilities allow Prime system administrators and senior operators to
|
|
perform system management tasks from any point on a network.
|
|
|
|
DSM's main facilities are summarized below.
|
|
|
|
o SIM (System Information/Metering) Commands
|
|
System status and resource monitoring of local and remote
|
|
systems from any point within the network.
|
|
|
|
o RESUS (REmote System USer) Facility
|
|
Control of remote Prime systems from any terminal. Allows use of
|
|
console-only commands from a remote terminal.
|
|
|
|
o Collection and collation of event messages, including PRIMOS and
|
|
network events, through DSM's Unsolicited Message Handling (UMH)
|
|
and logging services, with redirection of event messages to
|
|
log files or users throughout the network.
|
|
|
|
o Generalized logging of DSM messages in private or system logs, with
|
|
commands for administering, displaying and printing logs.
|
|
|
|
o Facilities for defining users' access to DSM commands throughout the
|
|
network, in a single configuration file.
|
|
|
|
As you can see, the DSM utilities can be a very useful asset to have. Unfort-
|
|
unately, SYS1 privileges (administrator) are required to use the most exciting
|
|
aspects of the DSM utilities. All normal users can utilize the SIM commands,
|
|
and I have even mentioned some of them in other parts of this series. What is
|
|
really useful to us, however, are the RESUS and log utilities. In a nutshell
|
|
here are the basic DSM commands. After this list will be full discourses on
|
|
the RESUS utility and the SIM commands.
|
|
|
|
|
|
Remote System Control:
|
|
|
|
RESUS -- Invokes Prime's REmote System USer facility.
|
|
|
|
Event Message Handling and Redirection:
|
|
|
|
CONFIG_UM -- configures DSM Unsolicited Message Handling.
|
|
|
|
Administering Logs:
|
|
|
|
ADMIN_LOG -- creates and administers DSM log files.
|
|
|
|
Displaying and Printing Logs:
|
|
|
|
DISPLAY_LOG -- displays and prints the contents of log files,
|
|
including system and network event logs.
|
|
|
|
DSM Configurator Commands:
|
|
|
|
CONFIG_DSM -- creates a new DSM configuration file.
|
|
DISTRIBUTE_DSM -- distributes a new DSM configuration file.
|
|
STATUS_DSM -- displays the currently active configuration.
|
|
|
|
DSM Startup and Shutdown Commands:
|
|
|
|
START_DSM - starts DSM system console commands.
|
|
STOP_DSM - stops DSM system console commands.
|
|
|
|
For more information on any of the DSM commands, type:
|
|
|
|
HELP command-name or command-name -HELP
|
|
|
|
_______________________________________________________________________________
|
|
|
|
THE RESUS UTILITY
|
|
|
|
|
|
RESUS is the REmote System USer facility, and allows remote operation of the
|
|
physical supervisor console from any terminal. What this basically means is
|
|
that, with RESUS enabled, all users with administrator access will be able to
|
|
execute commands that are normally only executable from the system console. It
|
|
will let you force log other users off the system (not a good idea to use this
|
|
capability unless you MUST), take the system down (you must be STUPID to do
|
|
such a thing), etc. RESUS supports the following command line options:
|
|
|
|
{-ENABLE }
|
|
{-DISABLE [-FORCE] }
|
|
{-START [-ON node name] }
|
|
{-STOP }
|
|
{-STATUS [-ON node group] }
|
|
{-HELP [-NO_WAIT] }
|
|
{-USAGE }
|
|
|
|
-ENABLE
|
|
This option enables RESUS to be used on a system. It is only
|
|
valid from the supervisor terminal.
|
|
|
|
-DISABLE
|
|
This option is used to prevent RESUS from being used on a system on
|
|
which it has previously been -ENABLEd. The -FORCE option must be
|
|
supplied if the RESUS is actually in use. It is only valid from the
|
|
supervisor terminal.
|
|
|
|
-START [-ON node name]
|
|
This is the means by which an authorised user of RESUS may
|
|
invoke REmote System USer facilities on a system. If -ON node name
|
|
is omitted, the default is the local node. For this command to be
|
|
successful, RESUS must previously have been -ENABLEd at the
|
|
supervisor terminal.
|
|
|
|
-STOP
|
|
This option terminates remote control of the supervisor terminal,
|
|
leaving the REmote System USer facilities available for use by
|
|
other authorised users. It is only valid from the remote terminal
|
|
in control of the supervisor terminal through RESUS.
|
|
|
|
-STATUS [-ON nodegroup]
|
|
This displays the current status of RESUS on all nodes in a
|
|
specified node group. If a node group is not specified, the status
|
|
of the local node is displayed.
|
|
|
|
-HELP, -H [-NO_WAIT, -NW]
|
|
|
|
Displays command-specific Help text.
|
|
|
|
-USAGE
|
|
|
|
Displays command line syntax.
|
|
|
|
_______________________________________________________________________________
|
|
|
|
THE DSM SIM COMMANDS
|
|
|
|
|
|
The DSM SIM (System Information/Metering) commands gather and display
|
|
information about system/network status and resource usage from any point on
|
|
the network.
|
|
|
|
SIM commands are invoked from the PRIMOS command line. They can be invoked
|
|
from any terminal to display information about any system on the network. They
|
|
can be invoked once, or periodically at specified time intervals. Output
|
|
displays are paginated for screen display and can be recorded in private or
|
|
system log files. User access to SIM commands on local and remote nodes is
|
|
controlled by DSM security.
|
|
|
|
A list of SIM commands and descriptions of the general SIM options follows.
|
|
|
|
LIST_ASSIGNED_DEVICES - lists assigned devices
|
|
LIST_ASYNC - lists asynchronous terminals
|
|
LIST_COMM_CONTROLLERS - lists comms controllers configuration
|
|
LIST_CONFIG - lists PRIMOS coldstart configuration
|
|
LIST_DISKS - lists disk partition names
|
|
LIST_LAN_NODES - lists nodes on LAN300 local networks
|
|
LIST_MEMORY - lists physical memory usage
|
|
LIST_PRIMENET_NODES - lists PRIMENET configured nodes
|
|
LIST_PRIMENET_LINKS - lists active PRIMENET links
|
|
LIST_PRIMENET_PORTS - lists assigned PRIMENET ports
|
|
LIST_PROCESS - lists active system processes
|
|
LIST_SEMAPHORES - lists active semaphores
|
|
LIST_SYNC - lists synchronous line configuration
|
|
LIST_UNITS - lists users open file units
|
|
LIST_VCS - lists active virtual circuits
|
|
|
|
General SIM options are:
|
|
|
|
-HELP, -H [-NO_WAIT, -NW]
|
|
-USAGE
|
|
-ON {node, nodegroup}
|
|
-PRIVATE_LOG, -PLOG pathname [-NTTY, -N]
|
|
-SYSTEM_LOG, -SLOG pathname [-NTTY, -N]
|
|
-NO_WAIT, -NW
|
|
-FREQ integer
|
|
-TIMES integer
|
|
-START, -S date+time
|
|
-STOP date+time
|
|
|
|
-ON {node, nodegroup}
|
|
|
|
This option allows you to specify the target node, or nodegroup
|
|
to which the command is to be directed. The default is to direct
|
|
the command to the node on which the command is invoked.
|
|
|
|
|
|
-PRIVATE_LOG, -PLOG pathname [ -NTTY, -N ]
|
|
-SYSTEM_LOG, -SLOG pathname [ -NTTY, -N ]
|
|
|
|
The -PRIVATE_LOG option allows you to specify a standard PRIMOS
|
|
pathname as a DSM log file to which all messages from the target
|
|
nodes are to be logged. If the log does not already exist, it is
|
|
created automatically for you. User DSMASR (the DSM application
|
|
server) must have ALL access to the directory that contains the
|
|
log.
|
|
|
|
The -SYSTEM_LOG option allows you a similar facility using logs
|
|
that are maintained on the system logging directory DSM*>LOGS.
|
|
System logs only exist on this directory or its subdirectories,
|
|
and must be created with the ADMIN_LOG command prior to use.
|
|
|
|
Logged data can subsequently be retrieved, printed and
|
|
displayed using the DISPLAY_LOG command.
|
|
|
|
-NTTY, -N; can be used with the -PRIVATE_LOG and -SYSTEM_LOG
|
|
options, and indicates that no data is to be displayed to the
|
|
user. When this option is used, the command spawns a phantom
|
|
which executes the command on your behalf, and frees your
|
|
terminal.
|
|
|
|
|
|
-HELP, -H [NO_WAIT, -NW]
|
|
|
|
This option overrides all other options to display help
|
|
information about the associated command.
|
|
|
|
|
|
-USAGE
|
|
|
|
This option overrides all other options to display usage
|
|
information, for the associated command.
|
|
|
|
|
|
-NO_WAIT, -NW
|
|
|
|
This option indicates that you are not to be prompted or queried
|
|
during the command output display.
|
|
|
|
If this option is not used, you are prompted between each target
|
|
node's response, and after every 23 lines (1 page) of output
|
|
displays '--More--' and waits, for your response. To see more
|
|
output press the carraige return. To supress further output and
|
|
return to command level, type Q, Quit, N, or No. Any other
|
|
response will display more output.
|
|
|
|
-FREQ
|
|
-TIMES
|
|
-START, -S
|
|
-STOP
|
|
|
|
These options can be used to implement periodic execution of a
|
|
command.
|
|
|
|
-FREQ option provides periodic execution of a command, with
|
|
the interval between executions determined in seconds. The
|
|
interval you specify is the interval between two successive
|
|
executions of a command, and not the interval between completion
|
|
of the command's display and the next execution. The interval is
|
|
corrected to the nearest multiple of four seconds below that
|
|
specified.If FREQ 0 is specified, the command is re-executed
|
|
immediately on completion of the previous execution. If the
|
|
interval elapses before completion of the previous display, the
|
|
next execution is delayed until the display is complete.
|
|
|
|
|
|
-TIMES is used in association with the -FREQ option, to set a
|
|
limit on the number of times that a command is to be executed.
|
|
|
|
|
|
-START, -S sets the date and time that execution starts. The
|
|
format can be in either ISO standard:
|
|
|
|
(YY_MM_DD.HH:MM:SS)
|
|
|
|
or in USA standard:
|
|
|
|
(MM/DD/YY.HH:MM:SS)
|
|
|
|
Defaults are: year to current year; date to current date; and
|
|
time to zero.
|
|
|
|
-STOP sets the date and time execution stops; format and
|
|
defaults are the same as for -Start.
|
|
|
|
In the absence of any of these four options, the command is
|
|
executed once, and immediately.
|
|
|
|
In the presence of any of these four options, the defaults
|
|
applied to the unspecified options are:
|
|
|
|
-FREQ immediate reexecution
|
|
-TIMES infinite
|
|
-START now
|
|
-STOP never
|
|
|
|
|
|
For more information on any of the SIM commands, type:
|
|
|
|
HELP command-name or command-name -HELP
|
|
|
|
_______________________________________________________________________________
|
|
|
|
PRIMOS ELECTRONIC MAIL CAPABILITIES
|
|
|
|
|
|
PRIMOS, like any other operating system worth it's beans, supports full elect-
|
|
ronic mail capabilities. However, the mail system used will vary from system
|
|
to system. A lack of standards? Perhaps. But I find it enjoyable learning
|
|
the differences between the many mail systems available.
|
|
|
|
I won't discuss how to use the mail systems I discuss due to lack of space, but
|
|
that should pose no problem, as all of them have online help available.
|
|
|
|
Prime Computer, Inc.'s old mail system (invoked by typing MAIL) is your typical
|
|
run-of-the-mill mail system. It's not too difficult to figure out how to use.
|
|
|
|
Prime Computer, Inc. has also created a PRIMOS implementation of the UNIX XMAIL
|
|
system. This seems to be their preferred electronic mail system. It is very
|
|
easy to use, not to mention very powerful.
|
|
|
|
My favorite electronic mail server is NETMAIL, written by those cunning prog-
|
|
rammers at Bramalea Software Systems (the same firm that created LOGIN_SENTRY).
|
|
NETMAIL is the mail server with the most useful features. Not only do you get
|
|
the normal features of sending user-to-user mail locally and to similarly con-
|
|
figured sites on the network, you can also send:
|
|
|
|
o Courtesy copies to other users
|
|
o Encapsulated non-SAM files
|
|
|
|
Courtesy copies is basically message forwarding. Assume I wrote a memorandum.
|
|
If I wanted all the people on the 'Board of Trustees' to get a copy I just send
|
|
cc's (courtesy copies) to them.
|
|
|
|
The file encapsulation feature makes NETMAIL a pseudo-file transfer application
|
|
like FTS (File Transfer Service, Prime's answer to UNIX's FTP utility). Say I
|
|
wrote a useful public domain program and want to distribute it to some users on
|
|
the local system and some remote systems. Don't want them to get the sources,
|
|
now do we? So we encapsulate the executable file (compiled program) and mail
|
|
it out as an encapsulated file. When the recievers read their mail, they will
|
|
be able to tell NETMAIL to save it as a file to their directory. Very nice!
|
|
|
|
Some sites use custom-written mail utilities. It all depends. Most, if not
|
|
all, are rather user-friendly and easy to learn without documentation. Don't
|
|
forget! Online help files.
|
|
|
|
_______________________________________________________________________________
|
|
|
|
ED - THE PRIMOS TEXT EDITOR
|
|
|
|
|
|
ED is the PRIMOS text editor and it is line-oriented as opposed to full-screen.
|
|
If you are using VT-100 or a similar emulation, you might play around with the
|
|
EMACS full-screen editor, but I won't be discussing EMACS here. After all, it
|
|
comes with it's own interactive tutorial. Another reason why I won't be discu-
|
|
ussing it is because not all Prime sites have it online (it is a separately
|
|
priced product). RUNOFF is another separately priced product. It is a fully
|
|
equipped word processor. ED, on the other hand, comes with PRIMOS and it is
|
|
always available.
|
|
|
|
To invoke the PRIMOS EDitor, type:
|
|
|
|
OK, ed
|
|
|
|
This will enter ED with an empty workspace. You are creating a new file. To
|
|
edit an existing filesystem object, type:
|
|
|
|
OK, ed filename
|
|
|
|
When you enter ED with an empty workspace you will be dumped into INPUT mode.
|
|
Everything you type here will be taken as input into the file you are creating.
|
|
|
|
If you tell ED to load a file and edit it (ie, ED filename) then you will be
|
|
dumped into EDIT mode. Everything you type will be taken as ED editing comm-
|
|
ands.
|
|
|
|
To switch between INPUT and EDIT mode, issue a null line (that is to say, press
|
|
the RETURN key). This brings a new problem into mind. How do you make a blank
|
|
line if when you press RETURN alone it switches between modes? Yes, this is a
|
|
shortcoming to PRIMOS users that are used to standard text editing systems. To
|
|
create a 'null' line, type a space and then press RETURN. It looks null, but
|
|
it is really treated as a line 1 character in length by ED. Take note that
|
|
both INPUT mode and EDIT mode use no prompt.
|
|
|
|
Ok, to illustrate what we have learned so far, consider this 'pretend' session
|
|
with the ED line editor:
|
|
|
|
OK, ed
|
|
INPUT
|
|
Hey, this is pretty nice. A nice text editor. Heh. Ok, lets see what
|
|
Damn! No wordwrap. Remember, press RETURN at the end of each 79
|
|
characters, ok? Now, lets go to EDIT mode...
|
|
|
|
EDIT
|
|
wow
|
|
BAD WOW
|
|
|
|
INPUT
|
|
oops! 'wow' is not an ED command! I'll discuss ED's EDIT mode
|
|
commands in a few minutes. Let's quit!
|
|
|
|
EDIT
|
|
q
|
|
FILE MODIFIED OK TO QUIT? y
|
|
OK,
|
|
|
|
Okay, we are back at the PRIMOS command line. Damn! We forgot to save our
|
|
newly-created text! What do we do now! Don't panic. Your text is still
|
|
floating around in PRIMOS' memory. To restore your ED session, type:
|
|
|
|
OK, start 1000 <-- Continues from break
|
|
|
|
or
|
|
|
|
OK, start 1001 <-- Resume in EDIT mode
|
|
|
|
So, let's test it out, shall we?
|
|
|
|
OK, start 1001
|
|
|
|
EDIT
|
|
file sample_text
|
|
q
|
|
OK,
|
|
|
|
Alright. A few comments are now in order. Normally, when done with a docu-
|
|
ment you would FILE the text away and then QUIT. If you try and QUIT without
|
|
saving new text or changes made to text, you will be told that the file has
|
|
been modified and asked for verification to quit. Should you make a 'boo-boo'
|
|
you can save your text by using one of the START command variations. The two
|
|
EDIT mode commands we have just learned are:
|
|
|
|
FILE (abbreviated FIL) Files your text to the current UFD
|
|
QUIT (abbreviated Q) Exit ED to the PRIMOS command line
|
|
|
|
An alternate command to save your text is the SAVE command (abbreviated by SA).
|
|
I prefer SAVE to FILE because SAVE is also used on my microcomputer. Use
|
|
whichever you prefer, however.
|
|
|
|
A great feature of the START command will now be illustrated. Say you are mov-
|
|
ing around UFD's and you end up trying to create a file in a directory that
|
|
you don't have W (Write) access in. Oh no! How do we save this new CPL prog-
|
|
ram we just created? Simple! Using techniques that you have just learned you
|
|
can move to a different UFD (one that you have W access in) and save your text
|
|
in. First, get into EDIT mode and QUIT the EDitor. From the PRIMOS command
|
|
line, use the OR command to get to your 'home' UFD or ATTACH to a different one
|
|
and then issue the START 1001 command. Now FILE your text. Voila! A nice
|
|
trick for the forgetful.
|
|
|
|
We now know the very basics of the PRIMOS line EDitor. We can create new files
|
|
from scratch, append text to existing files, save or abort our modifications,
|
|
and recover our text if we accidentally quit or hit the BREAK key (or send a
|
|
BREAK signal). What we don't know is how to edit the text within an existing
|
|
file or how to insert/delete text from an existing file (which is really easy).
|
|
So read on!
|
|
|
|
CAVEAT! PRIMOS normally uses the '?' and '"' (double quote) as the kill and
|
|
erase characters, respectively. So typing a '?' in INPUT mode will kill the
|
|
entire line. A '"' will similarly erase the previous character. I find the
|
|
'?' and '"' characters integral in my documents and you will probably too. The
|
|
fix? Simple. From the PRIMOS command line, type:
|
|
|
|
OK, term -erase <Ctrl-H>
|
|
OK, term -kill _
|
|
|
|
Press CONTROL-H where it says '<Ctrl-H>'. This will make the erase character
|
|
a backspace and the kill character the DELETE key. Substitute whatever char-
|
|
acters you feel most comfortable with on your microcomputer. I will detail
|
|
the TERM command more fully in Part V in the section entitled CUSTOMIZING
|
|
YOUR ENVIRONMENT.
|
|
|
|
Another caveat. The semicolon character at the end of a line (';') will force
|
|
a linefeed (as if you had pressed RETURN instead). You can end a line with
|
|
either RETURN or a semicolon (useful if your RETURN key is broken?). If you
|
|
enter a line of text containing semicolons such as this:
|
|
|
|
line one;;line three
|
|
|
|
ED will take it and output it as this:
|
|
|
|
line one
|
|
|
|
line three
|
|
|
|
instead of:
|
|
|
|
line one;;line three
|
|
|
|
Depending upon the location of the semicolon it may produce a linefeed or a
|
|
mode switch. Thus, the line of text:
|
|
|
|
This is a caveat;
|
|
|
|
will switch you from INPUT mode into EDIT mode. Avoid having semicolons at
|
|
the end of a line of text. I will detail the method you will have to use to
|
|
get around this if you want to have semicolons in your file.
|
|
|
|
Should you wish to edit/insert/delete lines of text within an existing file you
|
|
will have to learn how ED addresses text in it's buffer. I'll assume that you
|
|
have loaded a file into ED and are in EDIT mode. The basis of our example:
|
|
|
|
OK, ed example_file
|
|
EDIT
|
|
|
|
Ok, now let's view the entire file:
|
|
|
|
p 9999
|
|
.NULL.
|
|
This is the text of the file we are using in our example.
|
|
I will change this file around so that you will see how
|
|
to edit/add/delete text in a file.
|
|
.NULL.
|
|
BOTTOM
|
|
|
|
This example used 'P 9999' to display the contents. 'P' is the abbreviation
|
|
for the PRINT command. So you see, I told ED to PRINT the first 9999 lines of
|
|
the file in it's buffer. PRINT displays the specified number of lines (9999 in
|
|
the example) and makes the last line displayed the'current' line.
|
|
|
|
The .NULL. is not a part of the file, but rather a marker. It marks a place
|
|
where you can insert text. BOTTOM indicates that you are at the bottom of the
|
|
file. Should you type PRINT (or P) again it will simply say:
|
|
|
|
.NULL.
|
|
|
|
You can type PRINT (or P) by itself without a numeric argument. PRINT has a
|
|
default value of 1. Conversely, a PRINT -n ('n' being a whole number) command
|
|
will cause ED to display the file backwards.
|
|
|
|
To get to the top or bottom of a file, type:
|
|
|
|
top <--- Abbreviation is T
|
|
|
|
or
|
|
|
|
bottom <--- Abbreviation is B
|
|
|
|
Very simple. To see what the line number of the current line you are pointing
|
|
to is, type:
|
|
|
|
where
|
|
BOTTOM
|
|
|
|
Since we did that PRINT 9999 command we are at the BOTTOM of the file. Let's
|
|
go to line 2. Type:
|
|
|
|
point 2
|
|
|
|
This will set the ED pointer to line number 2. ED will tell you that you are
|
|
at line 2 by displaying line 2 on your screen. You can abbreviate the POINT
|
|
command by typing PO instead. Now try the WHERE command (it also has an abb-
|
|
reviated form, which is W). Type:
|
|
|
|
w
|
|
LINE 2
|
|
|
|
Ok, we now know how to move around in a file and display some or all of the
|
|
lines of text it contains.
|
|
|
|
The NEXT command (abbreviated by N) will move the pointer to down the specified
|
|
number of lines towards the BOTTOM of the file (assuming that the specified
|
|
number is positive). Negative numbers will move the pointer up. As per the PO
|
|
command, the new pointer line will be displayed. Here are two examples:
|
|
|
|
n 1
|
|
to edit/add/delete text in a file.
|
|
n -2
|
|
This is the text of the file we are using in our example.
|
|
|
|
To find text in the bufferm use the LOCATE command (abbreviated L). For exam-
|
|
ple, to find the string 'change this file' type:
|
|
|
|
l change this file
|
|
I will change this file around so that you will see how
|
|
|
|
Now look and see where you are. Type:
|
|
|
|
w
|
|
LINE 2
|
|
|
|
Aha! The LOCATE command not only finds the specified string, but sets the
|
|
pointer to the new line. Now, try and LOCATE the string 'Aunt Jamima'. Type:
|
|
|
|
l Aunt Jamima
|
|
BOTTOM
|
|
|
|
ED could not find the string in the text. The new pointer is BOTTOM, meaning
|
|
that you are at the last line in the file.
|
|
|
|
Similar to LOCATE is the FIND command (abbreviated F). FIND only checks to see
|
|
if the specified string is at the beginning of a line (ie, the first character
|
|
is in column 1, the second in column 2, and so forth). Here is an example:
|
|
|
|
find to edit/add
|
|
to edit/add/delete text in a file.
|
|
|
|
As with LOCATE, FIND displays the line and resets the pointer to its new loc-
|
|
ation. If the string is not found FIND returns with BOTTOM and sets the point-
|
|
er to the bottom of the file.
|
|
|
|
NFIND is a similar command which works in the opposite manner of the FIND comm-
|
|
and. NFIND (abbrevated NF) will locate the first line below the current line
|
|
which does not begin with the specified string. In the following example, I'll
|
|
display use of the NFIND command as well as display the method you may use to
|
|
have multiple ED commands on one line.
|
|
|
|
EDIT
|
|
p3
|
|
.NULL.
|
|
This is the text of the file we are using in our example.
|
|
I will change this file around so that you will see how
|
|
to edit/add/delete text in a file.
|
|
top, nfind This is
|
|
I will change this file around so that you will see how
|
|
|
|
As you can see, NFIND only finds the first line that does not start with the
|
|
specified string. Also note the use of the comma as a command delimeter when
|
|
issuing the TOP and NFIND commands. Just like with LOCATE and FIND, NFIND will
|
|
also return BOTTOM and set the pointer to the end of the file if it cannot find
|
|
a line not starting with the string you specify.
|
|
|
|
You can also FIND and NFIND string patterns on a line starting at a column pos-
|
|
ition other than 1. The format for this option is displayed below:
|
|
|
|
f(8) change this file
|
|
I will change this fie around so that you will see how
|
|
|
|
The parenthesis are required and there cannot be any spaces between the command
|
|
and the (#).
|
|
|
|
To append text to the end of the current line, use the APPEND command (abbrevi-
|
|
ated with A). To append ' 02/24/89.' to the end of the last line,
|
|
type:
|
|
|
|
po3
|
|
to edit/add/delete text in a file.
|
|
a 02/24/89.
|
|
to edit/add/delete text in a file. 02/24/89.
|
|
|
|
You must have a space between the APPEND command and the string you wish to
|
|
append. If you had instead typed:
|
|
|
|
a 02/24/89.
|
|
|
|
you would have gotten:
|
|
|
|
to edit/add/delete text in a file.02/24/89.
|
|
|
|
Use the CHANGE command (abbreviated C) to change a string in the current line.
|
|
The first character after the CHANGE command is used as the delimeter. This is
|
|
a more complicated command than most other ED commands. Format:
|
|
|
|
CHANGE/string-1/string-2/[G] [n]
|
|
|
|
'string-1' is the original string and 'string-2' is the replacement string. G
|
|
specifies a global change. If G is ommitted then only the first occurance of
|
|
string-1 will be changed. 'n' is a pointer value. If it is 0 or 1 (default
|
|
values) then the change will be made to the current line (assuming the G option
|
|
is not in use). If 'n' is a value other than 0 or 1 then ED will inspect and
|
|
make changes on 'n' lines starting at the current line. As sual, ED will reset
|
|
the pointer to the last line inspected. Should the file contain fewer than 'n'
|
|
lines then ED will make the specified changes in all the lines of the file and
|
|
end by saying BOTTOM.
|
|
|
|
Should you wish to change a string containing slashes ('/'), CHANGE's delimeter
|
|
character, then substitute a new delimeter character. Examples:
|
|
|
|
f 02
|
|
to edit/add/delete text in a file. 02/24/89.
|
|
change:02/:01/:
|
|
to edit/add/delete text in a file. 01/24/89.
|
|
c#/#-#
|
|
to edit/add/delete text in a file. 01-24-89.
|
|
c/01-24/24-Feb/
|
|
to edit/add/delete text in a file. 24-Feb-89.
|
|
|
|
You should always issue the TOP command prior to making global file changes.
|
|
|
|
To insert characters at the beginning of a line, use CHANGE like this:
|
|
|
|
po3
|
|
to edit/add/delete text in a file. 24-Feb-89.
|
|
c//Last Line --> /
|
|
Last Line --> to edit/add/delete text in a file. 24-Feb-89.
|
|
|
|
Remember our dilema with the semicolon character (';')? Say you want to have
|
|
semicolons in your file. Lets put a semicolon in our file. First, lets mark
|
|
where we want ED to put the semicolon. Do this:
|
|
|
|
po3
|
|
Last Line --> to edit/add/delete text in a file. 24-Feb-89.
|
|
c/. 24/@ 24/
|
|
Last Line --> to edit/add/delete text in a file@ 24-Feb-89.
|
|
top, c/@/;/g9999
|
|
Last Line --> to edit/add/delete text in a file; 24-Feb-89.
|
|
|
|
If you know where you want your semicolons from the start then just use a char-
|
|
acter that you don't plan on using elsewhere in the file (like the '@' charact-
|
|
er) and place them where you desire. Then perform the above procedure. Voila!
|
|
Instant semicolons when you thought it couldn't be done.
|
|
|
|
To delete commands from a file, use the DELETE command (abbreviated with D). I
|
|
believe I don't like the second line of our example file. Let's delete it. To
|
|
do this, type:
|
|
|
|
po2
|
|
d
|
|
top
|
|
p9999
|
|
.NULL.
|
|
This is the text of the file we are using in our example.
|
|
Last Line --> to edit/add/delete text in a file; 24-Feb-89.
|
|
.NULL.
|
|
|
|
No more line 2. As with other ED commands, DELETE deletes from the current
|
|
line. DELETE 1 will not delete the first line of the file, but rather the
|
|
current line. DELETE 5 will delete the fifth line from the current line (with
|
|
starting line being the current line).
|
|
|
|
The last ED command I will go over is the RETYPE command (abbreviated with R).
|
|
RETYPE will delete tge current line and replace it with the specified string.
|
|
Notice that the text of our example is now nonsensical. The second line is a
|
|
sentance fragment. All hackers should spell correctly (grin). Let's fix this
|
|
grammatical error.
|
|
|
|
po2
|
|
Last Line --> to edit/add/delete text in a file; 24-Feb-89.
|
|
r Now you will learn how to edit/add/delete text in a file.
|
|
Now you will learn how to edit/add/delete text in a file.
|
|
|
|
RETYPE followed by a space and a RETURN will delete the current line. This
|
|
will make a 'null' line. This can be used as an alternate method for creating
|
|
'null' lines (to delimit paragraphs in your text) as opposed to making the line
|
|
a blank space.
|
|
|
|
Let's look at both the original example file and its present form:
|
|
|
|
ORIGINAL:
|
|
|
|
This is the text of the file we are using in our example.
|
|
I will change this file around so that you will see how
|
|
to edit/add/delete text in a file.
|
|
|
|
CURRENT:
|
|
|
|
This is the text of the file we are using in our example.
|
|
Now you will learn how to edit/add/delete text in a file.
|
|
|
|
The most useful means of using ED is to upload text (documents or sources) to
|
|
the host Prime. Simply load in the file on your microcomputer and go into your
|
|
terminal program's editor. Change all occurances of a null line to a space and
|
|
a RETURN. Now enter ED and upload your file via the ASCII protocol. You might
|
|
need to lower the sending speed (the line delay) if you seem to be sending text
|
|
too fast for ED to get it. When done with the send, just enter EDIT mode and
|
|
SAVE or FILE the text.
|
|
|
|
|
|
WARNING: If the filename you specify ED to save your text as exists in the cur-
|
|
rent UFD then ED will overwrite the file with the text in its buffer. Be care-
|
|
ful not to use an existing filename when you save files or you might be sorry.
|
|
|
|
Now for some important notes on PRIMOS filenames.
|
|
|
|
1. Filename can be up to 32 characters long.
|
|
2. Filenames can only contain the following characters: A-Z, 0-9, & - $ . _ / #
|
|
3. The first character cannot be a number.
|
|
4. No embedded blanks or special characters (like [ ] ( ) { } etc).
|
|
5. All characters are mapped to UPPER CASE by PRIMOS.
|
|
|
|
Legal Filenames Illegal Filenames
|
|
|
|
MYFILE MY FILE
|
|
TODAYS-SYSTEMS SYSTEMS?
|
|
$MONEY 4MONEY
|
|
TEXT_FILE ACCTS@PRIME
|
|
PRIMES&VAXEN "COOL"
|
|
|
|
NOTE: ED does not like TABs! Do not use your terminal's TAB key! ED will
|
|
not understand them. To tell ED to use a TAB, use the backslash ('\') charac-
|
|
ter. Example:
|
|
|
|
tab\this\out\for me.
|
|
|
|
is interpreted as:
|
|
|
|
tab this out for me.
|
|
|
|
EDitor has many other commands. Type HELP ED to obtain a list of them and a
|
|
brief statement of each one's function.
|
|
|
|
Question: Ever see a more detailed description of how to use a text editor on a
|
|
mainframe in a 'how-to-hack-this-op/sys' type of file?
|
|
|
|
_______________________________________________________________________________
|
|
|
|
EXPERIMENTATION WITH OTHER PRIMOS APPLICATIONS AND UTILITIES
|
|
|
|
|
|
There are many other applications that you will find on Primes. Some of them
|
|
useful and interesting, some of no use whatsoever to the hacker. I can't begin
|
|
to describe them here. This part of the series is already larger than I had
|
|
planned, so I am going to have to end it here. Here is a very incomplete list
|
|
of applications commonly found on Prime computer systems:
|
|
|
|
PRIME INFORMATION A database system
|
|
PRIME WORD A word-processing system
|
|
MIDAS A graphics design utility
|
|
TELL-A-GRAF A graphing utility
|
|
ORACLE A database system
|
|
|
|
There are tons more application systems to be found on Primes. Experiment! It
|
|
is best to experiment with available applications to see if they can be useful.
|
|
Read people's word processing documents, see what's in their database. Never
|
|
know what you might find! Just be careful not to delete or change anything!
|
|
|
|
In the next installment of this series I will detail the networking utilities &
|
|
software available for the Prime computer. I will cover the network-related
|
|
SIM commands, the NETLINK utility, PRIMENET, and more! Look for it.
|
|
|
|
May the forces of darkness become confused on the way to your house.
|
|
|
|
_______________________________________________________________________________
|
|
|
|
End of Part III of the "Introduction to the PRIMOS Operating System"
|
|
_______________________________________________________________________________
|
|
|
|
|