๐ io
io::cat
Print the content of a file to stdout. This is a pure bash equivalent of cat.
- $1: path as string: the file to print
io::cat "myFile"
Also see log::printFile if you want to print a file for a user.
io::checkAndFail
Check last return code and fail (exit) if it is an error.
- $1: exit code as int: the return code
- $@: message as string: the error message to display in case of error
command_that_could_fail || io::checkAndFail "$?" "The command that could fail has failed!"
io::checkAndWarn
Check last return code and warn the user in case the return code is not 0.
- $1: exit code as int: the last return code
- $@: message as string: the warning message to display in case of error
command_that_could_fail || io::checkAndWarn "$?" "The command that could fail has failed!"
io::cleanupTempFiles
Removes all the temporary files and directories that were created by the io::createTempFile and io::createTempDirectory functions.
io::cleanupTempFiles
shellcheck disable=SC2016
io::convertFromWindowsPath
Convert a Windows path to a unix path.
- $1: path as string: the path to convert
Returns:
RETURNED_VALUE
: The unix path.
io::convertFromWindowsPath "C:\path\to\file"
Handles paths starting with
X:\
.
io::convertToWindowsPath
Convert a unix path to a Windows path.
- $1: path as string: the path to convert
Returns:
RETURNED_VALUE
: The Windows path.
io::convertToWindowsPath "/path/to/file"
Handles paths starting with
/mnt/x/
or/x/
.
io::countArgs
Returns the number of arguments passed.
A convenient function that can be used to:
count the files/directories in a directory
io::countArgs "${PWD}"/* && local numberOfFiles="${RETURNED_VALUE}"
count the number of variables starting with VALET_
io::countArgs "${!VALET_@}" && local numberOfVariables="${RETURNED_VALUE}"
$@: arguments as any: the arguments to count
Returns:
RETURNED_VALUE
: The number of arguments passed.
io::countArgs 1 2 3
io::createDirectoryIfNeeded
Create the directory tree if needed.
- $1: path as string: The directory path to create.
Returns:
RETURNED_VALUE
: The absolute path to the directory.
io::createDirectoryIfNeeded "/my/directory"
io::createFilePathIfNeeded
Make sure that the given file path exists. Create the directory tree and the file if needed.
- $1: path as string: the file path to create
Returns:
RETURNED_VALUE
: The absolute path of the file.
io::createFilePathIfNeeded "myFile"
io::createLink
Create a soft or hard link (original โ link).
Reminder:
- A soft (symbolic) link is a new file that contains a reference to another file or directory in the form of an absolute or relative path.
- A hard link is a directory entry that associates a new pathname with an existing file (inode + data block) on a file system.
This function allows to create a symbolic link on Windows as well as on Unix.
- $1: linked path as string: the path to link to (the original file)
- $2: link path as string: the path where to create the link
- $3: hard link as boolean: (optional) true to create a hard link, false to create a symbolic link (defaults to false)
- $4: force as boolean: (optional) true to overwrite the link or file if it already exists. Otherwise, the function will fail on an existing link. (defaults to true)
io::createLink "/path/to/link" "/path/to/linked"
io::createLink "/path/to/link" "/path/to/linked" true
On unix, the function uses the
ln
command. On Windows, the function usespowershell
(and optionally ls to check the existing link).
io::createTempDirectory
Creates a temporary directory.
Returns:
RETURNED_VALUE
: The created path.
io::createTempDirectory
local directory="${RETURNED_VALUE}"
Directories created this way are automatically cleaned up by the io::cleanupTempFiles function when valet ends.
io::createTempFile
Creates a temporary file and return its path.
Returns:
RETURNED_VALUE
: The created path.
io::createTempFile
local file="${RETURNED_VALUE}"
Files created this way are automatically cleaned up by the io::cleanupTempFiles function when valet ends.
io::invoke
This function call an executable and its arguments. If the execution fails, it will fail the script and show the std/err output. Otherwise it hides both streams, effectively rendering the execution silent unless it fails.
It redirects the stdout and stderr to environment variables. Equivalent to io::invoke5 true 0 ’’ ’’ “${@}”
- $1: executable as string: the executable or command
- $@: arguments as any: the command and its arguments
Returns:
- $?: The exit code of the executable.
RETURNED_VALUE
: The content of stdout.RETURNED_VALUE2
: The content of stderr.
io::invoke git add --all
See io::invokef5 for more information.
io::invoke2
This function call an executable and its arguments. It redirects the stdout and stderr to environment variables. Equivalent to io::invoke5 “${1}” 0 "" "" “${@:2}”
- $1: fail as bool: true/false to indicate if the function should fail in case the execution fails. If true and the execution fails, the script will exit.
- $2: executable as string: the executable or function to execute
- $@: arguments as any: the arguments to pass to the executable
Returns:
- $?: The exit code of the executable.
RETURNED_VALUE
: The content of stdout.RETURNED_VALUE2
: The content of stderr.
io::invokef2 false git status || core::fail "status failed."
stdout="${RETURNED_VALUE}"
stderr="${RETURNED_VALUE2}"
See io::invokef5 for more information.
io::invoke2piped
This function call an executable and its arguments and input a given string as stdin. It redirects the stdout and stderr to environment variables. Equivalent to io::invoke5 “${1}” 0 false “${2}” “${@:3}”
- $1: fail as bool: true/false to indicate if the function should fail in case the execution fails. If true and the execution fails, the script will exit.
- $2: stdin as string: the stdin to pass to the executable
- $3: executable as string: the executable or function to execute
- $@: arguments as any: the arguments to pass to the executable
Returns:
- $?: The exit code of the executable.
RETURNED_VALUE
: The content of stdout.RETURNED_VALUE2
: The content of stderr.
io::invoke2piped true "key: val" yq -o json -p yaml -
stdout="${RETURNED_VALUE}"
stderr="${RETURNED_VALUE2}"
This is the equivalent of:
myvar="$(printf '%s\n' "mystring" | mycommand)"
But without using a subshell.See io::invokef5 for more information.
io::invokef2
This function call an executable and its arguments. It redirects the stdout and stderr to temporary files. Equivalent to io::invokef5 “${1}” 0 "" "" “${@:2}”
- $1: fail as bool: true/false to indicate if the function should fail in case the execution fails. If true and the execution fails, the script will exit.
- $2: executable as string: the executable or function to execute
- $@: arguments as any: the arguments to pass to the executable
Returns:
- $?: The exit code of the executable.
RETURNED_VALUE
: The file path containing the stdout of the executable.RETURNED_VALUE2
: The file path containing the stderr of the executable.
io::invokef2 false git status || core::fail "status failed."
stdoutFilePath="${RETURNED_VALUE}"
stderrFilePath="${RETURNED_VALUE2}"
See io::invokef5 for more information.
io::invokef2piped
This function call an executable and its arguments and input a given string as stdin. It redirects the stdout and stderr to temporary files. Equivalent to io::invokef5 “${1}” 0 false “${2}” “${@:3}”
- $1: fail as bool: true/false to indicate if the function should fail in case the execution fails. If true and the execution fails, the script will exit.
- $2: stdin as string: the stdin to pass to the executable
- $3: executable as string: the executable or function to execute
- $@: arguments as any: the arguments to pass to the executable
Returns:
- $?: The exit code of the executable.
RETURNED_VALUE
: The file path containing the stdout of the executable.RETURNED_VALUE2
: The file path containing the stderr of the executable.
io::invokef2piped true "key: val" yq -o json -p yaml -
stdoutFilePath="${RETURNED_VALUE}"
stderrFilePath="${RETURNED_VALUE2}"
This is the equivalent of:
myvar="$(printf '%s\n' "mystring" | mycommand)"
But without using a subshell.See io::invokef5 for more information.
io::invokef5
This function call an executable and its arguments. It redirects the stdout and stderr to temporary files.
- $1: fail as bool: true/false to indicate if the function should fail in case the execution fails. If true and the execution fails, the script will exit.
- $2: acceptable codes as string: the acceptable error codes, comma separated (if the error code is matched, then set the output error code to 0)
- $3: fail as bool: true/false to indicate if the 4th argument represents a file path or directly the content for stdin
- $4: sdtin as string: the stdin (can be empty)
- $5: executable as string: the executable or function to execute
- $@: arguments as any: the arguments to pass to the executable
Returns:
- $?: The exit code of the executable.
RETURNED_VALUE
: The file path containing the stdout of the executable.RETURNED_VALUE2
: The file path containing the stderr of the executable.
io::invokef5 "false" "130,2" "false" "This is the stdin" "stuff" "--height=10" || core::fail "stuff failed."
stdoutFilePath="${RETURNED_VALUE}"
stderrFilePath="${RETURNED_VALUE2}"
- In windows, this is tremendously faster to do (or any other invoke flavor):
io::invokef5 false 0 false '' mycommand && myvar="${RETURNED_VALUE}"
than doing:myvar="$(mycommand)".
- On linux, it is slightly faster (but it might be slower if you don’t have SSD?).
- On linux, you can use a tmpfs directory for massive gains over subshells.
io::isDirectoryWritable
Check if the directory is writable. Creates the directory if it does not exist.
- $1: directory as string: the directory to check
- $2: test file name as string: (optional) the name of the file to create in the directory to test the write access
Returns:
- $?:
- 0 if the directory is writable
- 1 otherwise
if io::isDirectoryWritable "/path/to/directory"; then
echo "The directory is writable."
fi
io::listDirectories
List all the directories in the given directory.
- $1: directory as string: the directory to list
- $2: recursive as bool: (optional) true to list recursively, false otherwise (defaults to false)
- $3: hidden as bool: (optional) true to list hidden paths, false otherwise (defaults to false)
- $4: directory filter function name as string: (optional) a function name that is called to filter the sub directories (for recursive listing) The function should return 0 if the path is to be kept, 1 otherwise. The function is called with the path as the first argument. (defaults to empty string, no filter)
Returns:
RETURNED_ARRAY
: An array with the list of all the files.
io::listDirectories "/path/to/directory" true true myFilterFunction
for path in "${RETURNED_ARRAY[@]}"; do
printf '%s' "${path}"
done
io::listFiles
List all the files in the given directory.
- $1: directory as string: the directory to list
- $2: recursive as bool: (optional) true to list recursively, false otherwise (defaults to false)
- $3: hidden as bool: (optional) true to list hidden paths, false otherwise (defaults to false)
- $4: directory filter function name as string: (optional) a function name that is called to filter the directories (for recursive listing) The function should return 0 if the path is to be kept, 1 otherwise. The function is called with the path as the first argument. (defaults to empty string, no filter)
Returns:
RETURNED_ARRAY
: An array with the list of all the files.
io::listFiles "/path/to/directory" true true myFilterFunction
for path in "${RETURNED_ARRAY[@]}"; do
printf '%s' "${path}"
done
io::listPaths
List all the paths in the given directory.
- $1: directory as string: the directory to list
- $2: recursive as bool: (optional) true to list recursively, false otherwise (defaults to false)
- $3: hidden as bool: (optional) true to list hidden paths, false otherwise (defaults to false)
- $4: path filter function name as string: (optional) a function name that is called to filter the paths that will be listed The function should return 0 if the path is to be kept, 1 otherwise. The function is called with the path as the first argument. (defaults to empty string, no filter)
- $5: directory filter function name as string: (optional) a function name that is called to filter the directories (for recursive listing) The function should return 0 if the path is to be kept, 1 otherwise. The function is called with the path as the first argument. (defaults to empty string, no filter)
Returns:
RETURNED_ARRAY
: An array with the list of all the paths.
io::listPaths "/path/to/directory" true true myFilterFunction myFilterDirectoryFunction
for path in "${RETURNED_ARRAY[@]}"; do
printf '%s' "${path}"
done
- It will correctly list files under symbolic link directories.
io::readFile
Reads the content of a file and returns it in the global variable RETURNED_VALUE. Uses pure bash.
- $1: path as string: the file path to read
- $2: max char as int: (optional) the maximum number of characters to read (defaults to 0, which means read the whole file)
If the file does not exist, the function will return an empty string instead of failing.
Returns:
RETURNED_VALUE
: The content of the file.
io::readFile "/path/to/file" && local fileContent="${RETURNED_VALUE}"
io::readFile "/path/to/file" 500 && local fileContent="${RETURNED_VALUE}"
io::readStdIn
Read the content of the standard input. Will immediately return if the standard input is empty.
Returns:
RETURNED_VALUE
: The content of the standard input.
io::readStdIn && local stdIn="${RETURNED_VALUE}"
io::sleep
Sleep for the given amount of time. This is a pure bash replacement of sleep.
- $1: time as float: the time to sleep in seconds (can be a float)
io:sleep 1.5
The sleep command is not a built-in command in bash, but a separate executable. When you use sleep, you are creating a new process.
io::toAbsolutePath
This function returns the absolute path of a path.
- $1: path as string: The path to translate to absolute path.
Returns:
RETURNED_VALUE
: The absolute path of the path.
io::toAbsolutePath "myFile"
local myFileAbsolutePath="${RETURNED_VALUE}"
This is a pure bash alternative to
realpath
orreadlink
.
io::windowsCreateTempDirectory
Create a temporary directory on Windows and return the path both for Windows and Unix.
This is useful for creating temporary directories that can be used in both Windows and Unix.
Returns:
RETURNED_VALUE
: The Windows path.RETURNED_VALUE2
: The Unix path.
io::windowsCreateTempDirectory
Directories created this way are automatically cleaned up by the io::cleanupTempFiles function when valet ends.
io::windowsCreateTempFile
Create a temporary file on Windows and return the path both for Windows and Unix.
This is useful for creating temporary files that can be used in both Windows and Unix.
Returns:
RETURNED_VALUE
: The Windows path.RETURNED_VALUE2
: The Unix path.
io::windowsCreateTempFile
Files created this way are automatically cleaned up by the io::cleanupTempFiles function when valet ends.
io::windowsPowershellBatchEnd
This function will run all the commands that were batched with io::windowsPowershellBatchStart
.
Returns:
- $?
- 0 if the command was successful
- 1 otherwise.
RETURNED_VALUE
: The content of stdout.RETURNED_VALUE2
: The content of stderr.
io::windowsPowershellBatchStart
io::windowsRunInPowershell "Write-Host \"Hello\""
io::windowsRunInPowershell "Write-Host \"World\""
io::windowsPowershellBatchEnd
io::windowsPowershellBatchStart
After running this function, all commands that should be executed by
io::windowsRunInPowershell
will be added to a batch that will only be played
when io::windowsPowershellBatchEnd
is called.
This is a convenient way to run multiple commands in a single PowerShell session. It makes up for the fact that running a new PowerShell session for each command is slow.
io::windowsPowershellBatchStart
io::windowsRunInPowershell "Write-Host \"Hello\""
io::windowsRunInPowershell "Write-Host \"World\""
io::windowsPowershellBatchEnd
io::windowsRunInPowershell
Runs a PowerShell command. This is mostly useful on Windows.
- $1: command as string: the command to run.
- $2: run as administrator as boolean: (optional) whether to run the command as administrator. (defaults to false).
Returns:
- $?
- 0 if the command was successful
- 1 otherwise.
RETURNED_VALUE
: The content of stdout.RETURNED_VALUE2
: The content of stderr.
io::windowsRunInPowershell "Write-Host \"Press any key:\"; Write-Host -Object ('The key that was pressed was: {0}' -f [System.Console]::ReadKey().Key.ToString());"
Documentation generated for the version 0.27.285 (2024-12-05).