Janet 1.34.0-f92f3eb Documentation
(Other Versions:
          
          1.31.0
          
          1.29.1
          
          1.28.0
          
          1.27.0
          
          1.26.0
          
          1.25.1
          
          1.24.0
          
          1.23.0
          
          1.22.0
          
          1.21.0
          
          1.20.0
          
          1.19.0
          
          1.18.1
          
          1.17.1
          
          1.16.1
          
          1.15.0
          
          1.13.1
          
          1.12.2
          
          1.11.1
          
          1.10.1
          
          1.9.1
          
          1.8.1
          
          1.7.0
          
          1.6.0
          
          1.5.1
          
          1.5.0
          
          1.4.0
          
          1.3.1
          )
        OS Module
The os module contains most Operating System specific functionality as well as routines
for interacting with the host OS. There is also some functionality for interacting with the
file system. The functionality in this module can be much reduced by setting the JANET_REDUCED_OS
define in janetconf.h.
Index
os/arch os/cd os/chmod os/clock os/compiler os/cpu-count os/cryptorand os/cwd os/date os/dir os/environ os/execute os/exit os/getenv os/isatty os/link os/lstat os/mkdir os/mktime os/open os/perm-int os/perm-string os/pipe os/posix-exec os/posix-fork os/proc-close os/proc-kill os/proc-wait os/readlink os/realpath os/rename os/rm os/rmdir os/setenv os/shell os/sigaction os/sleep os/spawn os/stat os/strftime os/symlink os/time os/touch os/umask os/which
(os/arch) Check the ISA that janet was compiled for. Returns one of: * :x86 * :x64 * :arm * :aarch64 * :riscv32 * :riscv64 * :sparc * :wasm * :unknownCommunity Examples
(os/cd path) Change current directory to path. Returns nil on success, errors on failure.Community Examples
(os/chmod path mode) Change file permissions, where `mode` is a permission string as returned by `os/perm-string`, or an integer as returned by `os/perm-int`. When `mode` is an integer, it is interpreted as a Unix permission value, best specified in octal, like 8r666 or 8r400. Windows will not differentiate between user, group, and other permissions, and thus will combine all of these permissions. Returns nil.Community Examples
(os/clock &opt source format) Return the current time of the requested clock source. The `source` argument selects the clock source to use, when not specified the default is `:realtime`: - :realtime: Return the real (i.e., wall-clock) time. This clock is affected by discontinuous jumps in the system time - :monotonic: Return the number of whole + fractional seconds since some fixed point in time. The clock is guaranteed to be non-decreasing in real time. - :cputime: Return the CPU time consumed by this process (i.e. all threads in the process) The `format` argument selects the type of output, when not specified the default is `:double`: - :double: Return the number of seconds + fractional seconds as a double - :int: Return the number of seconds as an integer - :tuple: Return a 2 integer tuple [seconds, nanoseconds]Community Examples
(os/compiler) Get the compiler used to compile the interpreter. Returns one of: * :gcc * :clang * :msvc * :unknownCommunity Examples
(os/cpu-count &opt dflt) Get an approximate number of CPUs available on for this process to use. If unable to get an approximation, will return a default value dflt.Community Examples
(os/cryptorand n &opt buf) Get or append `n` bytes of good quality random data provided by the OS. Returns a new buffer or `buf`.Community Examples
(os/date &opt time local) Returns the given time as a date struct, or the current time if `time` is not given. Returns a struct with following key values. Note that all numbers are 0-indexed. Date is given in UTC unless `local` is truthy, in which case the date is formatted for the local timezone. * :seconds - number of seconds [0-61] * :minutes - number of minutes [0-59] * :hours - number of hours [0-23] * :month-day - day of month [0-30] * :month - month of year [0, 11] * :year - years since year 0 (e.g. 2019) * :week-day - day of the week [0-6] * :year-day - day of the year [0-365] * :dst - if Day Light Savings is in effectCommunity Examples
(os/dir dir &opt array) Iterate over files and subdirectories in a directory. Returns an array of paths parts, with only the file name or directory name and no prefix.Community Examples
(os/execute args &opt flags env) Execute a program on the system and pass it string arguments. `flags` is a keyword that modifies how the program will execute. * :e - enables passing an environment to the program. Without :e, the current environment is inherited. * :p - allows searching the current PATH for the binary to execute. Without this flag, binaries must use absolute paths. * :x - raise error if exit code is non-zero. * :d - Don't try and terminate the process on garbage collection (allow spawning zombies). `env` is a table or struct mapping environment variables to values. It can also contain the keys :in, :out, and :err, which allow redirecting stdio in the subprocess. :in, :out, and :err should be core/file values or core/stream values. core/file values and core/stream values passed to :in, :out, and :err should be closed manually because os/execute doesn't close them. Returns the exit code of the program.Community Examples
(os/exit &opt x force) Exit from janet with an exit code equal to x. If x is not an integer, the exit with status equal the hash of x. If `force` is truthy will exit immediately and skip cleanup code.Community Examples
(os/getenv variable &opt dflt) Get the string value of an environment variable.Community Examples
(os/isatty &opt file) Returns true if `file` is a terminal. If `file` is not specified, it will default to standard output.Community Examples
(os/link oldpath newpath &opt symlink) Create a link at newpath that points to oldpath and returns nil. Iff symlink is truthy, creates a symlink. Iff symlink is falsey or not provided, creates a hard link. Does not work on Windows.Community Examples
(os/lstat path &opt tab|key) Like os/stat, but don't follow symlinks.Community Examples
(os/mkdir path) Create a new directory. The path will be relative to the current directory if relative, otherwise it will be an absolute path. Returns true if the directory was created, false if the directory already exists, and errors otherwise.Community Examples
(os/mktime date-struct &opt local) Get the broken down date-struct time expressed as the number of seconds since January 1, 1970, the Unix epoch. Returns a real number. Date is given in UTC unless `local` is truthy, in which case the date is computed for the local timezone. Inverse function to os/date.Community Examples
(os/open path &opt flags mode) Create a stream from a file, like the POSIX open system call. Returns a new stream. `mode` should be a file mode as passed to `os/chmod`, but only if the create flag is given. The default mode is 8r666. Allowed flags are as follows: * :r - open this file for reading * :w - open this file for writing * :c - create a new file (O\_CREATE) * :e - fail if the file exists (O\_EXCL) * :t - shorten an existing file to length 0 (O\_TRUNC) Posix-only flags: * :a - append to a file (O\_APPEND) * :x - O\_SYNC * :C - O\_NOCTTY Windows-only flags: * :R - share reads (FILE\_SHARE\_READ) * :W - share writes (FILE\_SHARE\_WRITE) * :D - share deletes (FILE\_SHARE\_DELETE) * :H - FILE\_ATTRIBUTE\_HIDDEN * :O - FILE\_ATTRIBUTE\_READONLY * :F - FILE\_ATTRIBUTE\_OFFLINE * :T - FILE\_ATTRIBUTE\_TEMPORARY * :d - FILE\_FLAG\_DELETE\_ON\_CLOSE * :b - FILE\_FLAG\_NO\_BUFFERINGCommunity Examples
(os/perm-int bytes) Parse a 9-character permission string and return an integer that can be used by chmod.Community Examples
(os/perm-string int) Convert a Unix octal permission value from a permission integer as returned by `os/stat` to a human readable string, that follows the formatting of Unix tools like `ls`. Returns the string as a 9-character string of r, w, x and - characters. Does not include the file/directory/symlink character as rendered by `ls`.Community Examples
(os/pipe) Create a readable stream and a writable stream that are connected. Returns a two-element tuple where the first element is a readable stream and the second element is the writable stream.Community Examples
(os/posix-exec args &opt flags env) Use the execvpe or execve system calls to replace the current process with an interface similar to os/execute. Hoever, instead of creating a subprocess, the current process is replaced. Is not supported on windows, and does not allow redirection of stdio.Community Examples
(os/posix-fork) Make a `fork` system call and create a new process. Return nil if in the new process, otherwise a core/process object (as returned by os/spawn). Not supported on all systems (POSIX only).Community Examples
(os/proc-close proc) Close pipes created by `os/spawn` if they have not been closed. Then, if os/proc-wait was not already called on proc, os/proc-wait is called on it, and it returns the exit code returned by os/proc-wait. Otherwise, returns nil.Community Examples
(os/proc-kill proc &opt wait signal) Kill a subprocess by sending SIGKILL to it on posix systems, or by closing the process handle on windows. If os/proc-wait already finished for proc, os/proc-kill raises an error. After sending signal to proc, if `wait` is truthy, will wait for the process to finish and return the exit code by calling os/proc-wait. Otherwise, returns `proc`. If signal is specified, send it instead. Signal keywords are named after their C counterparts but in lowercase with the leading `SIG` stripped. Signals are ignored on windows.Community Examples
(os/proc-wait proc) Suspend the current fiber until the subprocess completes. Returns the subprocess return code. os/proc-wait cannot be called twice on the same process. If `ev/with-deadline` cancels `os/proc-wait` with an error or os/proc-wait is cancelled with any error caused by anything else, os/proc-wait still finishes in the background. Only after os/proc-wait finishes, a process is cleaned up by the operating system. Thus, a process becomes a zombie process if os/proc-wait is not called.Community Examples
(os/readlink path) Read the contents of a symbolic link. Does not work on Windows.Community Examples
(os/realpath path) Get the absolute path for a given path, following ../, ./, and symlinks. Returns an absolute path as a string.Community Examples
(os/rename oldname newname) Rename a file on disk to a new path. Returns nil.Community Examples
(os/rmdir path) Delete a directory. The directory must be empty to succeed.Community Examples
(os/setenv variable value) Set an environment variable.Community Examples
(os/shell str) Pass a command string str directly to the system shell.Community Examples
(os/sigaction which &opt handler interrupt-interpreter) Add a signal handler for a given action. Use nil for the `handler` argument to remove a signal handler. All signal handlers are the same as supported by `os/proc-kill`.Community Examples
(os/sleep n) Suspend the program for `n` seconds. `n` can be a real number. Returns nil.Community Examples
(os/spawn args &opt flags env) Execute a program on the system and return a handle to the process. Otherwise, takes the same arguments as `os/execute`. Does not wait for the process. For each of the :in, :out, and :err keys of the `env` argument, one can also pass in the keyword `:pipe` to get streams for standard IO of the subprocess that can be read from and written to. The returned value `proc` has the fields :in, :out, :err, and the additional field :pid on unix-like platforms. `(os/proc-wait proc)` must be called to rejoin the subprocess. After `(os/proc-wait proc)` finishes, proc gains a new field, :return-code. If :x flag is passed to os/spawn, non-zero exit code will cause os/proc-wait to raise an error. If pipe streams created with :pipe keyword are not closed in time, janet can run out of file descriptors. They can be closed individually, or `os/proc-close` can close all pipe streams on proc. If pipe streams aren't read before `os/proc-wait` finishes, then pipe buffers become full, and the process cannot finish because the process cannot print more on pipe buffers which are already full. If the process cannot finish, os/proc-wait cannot finish, either.Community Examples
(os/stat path &opt tab|key) Gets information about a file or directory. Returns a table if the second argument is a keyword, returns only that information from stat. If the file or directory does not exist, returns nil. The keys are: * :dev - the device that the file is on * :mode - the type of file, one of :file, :directory, :block, :character, :fifo, :socket, :link, or :other * :int-permissions - A Unix permission integer like 8r744 * :permissions - A Unix permission string like "rwxr--r--" * :uid - File uid * :gid - File gid * :nlink - number of links to file * :rdev - Real device of file. 0 on Windows * :size - size of file in bytes * :blocks - number of blocks in file. 0 on Windows * :blocksize - size of blocks in file. 0 on Windows * :accessed - timestamp when file last accessed * :changed - timestamp when file last changed (permissions changed) * :modified - timestamp when file last modified (content changed)Community Examples
(os/strftime fmt &opt time local) Format the given time as a string, or the current time if `time` is not given. The time is formatted according to the same rules as the ISO C89 function strftime(). The time is formatted in UTC unless `local` is truthy, in which case the date is formatted for the local timezone.Community Examples
(os/symlink oldpath newpath) Create a symlink from oldpath to newpath, returning nil. Same as `(os/link oldpath newpath true)`.Community Examples
(os/time) Get the current time expressed as the number of whole seconds since January 1, 1970, the Unix epoch. Returns a real number.Community Examples
(os/touch path &opt actime modtime) Update the access time and modification times for a file. By default, sets times to the current time.Community Examples
(os/which) Check the current operating system. Returns one of: * :windows * :mingw * :cygwin * :macos * :web - Web assembly (emscripten) * :linux * :freebsd * :openbsd * :netbsd * :dragonfly * :bsd * :posix - A POSIX compatible system (default) May also return a custom keyword specified at build time.Community Examples