Concepts:
Since we did this part last week. let's use the text space on this page
for some new material that doesn't need a graphic. The topic heading on page 355 only mentions one of several tips that page of advice covers. The point of the discussion there is that you can make some elements of a script run faster if you run a command with useful output once, and save that output in a script variable. This avoids two delays. The delay of running
the command a second time may not be much, but it exists. The time it
takes for the computer to search
for the command in all the folders listed in the PATH variable may be
the longer delay. (It's a computer. It doesn't remember where it found
the command the last time it found it.) The text's tip about saving the
output of the clear command and
the output of the date command
in separate variables will let your script simply echo
the content of those variables as needed, which will avoid each of the
expected delays each time your script subsequently needs those values.
This idea is only valid as long as you are not expecting the date or
the screen size to change while the script continues to run. Before using
a tip, ask yourself if the assumptions it is based on are valid. Note,
also, that in order to capture the output of these commands, you have
to run them at least once. Since that is the case, pick a good spot in
your program to do so. The text also reminds us of a trick that will extend this savings to
other scripts. Remember that script variables are local
to a script. That means that the variable and its contents are forgotten
when the script stops running, unless you export
the variable, making it available to other scripts you may run in the
same Linux session. This will come in handy for projects that use common
variables across several scripts.
Note, that you will have to create, assign values to, and export the variables
in the first script that runs
in the project in order to make use of the efficiency of this idea. The
nature of the script you are writing should dictate what other commands
might be handy to capture in variables for repeated use. Let's move to page 359 to discuss functions.
A function is a named set of commands. You name it so you can invoke
it wherever you need to run it in the course of a script. The example
on page 360 is rather silly. The author has created a function that runs
one command which is shorter than the name he gave it. The format for
this example, and for all functions you may use in a script, looks like
this: In this generic structure, I am showing you that a function must have a name, it must have parentheses that may (or may not) be empty, and it must contain one or more command lines to execute. The formal statement of the structure and commands in a function may be called the function definition. The second half of page 360 shows that you can create a function definition on a command line. In the example, the text shows us that when the operating system sees a function name that it does not know, it provides the opportunity (requires, it really) to enter a left curly brace, some number of command lines, and a right curly brace, which enables the function to be used. If we were defining our function in one of the C languages, we would have to state in the definition how many, and what kind of arguments this function is meant to accept. A shell based function is more open minded. The text explains that we can pass up to nine arguments to a function, then reference their values in the function's code as $1 for the contents of the first argument, $2 for the contents of the second argument, and so on through $9. I think the author has forgotten to revise his program in the discussion at the top of page 361. He is expecting the function to read and use the contents of the function's first argument when he has not told it to do so. The proper code for the function is in Project 7-16 at the end of the chapter. The text should probably have continued the lesson with a discussion
of writing a function in a script. The structure for a function in a script
is no different from the structure of a function entered on the command
line, so he contents himself with discussing it on a command line, which
may be distracting to the reader. The author then lists some functions
that he recommends for use in the phone list project he started earlier.
His general recommendation is to have a script full of useful functions
that runs when he logs in to his system. The author provides a list of troubleshooting techniques on pages 362 and 363. Review this list of advice, common typographical errors, and common logic errors. Among them are:
|