squish.lua

Tue, 30 Nov 2010 13:18:47 +0000

author
Matthew Wild <mwild1@gmail.com>
date
Tue, 30 Nov 2010 13:18:47 +0000
changeset 81
44f2945d09cf
parent 80
b70f75414c81
child 82
4d6a976c3bb7
permissions
-rwxr-xr-x

squish.lua: Support for AutoFetch to use file:// URLs

0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
1 #!/usr/bin/env lua
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
2
80
b70f75414c81 squish.lua: Initialise LuaRocks if available
Matthew Wild <mwild1@gmail.com>
parents: 71
diff changeset
3 -- Initialise LuaRocks if present
b70f75414c81 squish.lua: Initialise LuaRocks if available
Matthew Wild <mwild1@gmail.com>
parents: 71
diff changeset
4 pcall(require, "luarocks.require");
b70f75414c81 squish.lua: Initialise LuaRocks if available
Matthew Wild <mwild1@gmail.com>
parents: 71
diff changeset
5
46
c09caa0317cc -g == --debug
Matthew Wild <mwild1@gmail.com>
parents: 41
diff changeset
6 local short_opts = { v = "verbose", vv = "very_verbose", o = "output", q = "quiet", qq = "very_quiet", g = "debug" }
16
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
7 local opts = { use_http = false };
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
8
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
9 for _, opt in ipairs(arg) do
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
10 if opt:match("^%-") then
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
11 local name = opt:match("^%-%-?([^%s=]+)()")
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
12 name = (short_opts[name] or name):gsub("%-+", "_");
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
13 if name:match("^no_") then
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
14 name = name:sub(4, -1);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
15 opts[name] = false;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
16 else
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
17 opts[name] = opt:match("=(.*)$") or true;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
18 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
19 else
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
20 base_path = opt;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
21 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
22 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
23
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
24 if opts.very_verbose then opts.verbose = true; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
25 if opts.very_quiet then opts.quiet = true; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
26
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
27 local noprint = function () end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
28 local print_err, print_info, print_verbose, print_debug = noprint, noprint, noprint, noprint;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
29
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
30 if not opts.very_quiet then print_err = print; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
31 if not opts.quiet then print_info = print; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
32 if opts.verbose or opts.very_verbose then print_verbose = print; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
33 if opts.very_verbose then print_debug = print; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
34
29
0737a3bcf10b Map print() to print_verbose()
Matthew Wild <mwild1@gmail.com>
parents: 28
diff changeset
35 print = print_verbose;
0737a3bcf10b Map print() to print_verbose()
Matthew Wild <mwild1@gmail.com>
parents: 28
diff changeset
36
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
37 local modules, main_files, resources = {}, {}, {};
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
38
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
39 -- Functions to be called from squishy file --
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
40
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
41 function Module(name)
37
cb8b48b08e1e Only add a module to the list once, no matter how many times it is added in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 34
diff changeset
42 if modules[name] then
cb8b48b08e1e Only add a module to the list once, no matter how many times it is added in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 34
diff changeset
43 print_verbose("Ignoring duplicate module definition for "..name);
cb8b48b08e1e Only add a module to the list once, no matter how many times it is added in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 34
diff changeset
44 return function () end
cb8b48b08e1e Only add a module to the list once, no matter how many times it is added in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 34
diff changeset
45 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
46 local i = #modules+1;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
47 modules[i] = { name = name, url = ___fetch_url };
37
cb8b48b08e1e Only add a module to the list once, no matter how many times it is added in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 34
diff changeset
48 modules[name] = modules[i];
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
49 return function (path)
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
50 modules[i].path = path;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
51 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
52 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
53
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
54 function Resource(name, path)
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
55 local i = #resources+1;
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
56 resources[i] = { name = name, path = path or name };
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
57 return function (path)
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
58 resources[i].path = path;
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
59 end
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
60 end
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
61
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
62 function AutoFetchURL(url)
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
63 ___fetch_url = url;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
64 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
65
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
66 function Main(fn)
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
67 table.insert(main_files, fn);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
68 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
69
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
70 function Output(fn)
55
feb7832393cd Don't let squishy file override the user's specified output file, if one
Matthew Wild <mwild1@gmail.com>
parents: 54
diff changeset
71 if opts.output == nil then
feb7832393cd Don't let squishy file override the user's specified output file, if one
Matthew Wild <mwild1@gmail.com>
parents: 54
diff changeset
72 out_fn = fn;
feb7832393cd Don't let squishy file override the user's specified output file, if one
Matthew Wild <mwild1@gmail.com>
parents: 54
diff changeset
73 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
74 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
75
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
76 function Option(name)
31
84b653f78e5f Rewrite '-' to '_' in Option command
Matthew Wild <mwild1@gmail.com>
parents: 29
diff changeset
77 name = name:gsub("%-", "_");
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
78 if opts[name] == nil then
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
79 opts[name] = true;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
80 return function (value)
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
81 opts[name] = value;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
82 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
83 else
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
84 return function () end;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
85 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
86 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
87
13
b93f52cbe253 Add GetOption function for squishy files
Matthew Wild <mwild1@gmail.com>
parents: 11
diff changeset
88 function GetOption(name)
b93f52cbe253 Add GetOption function for squishy files
Matthew Wild <mwild1@gmail.com>
parents: 11
diff changeset
89 return opts[name:gsub('%-', '_')];
b93f52cbe253 Add GetOption function for squishy files
Matthew Wild <mwild1@gmail.com>
parents: 11
diff changeset
90 end
b93f52cbe253 Add GetOption function for squishy files
Matthew Wild <mwild1@gmail.com>
parents: 11
diff changeset
91
23
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
92 function Message(message)
24
73ac55bcc19a Make Message and Error commands obey user's verbosity options
Matthew Wild <mwild1@gmail.com>
parents: 23
diff changeset
93 if not opts.quiet then
73ac55bcc19a Make Message and Error commands obey user's verbosity options
Matthew Wild <mwild1@gmail.com>
parents: 23
diff changeset
94 print_info(message);
73ac55bcc19a Make Message and Error commands obey user's verbosity options
Matthew Wild <mwild1@gmail.com>
parents: 23
diff changeset
95 end
23
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
96 end
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
97
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
98 function Error(message)
24
73ac55bcc19a Make Message and Error commands obey user's verbosity options
Matthew Wild <mwild1@gmail.com>
parents: 23
diff changeset
99 if not opts.very_quiet then
73ac55bcc19a Make Message and Error commands obey user's verbosity options
Matthew Wild <mwild1@gmail.com>
parents: 23
diff changeset
100 print_err(message);
73ac55bcc19a Make Message and Error commands obey user's verbosity options
Matthew Wild <mwild1@gmail.com>
parents: 23
diff changeset
101 end
23
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
102 end
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
103
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
104 function Exit()
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
105 os.exit(1);
e3b923ccadb1 Support for Message and Error in squishy files to show messages to the user, and Exit to halt squishing
Matthew Wild <mwild1@gmail.com>
parents: 22
diff changeset
106 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
107 -- -- -- -- -- -- -- --- -- -- -- -- -- -- -- --
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
108
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
109 base_path = (base_path or "."):gsub("/$", "").."/"
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
110 squishy_file = base_path .. "squishy";
25
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
111 out_fn = opts.output;
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
112
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
113 local ok, err = pcall(dofile, squishy_file);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
114
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
115 if not ok then
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
116 print_err("Couldn't read squishy file: "..err);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
117 os.exit(1);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
118 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
119
25
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
120 if not out_fn then
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
121 print_err("No output file specified by user or squishy file");
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
122 os.exit(1);
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
123 elseif #main_files == 0 and #modules == 0 and #resources == 0 then
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
124 print_err("No files, modules or resources. Not going to generate an empty file.");
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
125 os.exit(1);
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
126 end
a4972a690064 Complain if output file not specified, or if squish would generate an empty file
Matthew Wild <mwild1@gmail.com>
parents: 24
diff changeset
127
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
128 local fetch = {};
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
129 function fetch.filesystem(path)
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
130 local f, err = io.open(path);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
131 if not f then return false, err; end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
132
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
133 local data = f:read("*a");
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
134 f:close();
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
135
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
136 return data;
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
137 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
138
16
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
139 if opts.use_http then
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
140 function fetch.http(url)
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
141 local http = require "socket.http";
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
142
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
143 local body, status = http.request(url);
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
144 if status == 200 then
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
145 return body;
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
146 end
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
147 return false, "HTTP status code: "..tostring(status);
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
148 end
16
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
149 else
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
150 function fetch.http(url)
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
151 return false, "Module not found. Re-squish with --use-http option to fetch it from "..url;
aaf1b38007d8 Add --use-http option, and default to off
Matthew Wild <mwild1@gmail.com>
parents: 15
diff changeset
152 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
153 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
154
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
155 print_info("Writing "..out_fn.."...");
32
d78440c40faa Warn when output file not writeable
Matthew Wild <mwild1@gmail.com>
parents: 31
diff changeset
156 local f, err = io.open(out_fn, "w+");
d78440c40faa Warn when output file not writeable
Matthew Wild <mwild1@gmail.com>
parents: 31
diff changeset
157 if not f then
d78440c40faa Warn when output file not writeable
Matthew Wild <mwild1@gmail.com>
parents: 31
diff changeset
158 print_err("Couldn't open output file: "..tostring(err));
d78440c40faa Warn when output file not writeable
Matthew Wild <mwild1@gmail.com>
parents: 31
diff changeset
159 os.exit(1);
d78440c40faa Warn when output file not writeable
Matthew Wild <mwild1@gmail.com>
parents: 31
diff changeset
160 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
161
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
162 if opts.executable then
28
99ec02c56716 Allow user or squishy file to specify custom shebang
Matthew Wild <mwild1@gmail.com>
parents: 25
diff changeset
163 if opts.executable == true then
99ec02c56716 Allow user or squishy file to specify custom shebang
Matthew Wild <mwild1@gmail.com>
parents: 25
diff changeset
164 f:write("#!/usr/bin/env lua\n");
99ec02c56716 Allow user or squishy file to specify custom shebang
Matthew Wild <mwild1@gmail.com>
parents: 25
diff changeset
165 else
99ec02c56716 Allow user or squishy file to specify custom shebang
Matthew Wild <mwild1@gmail.com>
parents: 25
diff changeset
166 f:write(opts.executable, "\n");
99ec02c56716 Allow user or squishy file to specify custom shebang
Matthew Wild <mwild1@gmail.com>
parents: 25
diff changeset
167 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
168 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
169
39
1d2cca116cce Rename --enable-debug option to --debug
Matthew Wild <mwild1@gmail.com>
parents: 38
diff changeset
170 if opts.debug then
34
0e34461ab2a6 Add new debug extension
Matthew Wild <mwild1@gmail.com>
parents: 32
diff changeset
171 f:write(require_resource("squish.debug"));
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
172 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
173
38
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
174 print_verbose("Resolving modules...");
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
175 do
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
176 local LUA_DIRSEP = package.config:sub(1,1);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
177 local LUA_PATH_MARK = package.config:sub(5,5);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
178
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
179 local package_path = package.path:gsub("[^;]+", function (path)
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
180 if not path:match("^%"..LUA_DIRSEP) then
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
181 return base_path..path;
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
182 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
183 end):gsub("/%./", "/");
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
184 local package_cpath = package.cpath:gsub("[^;]+", function (path)
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
185 if not path:match("^%"..LUA_DIRSEP) then
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
186 return base_path..path;
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
187 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
188 end):gsub("/%./", "/");
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
189
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
190 function resolve_module(name, path)
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
191 name = name:gsub("%.", LUA_DIRSEP);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
192 for c in path:gmatch("[^;]+") do
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
193 c = c:gsub("%"..LUA_PATH_MARK, name);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
194 print_debug("Looking for "..c)
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
195 local f = io.open(c);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
196 if f then
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
197 print_debug("Found!");
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
198 f:close();
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
199 return c;
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
200 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
201 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
202 return nil; -- not found
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
203 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
204
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
205 for i, module in ipairs(modules) do
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
206 if not module.path then
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
207 module.path = resolve_module(module.name, package_path);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
208 if not module.path then
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
209 print_err("Couldn't resolve module: "..module.name);
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
210 else
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
211 -- Strip base_path from resolved path
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
212 module.path = module.path:gsub("^"..base_path:gsub("%p", "%%%1"), "");
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
213 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
214 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
215 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
216 end
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
217
903128a42604 Support for resolving the paths of modules when they are not explicitly specified
Matthew Wild <mwild1@gmail.com>
parents: 37
diff changeset
218
10
d5a4aabb104b Some logging level changes
Matthew Wild <mwild1@gmail.com>
parents: 4
diff changeset
219 print_verbose("Packing modules...");
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
220 for _, module in ipairs(modules) do
71
e27ab4492cdd squish.lua: Only prepend project base path for relative paths specified in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 67
diff changeset
221 local modulename, path = module.name, module.path;
e27ab4492cdd squish.lua: Only prepend project base path for relative paths specified in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 67
diff changeset
222 if module.path:sub(1,1) ~= "/" then
e27ab4492cdd squish.lua: Only prepend project base path for relative paths specified in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 67
diff changeset
223 path = base_path..module.path;
e27ab4492cdd squish.lua: Only prepend project base path for relative paths specified in the squishy file
Matthew Wild <mwild1@gmail.com>
parents: 67
diff changeset
224 end
10
d5a4aabb104b Some logging level changes
Matthew Wild <mwild1@gmail.com>
parents: 4
diff changeset
225 print_debug("Packing "..modulename.." ("..path..")...");
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
226 local data, err = fetch.filesystem(path);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
227 if (not data) and module.url then
81
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
228 local url = module.url:gsub("%?", module.path);
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
229 print_debug("Fetching: ".. url)
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
230 if url:match("^https?://") then
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
231 data, err = fetch.http(url);
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
232 elseif url:match("^file://") then
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
233 local dataf, dataerr = io.open((url:gsub("^file://", "")));
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
234 if dataf then
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
235 data, err = dataf:read("*a");
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
236 dataf:close();
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
237 else
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
238 data, err = nil, dataerr;
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
239 end
44f2945d09cf squish.lua: Support for AutoFetch to use file:// URLs
Matthew Wild <mwild1@gmail.com>
parents: 80
diff changeset
240 end
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
241 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
242 if data then
21
27c2e279f0f3 Fix to work with modules which call module(...)
Matthew Wild <mwild1@gmail.com>
parents: 20
diff changeset
243 f:write("package.preload['", modulename, "'] = (function (...)\n");
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
244 f:write(data);
58
17121881cbf7 squish: Insert a space before ending our wrapper function, in case the module doesn't end with whitespace already
Matthew Wild <mwild1@gmail.com>
parents: 55
diff changeset
245 f:write(" end)\n");
39
1d2cca116cce Rename --enable-debug option to --debug
Matthew Wild <mwild1@gmail.com>
parents: 38
diff changeset
246 if opts.debug then
34
0e34461ab2a6 Add new debug extension
Matthew Wild <mwild1@gmail.com>
parents: 32
diff changeset
247 f:write(string.format("package.preload[%q] = ___adjust_chunk(package.preload[%q], %q);\n\n",
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
248 modulename, modulename, "@"..path));
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
249 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
250 else
67
2fc48318b8bb squish: Handle nil errors when can't pack a module
Matthew Wild <mwild1@gmail.com>
parents: 58
diff changeset
251 print_err("Couldn't pack module '"..modulename.."': "..(err or "unknown error... path to module file correct?"));
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
252 os.exit(1);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
253 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
254 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
255
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
256 if #resources > 0 then
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
257 print_verbose("Packing resources...")
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
258 f:write("do local resources = {};\n");
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
259 for _, resource in ipairs(resources) do
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
260 local name, path = resource.name, resource.path;
53
bd189ae0de00 Fixes for handling binary resources
Matthew Wild <mwild1@gmail.com>
parents: 46
diff changeset
261 local res_file, err = io.open(base_path..path, "rb");
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
262 if not res_file then
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
263 print_err("Couldn't load resource: "..tostring(err));
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
264 os.exit(1);
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
265 end
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
266 local data = res_file:read("*a");
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
267 local maxequals = 0;
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
268 data:gsub("(=+)", function (equals_string) maxequals = math.max(maxequals, #equals_string); end);
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
269
53
bd189ae0de00 Fixes for handling binary resources
Matthew Wild <mwild1@gmail.com>
parents: 46
diff changeset
270 f:write(("resources[%q] = %q"):format(name, data));
bd189ae0de00 Fixes for handling binary resources
Matthew Wild <mwild1@gmail.com>
parents: 46
diff changeset
271 --[[ f:write(("resources[%q] = ["):format(name), string.rep("=", maxequals+1), "[");
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
272 f:write(data);
53
bd189ae0de00 Fixes for handling binary resources
Matthew Wild <mwild1@gmail.com>
parents: 46
diff changeset
273 f:write("]", string.rep("=", maxequals+1), "];"); ]]
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
274 end
41
4ff9ecb6f1f6 Rename --enable-virtual-io to --virtual-io
Matthew Wild <mwild1@gmail.com>
parents: 39
diff changeset
275 if opts.virtual_io then
19
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
276 local vio = require_resource("vio");
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
277 if not vio then
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
278 print_err("Virtual IO requested but is not enabled in this build of squish");
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
279 else
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
280 -- Insert vio library
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
281 f:write(vio, "\n")
54
90bf9ea1aaf0 squish.lua: Small fix to comment
Matthew Wild <mwild1@gmail.com>
parents: 53
diff changeset
282 -- Override standard functions to use vio if opening a resource
20
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
283 f:write[[local io_open, io_lines = io.open, io.lines; function io.open(fn, mode)
19
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
284 if not resources[fn] then
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
285 return io_open(fn, mode);
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
286 else
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
287 return vio.open(resources[fn]);
20
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
288 end end
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
289 function io.lines(fn)
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
290 if not resources[fn] then
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
291 return io_lines(fn);
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
292 else
1766b5a287e1 Add io.lines support for the virtual io
Matthew Wild <mwild1@gmail.com>
parents: 19
diff changeset
293 return vio.open(resources[fn]):lines()
22
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
294 end end
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
295 local _dofile = dofile;
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
296 function dofile(fn)
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
297 if not resources[fn] then
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
298 return _dofile(fn);
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
299 else
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
300 return assert(loadstring(resources[fn]))();
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
301 end end
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
302 local _loadfile = loadfile;
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
303 function loadfile(fn)
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
304 if not resources[fn] then
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
305 return _loadfile(fn);
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
306 else
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
307 return loadstring(resources[fn], "@"..fn);
cb14d8c0d0f7 Add support for virtual IO in dofile and loadfile
Matthew Wild <mwild1@gmail.com>
parents: 21
diff changeset
308 end end ]]
19
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
309 end
f72a0f535301 Add virtual io support for accessing resources
Matthew Wild <mwild1@gmail.com>
parents: 16
diff changeset
310 end
11
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
311 f:write[[function require_resource(name) return resources[name] or error("resource '"..tostring(name).."' not found"); end end ]]
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
312 end
10bb5834c6db Support for adding 'resources'
Matthew Wild <mwild1@gmail.com>
parents: 10
diff changeset
313
0
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
314 print_debug("Finalising...")
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
315 for _, fn in pairs(main_files) do
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
316 local fin, err = io.open(base_path..fn);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
317 if not fin then
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
318 print_err("Failed to open "..fn..": "..err);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
319 os.exit(1);
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
320 else
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
321 f:write((fin:read("*a"):gsub("^#.-\n", "")));
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
322 fin:close();
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
323 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
324 end
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
325
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
326 f:close();
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
327
b119b560ca3d squish, because libraries don't have to be tricky to package!
Matthew Wild <mwild1@gmail.com>
parents:
diff changeset
328 print_info("OK!");

mercurial