mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 15:11:51 +00:00
Lunatic: in fs.listpath() use FIND_NOCURDIR. Also document that function.
git-svn-id: https://svn.eduke32.com/eduke32@4189 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
2a43511c70
commit
1542596290
2 changed files with 69 additions and 12 deletions
|
@ -1598,12 +1598,12 @@ Since the vector types are compound objects, they are always passed around by
|
|||
reference. For example, consider executing
|
||||
[source]
|
||||
----------
|
||||
v = xmath.vec3(0, 1)
|
||||
v = xmath.vec3(0, 10)
|
||||
w = v
|
||||
w.y = 2
|
||||
w.y = 20
|
||||
----------
|
||||
After this code, the expression `v.x` yields `2` instead of `v`'s initial value
|
||||
`1`.
|
||||
After this code, the expression `v.y` yields 20 instead of the initial value
|
||||
10.
|
||||
|
||||
===== Operations for `vec3` and `ivec3`
|
||||
|
||||
|
@ -1953,12 +1953,57 @@ Returns the index of the spawned sprite on success.
|
|||
The `fs` module -- virtual file system facilities
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
[red]*DRAFT*
|
||||
|
||||
[float]
|
||||
==== `files = fs.listpath(path, mask)`
|
||||
|
||||
Lists file names matching a wildcard `mask` which can be found under `path`.
|
||||
Returns a sequence table `files` of file names that can be found in a directory
|
||||
constructed as concatenation of any directory in the search path with `path`,
|
||||
and matching the wildcard `mask`. Currently, neither ZIP nor GRP files
|
||||
registered as file containers with EDuke32 are searched.
|
||||
|
||||
The `path` argument must separate directories by forward slashes (`/`). If no
|
||||
suffix is desired (i.e. the directories in the search path themselves are to be
|
||||
searched), `'/'` should be passed.
|
||||
|
||||
The file name `mask` is applied case-insensitively for the 26 characters of the
|
||||
basic Latin alphabet. It may contain the following meta-characters which are
|
||||
interpreted in a special way:
|
||||
|
||||
* a `*` matches any (potentially empty) sequence of characters
|
||||
* a `?` matches any single character
|
||||
|
||||
While the match with `mask` proceeds case-insensitively, file names are
|
||||
returned named exactly like on the file system. However, names differing only
|
||||
in case appear exactly once in the output list.
|
||||
|
||||
NOTE: For portability, it is crucial that `path` is specified with the same
|
||||
case as the actual directory on the file system.
|
||||
|
||||
.Example
|
||||
|
||||
Suppose the search path contains two directories `foo` and `bar` with the
|
||||
following file listing:
|
||||
----------
|
||||
foo/
|
||||
myhouse1.MAP
|
||||
myhouse2.map
|
||||
|
||||
bar/
|
||||
MYHOUSE1.map
|
||||
MYHOUSE10.MAP
|
||||
README.txt
|
||||
----------
|
||||
|
||||
Then a query with
|
||||
[source]
|
||||
----------
|
||||
fs.listpath("/", "myhouse?.map")
|
||||
----------
|
||||
will return a table with
|
||||
these strings:
|
||||
|
||||
* `myhouse1.MAP` or `MYHOUSE1.map`, but not both
|
||||
* `myhouse2.map`
|
||||
|
||||
|
||||
/////////////////
|
||||
|
|
|
@ -33,6 +33,7 @@ struct {
|
|||
static const int FIND_FILE = 1;
|
||||
static const int FIND_DIR = 2;
|
||||
static const int FIND_DRIVE = 4;
|
||||
static const int FIND_NOCURDIR = 8;
|
||||
|
||||
static const int OPT_NOSTACK = 0x100;
|
||||
|
||||
|
@ -49,22 +50,33 @@ struct {
|
|||
-- TODO: filter by 'source' (path, zip and/or grp)
|
||||
-- TODO: directories too, so that one can list them recursively, for example
|
||||
function fs.listpath(path, mask)
|
||||
if (path ~= nil and type(path)~="string") then
|
||||
error("Invalid argument #1: must be nil or a string", 2)
|
||||
if (type(path)~="string") then
|
||||
-- TODO: maybe also allow nil
|
||||
error("Invalid argument #1: must be a string", 2)
|
||||
end
|
||||
|
||||
if (type(mask) ~= "string") then
|
||||
error("Invalid argument #2: must be a string", 2)
|
||||
end
|
||||
|
||||
-- Normalization, for portability's sake
|
||||
|
||||
if (path:find("\\")) then
|
||||
error("Invalid argument #1: must not contain backslashes", 2)
|
||||
end
|
||||
|
||||
if (mask:find("[\\/]")) then
|
||||
error("Invalid argument #2: must not contain back or forward slashes", 2)
|
||||
end
|
||||
|
||||
local opsm = C.pathsearchmode
|
||||
C.pathsearchmode = 0
|
||||
local rootrec = C.klistpath(path, mask, CACHE1D.FIND_FILE)
|
||||
local rootrec = C.klistpath(path, mask, CACHE1D.FIND_FILE + CACHE1D.FIND_NOCURDIR)
|
||||
C.pathsearchmode = opsm
|
||||
|
||||
if (rootrec == nil) then
|
||||
-- TODO: discern?
|
||||
error("out of memory or failed listing path")
|
||||
-- XXX: may have failed hard or just no matching files
|
||||
return {}
|
||||
end
|
||||
|
||||
local files = {}
|
||||
|
|
Loading…
Reference in a new issue