Linux set Command & How to Use it {9 Examples}

Introduction

The set command is a built-in Linux shell command that displays and sets the names and values of shell and Linux environment variables. On Unix-like operating systems, the set command functions within the Bourne shell (sh), C shell (csh), and Korn shell (ksh).

In this tutorial, you will learn what the set command is and how to use it.

How to use the Linux set command

Prerequisites

  • A system running Linux.
  • Access to a terminal/command line.

Linux set Command Syntax

The general syntax for the set command is:

set [options] [arguments]

Options

In the context of the set command, [options] are settings or flags that are set or unset in the Bash shell environment. Use it to influence the behavior of defined shell scripts and help execute the desired tasks.

  • Set an option by using a minus sign (-) followed by the appropriate option.
  • Unset an option by using a plus sign (+) followed by the appropriate option.

Arguments

[arguments] are positional parameters and they are assigned in order with the following parameters:

  • $1
  • $2
  • $n

Not specifying any options or arguments causes the command to print all shell variables.

Exit Values

The set command has three exit values:

  • 0. Marks a successful completion.
  • 1. Failure caused by an invalid argument.
  • 2. Failure resulting in a usage message, usually because an argument is missing.

Linux set Command Options

The set command provides an extensive list of options that can be combined.

Most options have a corresponding -o flag that can be used to invoke the option. The table below lists all options and their respective alternative form using the -o flag syntax.

Options -o flags Description
-a -o allexport Marks all created or modified variables or functions for export.
-b -o notify Alerts the user upon background job termination.
-e -o errexit Instructs a shell to exit if a command fails, i.e., if it outputs a non-zero exit status.
-f -o noglob Disables filename generation (globbing).
-h -o hashall Locates and saves function commands when a function is defined. The -h option is enabled by default.
-k -o keyword Places all assignment arguments in the environment for a command, not just those preceding the command name.
-n -o noexec Reads commands but doesn’t execute them.
-m -o monitor Displays a message when a task completes.
-p -o privileged Disables the $ENV file processing and shell functions importing. The -p option is enabled by default when the real and effective user IDs don’t match. Turning it off sets the effective uid and gid to the real uid and gid.
-t -o onecmd Reads one command and then exits.
-u -o nounset Treats unset or undefined variables as an error when substituting (during parameter expansion). Does not apply to special parameters such as wildcard * or @.
-v -o verbose Prints out shell input lines while reading them.
-x -o xtrace Prints out command arguments during execution.
-B -o braceexpand Performs shell brace expansion.
-C -o noclobber Prevents overwriting existing regular files by output redirection. By default, Bash allows redirected output to overwrite existing files.
-E -o errtrace Causes shell functions to inherit the ERR trap.
-H -o histexpand Enables style history substitution. The option is on by default when the shell is interactive.
-P -o physical Prevents symbolic link following when executing commands.
-T -o functrace Causes shell functions to inherit the DEBUG trap.
-- n/a Assigns the remaining arguments to the positional parameters. If there are no remaining arguments, unsets the positional parameters.
- n/a Assigns any remaining arguments to the positional parameters. Turns off the -x and -v options.
n/a -o emacs Uses and emacs-style line editing interface.
n/a -o history Enables command history.
n/a -o ignoreeof The shell doesn’t quit upon reading the end of file.
n/a -o interactive-comments Allows comments in interactive commands.
n/a -o nolog Does not record function definitions in the history file.
n/a -o pipefail The return value of a pipeline is the status of the last command that had a non-zero status upon exit. If no command had a non-zero status upon exit, the value is zero.
n/a -o posix Causes Bash to match the standard when the default operation differs from the Posix standard.
n/a -o vi Uses a line editing interface similar to vi.

Linux set Command Examples

This section lists examples of the most common uses of the set command.

Using the set Command Without Options

Running the command without options or arguments outputs a list of all settings – the names and values of all shell variables and functions. Since the list is very long, you can scroll through it using the Page Up and Page Down keys.

Following is an example of a partial set command output:

Set command output.

Script Debugging

The set command is especially handy when you are trying to debug your scripts. Use the -x option with the set command to see which command in your script is being executed after the result, allowing you to determine each command’s result.

The following example demonstrates how to debug scripts with set -x. Follow the steps below:

1. Run set -x:

set -x

2. Use your favorite text editor (we use the vi editor) to create a script. We created a simple loop that allows us to see the -x option effects:

