1 Introduction 2 Ground Rules Building a File System 3 File Systems 4 File Content Data Structure 5 Allocation Cluster Manager 6 Exceptions and Emancipation 7 Base Classes, Testing, and More 8 File Meta Data 9 Native File Class 10 Our File System 11 Allocation Table 12 File System Support Code 13 Initializing the File System 14 Contiguous Files 15 Rebuilding the File System 16 Native File System Support Methods 17 Lookups, Wildcards, and Unicode, Oh My 18 Finishing the File System Class The Init Program 19 Hardware Abstraction and UOS Architecture 20 Init Command Mode 21 Using Our File System 22 Hardware and Device Lists 23 Fun with Stores: Partitions 24 Fun with Stores: RAID 25 Fun with Stores: RAM Disks 26 Init wrap-up The Executive 27 Overview of The Executive 28 Starting the Kernel 29 The Kernel 30 Making a Store Bootable 31 The MMC 32 The HMC 33 Loading the components 34 Using the File Processor 35 Symbols and the SSC 36 The File Processor and Device Management 37 The File Processor and File System Management 38 Finishing Executive Startup Users and Security 39 Introduction to Users and Security 40 More Fun With Stores: File Heaps 41 File Heaps, part 2 42 SysUAF 43 TUser 44 SysUAF API Terminal I/O 45 Shells and UCL 46 UOS API, the Application Side 47 UOS API, the Executive Side 48 I/O Devices 49 Streams 50 Terminal Output Filters 51 The TTerminal Class 52 Handles 53 Putting it All Together 54 Getting Terminal Input 55 QIO 56 Cooking Terminal Input 57 Putting it all together, part 2 58 Quotas and I/O UCL 59 UCL Basics 60 Symbol Substitution 61 Command execution 62 Command execution, part 2 63 Command Abbreviation 64 ASTs 65 Expressions, Part 1 66 Expressions, Part 2: Support code 67 Expressions, part 3: Parsing 68 SYS_GETJPIW and SYS_TRNLNM 69 Expressions, part 4: Evaluation UCL Lexical Functions 70 PROCESS_SCAN 71 PROCESS_SCAN, Part 2 72 TProcess updates 73 Unicode revisted 74 Lexical functions: F$CONTEXT 75 Lexical functions: F$PID 76 Lexical Functions: F$CUNITS 77 Lexical Functions: F$CVSI and F$CVUI 78 UOS Date and Time Formatting 79 Lexical Functions: F$CVTIME 80 LIB_CVTIME 81 Date/Time Contexts 82 SYS_GETTIM, LIB_Get_Timestamp, SYS_ASCTIM, and LIB_SYS_ASCTIM 83 Lexical Functions: F$DELTA_TIME 84 Lexical functions: F$DEVICE 85 SYS_DEVICE_SCAN 86 Lexical functions: F$DIRECTORY 87 Lexical functions: F$EDIT and F$ELEMENT 88 Lexical functions: F$ENVIRONMENT 89 SYS_GETUAI 90 Lexical functions: F$EXTRACT and F$IDENTIFIER 91 LIB_FAO and LIB_FAOL 92 LIB_FAO and LIB_FAOL, part 2 93 Lexical functions: F$FAO 94 File Processing Structures 95 Lexical functions: F$FILE_ATTRIBUTES 96 SYS_DISPLAY 97 Lexical functions: F$GETDVI 98 Parse_GetDVI 99 GetDVI 100 GetDVI, part 2 101 GetDVI, part 3 102 Lexical functions: F$GETJPI 103 GETJPI 104 Lexical functions: F$GETSYI 105 GETSYI 106 Lexical functions: F$INTEGER, F$LENGTH, F$LOCATE, and F$MATCH_WILD 107 Lexical function: F$PARSE 108 FILESCAN 109 SYS_PARSE 110 Lexical Functions: F$MODE, F$PRIVILEGE, and F$PROCESS 111 File Lookup Service 112 Lexical Functions: F$SEARCH 113 SYS_SEARCH 114 F$SETPRV and SYS_SETPRV 115 Lexical Functions: F$STRING, F$TIME, and F$TYPE 116 More on symbols 117 Lexical Functions: F$TRNLNM 118 SYS_TRNLNM, Part 2 119 Lexical functions: F$UNIQUE, F$USER, and F$VERIFY 120 Lexical functions: F$MESSAGE 121 TUOS_File_Wrapper 122 OPEN, CLOSE, and READ system services UCL Commands 123 WRITE 124 Symbol assignment 125 The @ command 126 @ and EXIT 127 CRELNT system service 128 DELLNT system service 129 IF...THEN...ELSE 130 Comments, labels, and GOTO 131 GOSUB and RETURN 132 CALL, SUBROUTINE, and ENDSUBROUTINE 133 ON, SET {NO}ON, and error handling 134 INQUIRE 135 SYS_WRITE Service 136 OPEN 137 CLOSE 138 DELLNM system service 139 READ 140 Command Recall 141 RECALL 142 RUN 143 LIB_RUN 144 The Data Stream Interface 145 Preparing for execution 146 EOJ and LOGOUT 147 SYS_DELPROC and LIB_GET_FOREIGN CUSPs and utilities 148 The I/O Queue 149 Timers 150 Logging in, part one 151 Logging in, part 2 152 System configuration 153 SET NODE utility 154 UUI 155 SETTERM utility 156 SETTERM utility, part 2 157 SETTERM utility, part 3 158 AUTHORIZE utility 159 AUTHORIZE utility, UI 160 AUTHORIZE utility, Access Restrictions 161 AUTHORIZE utility, Part 4 162 AUTHORIZE utility, Reporting 163 AUTHORIZE utility, Part 6 164 Authentication 165 Hashlib 166 Authenticate, Part 7 167 Logging in, part 3 168 DAY_OF_WEEK, CVT_FROM_INTERNAL_TIME, and SPAWN 169 DAY_OF_WEEK and CVT_FROM_INTERNAL_TIME 170 LIB_SPAWN 171 CREPRC 172 CREPRC, Part 2 173 COPY 174 COPY, part 2 175 COPY, part 3 176 COPY, part 4 177 LIB_Get_Default_File_Protection and LIB_Substitute_Wildcards 178 CREATESTREAM, STREAMNAME, and Set_Contiguous 179 Help Files 180 LBR Services 181 LBR Services, Part 2 182 LIBRARY utility 183 LIBRARY utility, Part 2 184 FS Services 185 FS Services, Part 2 186 Implementing Help 187 HELP 188 HELP, Part 2 189 DMG_Get_Key and LIB_Put_Formatted_Output 190 LIBRARY utility, Part 3 191 Shutting Down UOS 192 SHUTDOWN 193 WAIT 194 SETIMR 195 WAITFR and Scheduling 196 REPLY, OPCOM, and Mailboxes 197 REPLY utility 198 Mailboxes 199 BRKTHRU 200 OPCOM 201 Mailbox Services 202 Mailboxes, Part 2 203 DEFINE 204 CRELNM 205 DISABLE 206 STOP 207 OPCCRASH and SHUTDOWN 208 APPEND Glossary/Index Downloads |
UCL Basics This article is the first in a series where we will look at the execution of scripts in UCL. Unless otherwise noted, UOS UCL and VMS DCL are compatible from the user's perspective. First, let's look at an updated Run routine:
Symbol Substitution The Parse procedure performs symbol substitution. This is a process that allows
customization of commands, including program execution. Most shell scripts have
some similar ability. Essentially, symbol substitution means that the actual
values of symbols are substituted for the symbol names in the
command line prior to the line being executed. The apostrophe (') is used to
indicate a symbol substitution. For instance:
would return a directory listing of any files named "A". But
would return a directory listing of any files with the name of the value of symbol A. For instance, if symbol A contained the value "XYZ", then the above command would look like this after substitution:
A couple of things to note: first, the apostrophes must enclose the symbol. Second, the apostrophes are removed when the symbol value is substituted. Because the symbol name is delimited by apostrophes, we can embed the symbol name anywhere in the line. For instance:
would do a directory listing of any filename starting with "X", ending with "1" and with symbol A's value in-between. In the case of A containing "XYZ", after substitution the command would be:
In the case of string literals (those delimited by double quotes), two
apostrophes must be used to specify the start of a symbol name for substitution.
Thus, single apostrophes can be freely used within literals without having to worry
about inadvertant symbol substitution. Example:
Note that the symbol is still terminated by only a single apostrophe.
Symbol substitution is iterative. That is, if the substituted value contains
apostrophe-delimited symbol name, then that is also substituted. For example,
assume we have two symbols with the following values:
Now, if UCL does a substitution of the following:
The first iteration of substitution results in:
The next iteration results in:
Note that iterative substitution does not occur inside string literals. Thus, a full iterative substitution of:
will result in a final result of:
Phase Two Symbol Substitution
the substitution would result in:
This is because both P and B are substituted, as expected. But consider:
In this case, after phase 1 substitution, the command would look like this:
Then phase two of symbol substition occurs. In this case, symbol P5 is substituted. Assuming P5 contains "ABC", the new command will be:
which is quite different from
Symbol values are also used in expressions, which we'll cover in a future article. In such a case, as we will see, the symbol's value is used without apostrophes or ampersands because of context. However symbol substitution may, in most cases, accomplish the same end result in expressions. But since it is unnecessary, it is best not to do so in command files, both for performance sake and clarity of script code.
Other UCL script elements
Labels are a means of control flow of execution through command files. A label
is a token consisting of characters that are valid for a symbol name, followed
by a colon (:). Any symbol name followed by a colon is treated as a label even
if there is a symbol of the same name. Labels are ignored when encountered, but
can be used as destinations for such commands as GOTO. Example label:
Comments help to document scripts. They begin with an exclamation point (!) and
extend to the end of the line. They can be on a line by themselves or after some
other script code. An example comment from a command file:
Sometimes it is useful to continue a very long command onto multiple lines. When
being typed at a terminal, a command is usually considered complete at the end of the line.
To allow continuing a command onto the next input line from the terminal, a dash
(-) can be included at the end of the line. The dash must be immediately preceeded by a
space or tab. Although not required in command files, the line continuation may
be used there as well. Note, however, that any line with a comment on it cannot
be continued since the dash is considered to be part of the comment itself. Multiple
lines can be continued. An example of line continuation:
The above lines would be interpreted as a single line that looked like this:
Finally, let's consider the difference between running a command file and typing commands manually from a terminal (called "interactive mode"). In the latter case, some operations make no sense and will result in an error. For instance, a GOTO command is pointless in interactive mode, because there is no target label to which to move execution. Likewise, using a label in interactive mode makes no sense because once the line has been entered, it is done and gone. Any future (or prior) reference to that label can not go to it. We will discuss these situations as they come up.
UOS Errors and UCL Error Handling
UOS errors can be
warnings, errors, or fatal errors. Error handling can deal with each of these
separately, if desired. When an error is displayed to the user, it consists of
a string following this format:
Now that we've described the basic behavior of UCL we can look at the code to implement it. In the next article, we will implement symbol substitution, as described above.
Copyright © 2019 by Alan Conroy. This article may be copied in whole or in part as long as this copyright is included. |