summaryrefslogtreecommitdiffstats
path: root/DOCS
diff options
context:
space:
mode:
authorTSaaristo <tero.saaristo@gmail.com>2017-12-11 23:04:51 +0200
committerJan Ekström <jeebjp@gmail.com>2017-12-13 21:55:28 +0200
commit522bfe5be1212f356acbbd7d566092f8bd8d0748 (patch)
tree4e0992a9f092e9794c00290bd85f0aa8af30e8c0 /DOCS
parent47131365a323914d667ba23d50474717f88cd81c (diff)
downloadmpv-522bfe5be1212f356acbbd7d566092f8bd8d0748.tar.bz2
mpv-522bfe5be1212f356acbbd7d566092f8bd8d0748.tar.xz
lua+js: implement utils.file_info()
This commit introduces mp.utils.file_info() for querying information on file paths, implemented for both Lua and Javascript. The function takes a file path as an argument and returns a Lua table / JS object upon success. The table/object will contain the values: mode, size, atime, mtime, ctime and the convenience booleans is_file, is_dir. On error, the Lua side will return `nil, error` and the Javascript side will return `undefined` (and mark the last error). This feature utilizes the already existing cross-platform `mp_stat()` function.
Diffstat (limited to 'DOCS')
-rw-r--r--DOCS/man/javascript.rst2
-rw-r--r--DOCS/man/lua.rst28
2 files changed, 30 insertions, 0 deletions
diff --git a/DOCS/man/javascript.rst b/DOCS/man/javascript.rst
index 995899d07b..419f473e2c 100644
--- a/DOCS/man/javascript.rst
+++ b/DOCS/man/javascript.rst
@@ -168,6 +168,8 @@ Otherwise, where the Lua APIs return ``nil`` on error, JS returns ``undefined``.
``mp.utils.readdir(path [, filter])`` (LE)
+``mp.utils.file_info(path)`` (LE)
+
``mp.utils.split_path(path)``
``mp.utils.join_path(p1, p2)``
diff --git a/DOCS/man/lua.rst b/DOCS/man/lua.rst
index 831981db06..5fe7507049 100644
--- a/DOCS/man/lua.rst
+++ b/DOCS/man/lua.rst
@@ -591,6 +591,34 @@ strictly part of the guaranteed API.
On error, ``nil, error`` is returned.
+``utils.file_info(path)``
+ Stats the given path for information and returns a table with the
+ following entries:
+
+ ``mode``
+ protection bits (on Windows, always 755 (octal) for directories
+ and 644 (octal) for files)
+ ``size``
+ size in bytes
+ ``atime``
+ time of last access
+ ``mtime``
+ time of last modification
+ ``ctime``
+ time of last metadata change (Linux) / time of creation (Windows)
+ ``is_file``
+ Whether ``path`` is a regular file (boolean)
+ ``is_dir``
+ Whether ``path`` is a directory (boolean)
+
+ ``mode`` and ``size`` are integers.
+ Timestamps (``atime``, ``mtime`` and ``ctime``) are integer seconds since
+ the Unix epoch (Unix time).
+ The booleans ``is_file`` and ``is_dir`` are provided as a convenience;
+ they can be and are derived from ``mode``.
+
+ On error (eg. path does not exist), ``nil, error`` is returned.
+
``utils.split_path(path)``
Split a path into directory component and filename component, and return
them. The first return value is always the directory. The second return