x=10
while [ $x -gt 0 ]; do
         x=$[ $x-1 ]
         echo $x
         sleep 2
done

3. Make sure to chmod the script to make it executable. This step is always mandatory before running a script. The syntax is:

chmod +x [script-name.sh]

4. Execute the script. The syntax is:

./[script-name.sh]
How to debug a script using the set command.

The output prints one line at a time, runs it, shows the result if there is one, and moves on to the next line.

Another way to enable debugging is to place the -x flag on the shebang line of the script:

#!/bin/bash -x

Script Exporting

Automatically export any variable or function created using the -a option. Exporting variables or functions allows other subshells and scripts to use them.

Enable script exporting by running the following command:

set -a

The following example shows how script exporting works. Follow the steps below:

1. Create a new script using your editor of choice. For example:

one=1
two=2
three=3
four=4
/bin/bash

The /bin/bash argument marks the start of a new shell.

2. Check if the script works in a new shell:

echo $one $two $three $four
Exporting a script using the set command.

The output proves that the function we created was exported and works even when starting a new shell.

Exit When a Command Fails

Use the -e option to instruct a script to exit if it encounters an error during execution. Stopping a partially functional script helps prevent issues or incorrect results.

Create a script with the following contents to test this option:

#!/bin/bash
set -e
cat nonexistingfile
echo "The end"
Use the set command to exit a script in case of failure.

In the example above, the script encounters an error when trying to show the contents of nonexistingfile because that file doesn’t exist, causing it to exit at that point. Thus, the final echo command isn’t executed.

Note: You can use the cat command to show a file’s contents in a terminal window.

Prevent Data Loss

The default Bash setting is to overwrite existing files. However, using the -C option configures Bash not to overwrite an existing file when output redirection using >, >&, or <> is redirected to that file.

For example:

Prevent Bash from overwriting files using the set command.

Bash first allows us to overwrite the listing.txt file. However, after running the set -C command, Bash outputs a message stating that it cannot overwrite an existing file.

Report Non-Existent Variables

The default setting in Bash is to ignore non-existent variables and work with existing ones. Using the -u option prevents Bash from ignoring variables that don’t exist and makes it report the issue.

For example, the following script doesn’t contain the set -u command and Bash ignores that $var2 isn’t defined.

#!/bin/bash
var1="123"
echo $var1 $var2

The output contains only $var1.

Bash ignores non-existing variables and outputs the result.

However, changing the script and adding the set -u command prevents Bash from ignoring the problem and reports it:

#!/bin/bash
set -u
var1="123"
echo $var1 $var2
Bash reports non-existing variables in the output.

Set Positional Parameters

The set command can also assign values to positional parameters. A positional parameter is a shell variable whose value is referenced using the following syntax:

$[N]

The [N] value is a digit that denotes the position of the parameter. For example, $1 is the first positional parameter, $2 is the second parameter, etc.

For example:

set first second third

Running the command above sets first to correspond to the $1 positional parameter, second to $2, and third to $3. Check this with the echo command:

echo $2
Using the set command to set positional parameters.

Unset positional parameters by running:

set --

Split Strings

Use the set command to split strings based on spaces into separate variables. For example, split the strings in a variable called myvar, which says “This is a test”.

myvar="This is a test"

set -- $myvar
echo $1
echo $2
echo $3
echo $4

Split strings into separate variables using the set command.

Use this option to extract and filter out information from the output of a command, similar to what the awk command does.

Set allexport and notify Flags

The -o allexport flag allows you to automatically export all subsequently defined variables, while the -o notify flag instructs the shell to print job completion messages right away.

To set the flags, run:

set -o allexport -o notify

In the following example, we see that the shell notifies you upon background job completion since the script was exported:

An example for the allexport and notify options of the set command.

Note: If you want to run a process in the background, add the ampersand (&) symbol at the end of the command.

Conclusion

You now know what the set command is and how you can use it in Linux. Test out the different options to better understand the command and maximize your control of the Linux environment used by different packages.

If Bash is an interesting topic for you, check out our comprehensive tutorial on Bash Functions: How to Use Them.

原创文章,作者:3628473679,如若转载,请注明出处:https://blog.ytso.com/222547.html

(0)
上一篇 2022年1月6日
下一篇 2022年1月6日

相关推荐

发表回复

登录后才能评论