summaryrefslogtreecommitdiffstats
path: root/acf/path.lua
blob: 9b709e9b901b1547403bff489a64347d892568c0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
--[[
Copyright (c) 2012 Kaarle Ritvanen
See LICENSE file for license details
--]]

module(..., package.seeall)

require 'stringy'

local function filter(func, tbl)
   local res = {}
   for k, v in pairs(tbl) do if func(v) then res[k] = v end end
   return res
end


function is_absolute(path)
   return string.sub(path, 1, 1) == '/'
end

function to_absolute(path, base)
   if not is_absolute(path) then
      path = base..(base ~= '/' and '/' or '')..path
   end
   local comps = split(path)
   local i = 1
   while i <= #comps do
      if comps[i] == '..' then
	 if i == 1 then error('Invalid path: '..path) end
	 table.remove(comps, i - 1)
	 table.remove(comps, i - 1)
	 i = i - 1
      else i = i + 1 end
   end
   return '/'..table.concat(comps, '/')
end

function join(p1, p2, ...)
   if not p2 then return p1 end
   if not is_absolute(p2) then p2 = '/'..p2 end
   return join((p1 == '/' and '' or p1)..p2, unpack(arg))
end

function split(path)
   -- assume absolute paths
   assert(is_absolute(path))
   if path == '/' then return {} end
   return filter(function(s) return s > '' end,
		 stringy.split(string.sub(path, 2, -1), '/'))
end

function parent(path)
   local comps = split(path)
   table.remove(comps)
   return join('/', unpack(comps))
end

function name(path)
   local comps = split(path)
   return comps[#comps]
end