18. Bash Shell - Directory Stack Builtins
Contents
With a directory stack, we can push the directories we visit sequentially into the directory stack, and when we’ve done a series of operations, we can go all the way back to the origin based on the record of the directory stack.
Directory Stack Commands
The directory stack provides us with three available commands.
dirs
Displays all directories recorded in the directory stack:
|
|
data:image/s3,"s3://crabby-images/9f29c/9f29c162d807d07a2885532f33868f72fd07d7a7" alt="img"
Check dirs's definition and usage
pushd
Records the specified directory to the directory stack and switches the working directory to the recorded directory:
|
|
data:image/s3,"s3://crabby-images/53187/53187d94ef3213d5a89ae2216b850e4cfd5faccf" alt="img"
Check pushd's definition and usage
popd
Remove the last directory recorded in the directory stack and switch the working directory to the removed directory:
|
|
data:image/s3,"s3://crabby-images/7468b/7468b78c64a3168caa2a997e2c53b922a493c4e7" alt="img"
Check popd's definition and usage
Preparing Directories
Let’s prepare some directories for demonstration:
|
|
data:image/s3,"s3://crabby-images/05d67/05d67c17f123b531751c44cf090675d8afa4739a" alt="img"
Create nested directories and show their tree structure
Now that we have some nested directories, we can begin to demonstrate. The directory stack can store any directory we push into, and the nested directory is used here just for ease of operation.
Use of Commands
Adding Directories
Let’s adding directories to directory stack:
|
|
data:image/s3,"s3://crabby-images/20ec5/20ec5f8b5cd8135ad18a8a0ff2de79393c7aefe2" alt="img"
Switch to user's home directory, check to make sure that dirs only shows the tilde(~) and start pushing the nested directories into directory stack
Show Recorded Directories
By Default
Use dirs to print the recorded directories:
|
|
data:image/s3,"s3://crabby-images/d9164/d9164968c994bb8cce23074b1c307026cbeda6c4" alt="img"
Show the directory stack recorded directories
With User Home Directory Name
Use dirs -l to print the recorded directories with user home directory’s name instead of a tilde:
|
|
data:image/s3,"s3://crabby-images/8c425/8c425a4831ea644fe457932661f0b6bc24ae7158" alt="img"
Show the directory stack recorded directories with user home name instead of a tilde
Line by Line
Use dirs -p to print the recorded directories line by line:
|
|
data:image/s3,"s3://crabby-images/cdd9b/cdd9b3b62aebc85cc1e3852e7ba8c5d4b0779de5" alt="img"
Show the directory stack recorded directories line by line
Line by Line With Their Indexes
Use dirs -v to print the recorded directories line by line with their indexes:
|
|
data:image/s3,"s3://crabby-images/35582/3558225d40c500ce2898277b5cf98e3c70306d36" alt="img"
Show the directory stack recorded directories line by line with their indexes
First Recorded Directory
Use dirs -0 to print the first recorded directory:
|
|
data:image/s3,"s3://crabby-images/c7931/c79314a79e865e582ea4f8833649e1d268a420cf" alt="img"
Show the first recorded directory
Last Recorded Directory
Use dirs +0 to print the last recorded directory:
|
|
data:image/s3,"s3://crabby-images/84d5e/84d5e3e6694d66781c11da7304f1399455cb0a32" alt="img"
Show the last recorded directory
Use Recorded Directories
Use From right
Use pushd -0 to change to the rightmost directory and use it as a working directory:
|
|
data:image/s3,"s3://crabby-images/c3037/c303764c8673584f97602fa25d8ef7a3a0065459" alt="img"
Use the first recorded directory
Use From left
Use pushd +1 to change to the directory before the leftmost one and use it as a working directory:
|
|
data:image/s3,"s3://crabby-images/b80d1/b80d1ba391e47307263896a0ab0c27e2f1e3e266" alt="img"
Use the previous recorded directory
Remove Recorded Directories
Remove From right
Use popd -0 to remove the rightmost directory:
|
|
data:image/s3,"s3://crabby-images/17f07/17f0790141164d40ec58897fe41aadf831fffc67" alt="img"
Remove the first recorded directory
Remove From left
Use popd +0 to remove the leftmost directory and use the previous directory as a working directory:
|
|
data:image/s3,"s3://crabby-images/20e2b/20e2ba8b07c4d0ee1c22cc204860704e1e930385" alt="img"
Remove the last recorded directory and use the previous recorded directory as the working directory
References 6.8.1 Directory Stack Builtins
Author Dong Chen
LastMod Tue Feb 19 2019