The main release package of Ashita v3. Contains all the needed files for users to get up and running. Used by the launcher/injector to auto-update as well.
https://ashitaxi.com/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
156 lines
5.4 KiB
156 lines
5.4 KiB
--[[ |
|
* Ashita - Copyright (c) 2014 - 2017 atom0s [[email protected]] |
|
* |
|
* This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. |
|
* To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to |
|
* Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. |
|
* |
|
* By using Ashita, you agree to the above license and its terms. |
|
* |
|
* Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were |
|
* made. You must do so in any reasonable manner, but not in any way that suggests the licensor |
|
* endorses you or your use. |
|
* |
|
* Non-Commercial - You may not use the material (Ashita) for commercial purposes. |
|
* |
|
* No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the |
|
* modified material. You are, however, allowed to submit the modified works back to the original |
|
* Ashita project in attempt to have it added to the original project. |
|
* |
|
* You may not apply legal terms or technological measures that legally restrict others |
|
* from doing anything the license permits. |
|
* |
|
* No warranties are given. |
|
]]-- |
|
|
|
ashita = ashita or { }; |
|
ashita.settings = ashita.settings or { }; |
|
|
|
if (ashita.settings.JSON == nil) then |
|
ashita.settings.JSON = require('json.json'); |
|
end |
|
---------------------------------------------------------------------------------------------------- |
|
-- func: normalize_path |
|
-- desc: Normalizes a paths slashes to a single format. |
|
---------------------------------------------------------------------------------------------------- |
|
local function normalize_path(path) |
|
local p = path:gsub('/', '\\'); |
|
local i = p:find('\\'); |
|
|
|
while (i ~= nil) do |
|
if (p:sub(i + 1, i + 1) == '\\') then |
|
p = p:remove(i); |
|
i = p:find('\\'); |
|
else |
|
i = p:find('\\', i + 1); |
|
end |
|
end |
|
return p; |
|
end |
|
|
|
---------------------------------------------------------------------------------------------------- |
|
-- func: path_from_file |
|
-- desc: Obtains a path from a file location. |
|
---------------------------------------------------------------------------------------------------- |
|
local function path_from_file(f) |
|
-- Ensure the given data has a file extension.. |
|
if (f:find('%.') == nil) then |
|
return f; |
|
end |
|
|
|
-- Find the location of the first slash.. |
|
local s = f:find('\\'); |
|
if (s == nil) then return f; end |
|
|
|
-- Find the last slash location.. |
|
while (true) do |
|
local c = f:find('\\', s + 1); |
|
if (c == nil) then break; end |
|
s = c; |
|
end |
|
|
|
-- Pull and return the file path.. |
|
return f:sub(0, s - 1); |
|
end |
|
|
|
---------------------------------------------------------------------------------------------------- |
|
-- func: save_settings |
|
-- desc: Saves a table, as JSON, to the given file. |
|
---------------------------------------------------------------------------------------------------- |
|
local function save_settings(name, t) |
|
-- Convert the table to json.. |
|
local data = ashita.settings.JSON:encode_pretty(t, nil, { pretty = true, align_keys = false, indent = ' ' }); |
|
if (data == nil) then |
|
error('Failed to convert data to JSON for saving.'); |
|
return false; |
|
end |
|
|
|
-- Normalize the path.. |
|
local name = normalize_path(name); |
|
|
|
-- Ensure the path exists.. |
|
local dir = path_from_file(name); |
|
if (not ashita.file.dir_exists(dir)) then |
|
ashita.file.create_dir(dir); |
|
end |
|
|
|
-- Save the config file.. |
|
local f = io.open(name, 'w'); |
|
if (f == nil) then |
|
error('Failed to save configuration.'); |
|
return false; |
|
end |
|
|
|
-- Write and close the file.. |
|
f:write(data); |
|
f:close(); |
|
|
|
return true; |
|
end |
|
ashita.settings.save = save_settings; |
|
|
|
---------------------------------------------------------------------------------------------------- |
|
-- func: load_settings |
|
-- desc: Loads a json settings file and converts its data to a Lua table. |
|
---------------------------------------------------------------------------------------------------- |
|
local function load_settings(name) |
|
-- Load the file for reading.. |
|
local f = io.open(name, 'r'); |
|
if (f == nil) then |
|
return nil; |
|
end |
|
|
|
-- Read the full file contents.. |
|
local raw = f:read('*a'); |
|
f:close(); |
|
|
|
-- Convert the JSON to a Lua table.. |
|
local data = ashita.settings.JSON:decode(raw); |
|
if (type(data) == 'table') then return data; end |
|
|
|
-- Failed to convert.. |
|
return nil; |
|
end |
|
ashita.settings.load = load_settings; |
|
|
|
---------------------------------------------------------------------------------------------------- |
|
-- func: load_settings_merged |
|
-- desc: Loads a json settings file and converts its data to a Lua table. Afterward, merges the |
|
-- loaded settings into the parent table. |
|
---------------------------------------------------------------------------------------------------- |
|
local function load_settings_merged(name, parent) |
|
-- Ensure the parent table is valid.. |
|
if (parent == nil or type(parent) ~= 'table') then |
|
return nil; |
|
end |
|
|
|
-- Load the settings.. |
|
local data = ashita.settings.load(name); |
|
if (data == nil) then |
|
return parent; |
|
end |
|
|
|
-- Merge the tables.. |
|
return table.merge(parent, data); |
|
end |
|
ashita.settings.load_merged = load_settings_merged; |