mirror of
https://github.com/20kdc/OC-KittenOS.git
synced 2025-04-05 04:08:39 +11:00
Loads of documentation & adjustments. I should probably commit more.
This commit is contained in:
parent
3e43cd3aaa
commit
c5b58e79ff
@ -50,6 +50,7 @@ function regenCore()
|
|||||||
fd.close()
|
fd.close()
|
||||||
busy = false
|
busy = false
|
||||||
neoux.startDialog("Got the data!", nil, true)
|
neoux.startDialog("Got the data!", nil, true)
|
||||||
|
window.reset(regenCore())
|
||||||
end))
|
end))
|
||||||
table.insert(elems, neoux.tcbutton(6, l + 1, "set", function (window)
|
table.insert(elems, neoux.tcbutton(6, l + 1, "set", function (window)
|
||||||
if busy then return end
|
if busy then return end
|
||||||
@ -62,6 +63,7 @@ function regenCore()
|
|||||||
report = (wasOk and tostring(report)) or "Flash successful.\nI recommend relabelling the EEPROM."
|
report = (wasOk and tostring(report)) or "Flash successful.\nI recommend relabelling the EEPROM."
|
||||||
busy = false
|
busy = false
|
||||||
neoux.startDialog(report, nil, true)
|
neoux.startDialog(report, nil, true)
|
||||||
|
window.reset(regenCore())
|
||||||
end))
|
end))
|
||||||
local function dHandler(set, get, wd)
|
local function dHandler(set, get, wd)
|
||||||
local setter = v[set]
|
local setter = v[set]
|
||||||
@ -85,5 +87,11 @@ end
|
|||||||
local window = neoux.create(regenCore())
|
local window = neoux.create(regenCore())
|
||||||
|
|
||||||
while running do
|
while running do
|
||||||
event.pull()
|
local s = {event.pull()}
|
||||||
|
if (s[1] == "h.component_added" or s[1] == "h.component_removed") and busy then
|
||||||
|
-- Anything important?
|
||||||
|
if s[3] == "gpu" or s[3] == "screen" then
|
||||||
|
window.reset(regenCore())
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
@ -408,13 +408,8 @@ while true do
|
|||||||
-- always shutdown
|
-- always shutdown
|
||||||
shutdownFin(shutdownMode)
|
shutdownFin(shutdownMode)
|
||||||
end
|
end
|
||||||
if s[1] == "h.component_added" then
|
if s[1] == "h.component_added" or s[1] == "h.component_removed" then
|
||||||
-- Before doing anything, is it worth it?
|
-- Anything important?
|
||||||
if s[3] == "gpu" or s[3] == "screen" then
|
|
||||||
rescanDevs()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if s[1] == "h.component_removed" then
|
|
||||||
if s[3] == "gpu" or s[3] == "screen" then
|
if s[3] == "gpu" or s[3] == "screen" then
|
||||||
rescanDevs()
|
rescanDevs()
|
||||||
end
|
end
|
||||||
|
@ -410,6 +410,8 @@ local function initializeSystem()
|
|||||||
else
|
else
|
||||||
local v, err = neo.executeAsync(steps[w])
|
local v, err = neo.executeAsync(steps[w])
|
||||||
if not v then
|
if not v then
|
||||||
|
neo.emergency(steps[w] .. " STF")
|
||||||
|
neo.emergency(err)
|
||||||
table.insert(warnings, steps[w] .. " STF")
|
table.insert(warnings, steps[w] .. " STF")
|
||||||
table.insert(warnings, err)
|
table.insert(warnings, err)
|
||||||
end
|
end
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
-- This is released into the public domain.
|
||||||
|
-- No warranty is provided, implied or otherwise.
|
||||||
return {
|
return {
|
||||||
["neo"] = {
|
["neo"] = {
|
||||||
desc = "KittenOS NEO Kernel & Base Libs",
|
desc = "KittenOS NEO Kernel & Base Libs",
|
||||||
@ -123,7 +125,7 @@ return {
|
|||||||
},
|
},
|
||||||
["app-flash"] = {
|
["app-flash"] = {
|
||||||
desc = "KittenOS NEO EEPROM Flasher",
|
desc = "KittenOS NEO EEPROM Flasher",
|
||||||
v = 0,
|
v = 2,
|
||||||
deps = {
|
deps = {
|
||||||
"neo"
|
"neo"
|
||||||
},
|
},
|
||||||
|
@ -17,6 +17,16 @@ if ocemu then
|
|||||||
emergencyFunction = ocemu.log
|
emergencyFunction = ocemu.log
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if load(string.dump(function()end)) then
|
||||||
|
-- This is your first and only warning.
|
||||||
|
-- allowBytecode has effects *outside the game.*
|
||||||
|
-- If it is enabled, any program with load can take over your host system.
|
||||||
|
-- I refuse to allow KittenOS NEO to operate in this environment for your safety.
|
||||||
|
-- If you are truly unable to change it, tell someone who can.
|
||||||
|
emergencyFunction("Please set allowBytecode = false in OCEmu config.")
|
||||||
|
error("Please set allowBytecode = false in OC config.")
|
||||||
|
end
|
||||||
|
|
||||||
primaryDisk = component.proxy(computer.getBootAddress())
|
primaryDisk = component.proxy(computer.getBootAddress())
|
||||||
|
|
||||||
-- {{time, func, arg1...}...}
|
-- {{time, func, arg1...}...}
|
||||||
@ -149,7 +159,7 @@ function ensureType(a, t)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function ensurePathComponent(s)
|
function ensurePathComponent(s)
|
||||||
if not string.match(s, "^[a-zA-Z0-9_%-%+%,%#%~%@%'%;%[%]%(%)%&%%%$%! %=%{%}%^]+$") then error("chars disallowed") end
|
if not string.match(s, "^[a-zA-Z0-9_%-%+%,%.%#%~%@%'%;%[%]%(%)%&%%%$%! %=%{%}%^]+$") then error("chars disallowed: " .. s) end
|
||||||
if s == "." then error("single dot disallowed") end
|
if s == "." then error("single dot disallowed") end
|
||||||
if s == ".." then error("double dot disallowed") end
|
if s == ".." then error("double dot disallowed") end
|
||||||
end
|
end
|
||||||
@ -245,6 +255,7 @@ function loadLibraryInner(library)
|
|||||||
if l then
|
if l then
|
||||||
local ok, al = pcall(l)
|
local ok, al = pcall(l)
|
||||||
if ok then
|
if ok then
|
||||||
|
al = wrapMeta(al)
|
||||||
libraries[library] = al
|
libraries[library] = al
|
||||||
return al
|
return al
|
||||||
else
|
else
|
||||||
@ -355,6 +366,15 @@ function runProgramPolicy(ipkg, pkg, pid, ...)
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- This is hidden here to protect you.
|
||||||
|
-- I beg of you, don't remove it.
|
||||||
|
if load(string.dump(function()end)) then
|
||||||
|
local oldLoad = load
|
||||||
|
load = function (c, n, m, ...)
|
||||||
|
return oldLoad(c, n, "t", ...)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function retrieveAccess(perm, pkg, pid)
|
function retrieveAccess(perm, pkg, pid)
|
||||||
-- Return the access lib and the death callback.
|
-- Return the access lib and the death callback.
|
||||||
|
|
||||||
@ -467,7 +487,8 @@ function start(pkg, ...)
|
|||||||
|
|
||||||
local function startFromUser(ipkg, ...)
|
local function startFromUser(ipkg, ...)
|
||||||
ensureType(ipkg, "string")
|
ensureType(ipkg, "string")
|
||||||
ensurePathComponent(ipkg .. ".lua")
|
local ok, n = pcall(ensurePathComponent, ipkg .. ".lua")
|
||||||
|
if not ok then return nil, n end
|
||||||
local k, r = runProgramPolicy(ipkg, pkg, pid, ...)
|
local k, r = runProgramPolicy(ipkg, pkg, pid, ...)
|
||||||
if k then
|
if k then
|
||||||
return start(ipkg, pkg, pid, ...)
|
return start(ipkg, pkg, pid, ...)
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
-- This is released into the public domain.
|
-- This is released into the public domain.
|
||||||
-- No warranty is provided, implied or otherwise.
|
-- No warranty is provided, implied or otherwise.
|
||||||
|
|
||||||
-- Braille Neoux Component
|
-- Braille Converter & NeoUX component
|
||||||
-- Callbacks :
|
-- While the Neoux part isn't OS-independent,
|
||||||
|
-- the converter itself is. Enjoy.
|
||||||
|
|
||||||
|
-- Braille Neoux Component Callbacks :
|
||||||
-- selectable (boolean)
|
-- selectable (boolean)
|
||||||
-- key(window, update, a, c, d)
|
-- key(window, update, a, c, d)
|
||||||
-- touch(window, update, x, y, button)
|
-- touch(window, update, x, y, button)
|
||||||
@ -164,7 +167,7 @@ local function calcLine(x, y, w, span, get, colour)
|
|||||||
span(x, y, str, bg, fg)
|
span(x, y, str, bg, fg)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
heldRef = neo.wrapMeta({
|
heldRef = {
|
||||||
calcLine = calcLine,
|
calcLine = calcLine,
|
||||||
new = function (x, y, w, h, cbs, colour)
|
new = function (x, y, w, h, cbs, colour)
|
||||||
local control
|
local control
|
||||||
@ -189,5 +192,5 @@ heldRef = neo.wrapMeta({
|
|||||||
}
|
}
|
||||||
return control
|
return control
|
||||||
end,
|
end,
|
||||||
})
|
}
|
||||||
return heldRef
|
return heldRef
|
||||||
|
@ -18,6 +18,7 @@ fmt = {
|
|||||||
end
|
end
|
||||||
return t
|
return t
|
||||||
end,
|
end,
|
||||||
|
-- Expects safeTextFormat'd input
|
||||||
fmtText = function (text, w)
|
fmtText = function (text, w)
|
||||||
local nl = text:find("\n")
|
local nl = text:find("\n")
|
||||||
if nl then
|
if nl then
|
||||||
@ -67,4 +68,4 @@ fmt = {
|
|||||||
return {fmt.pad(text, w)}
|
return {fmt.pad(text, w)}
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
return neo.wrapMeta(fmt)
|
return fmt
|
||||||
|
@ -82,7 +82,10 @@ newNeoux = function (event, neo)
|
|||||||
return window
|
return window
|
||||||
end
|
end
|
||||||
-- Padding function
|
-- Padding function
|
||||||
neoux.pad = require("fmttext").pad
|
neoux.pad = function (...)
|
||||||
|
local fmt = require("fmttext")
|
||||||
|
return fmt.pad(...)
|
||||||
|
end
|
||||||
-- Text dialog formatting function.
|
-- Text dialog formatting function.
|
||||||
-- Assumes you've run unicode.safeTextFormat if need be
|
-- Assumes you've run unicode.safeTextFormat if need be
|
||||||
neoux.fmtText = function (...)
|
neoux.fmtText = function (...)
|
||||||
|
@ -26,12 +26,16 @@ function doSerialize(s)
|
|||||||
end
|
end
|
||||||
error("Cannot serialize " .. type(s))
|
error("Cannot serialize " .. type(s))
|
||||||
end
|
end
|
||||||
return neo.wrapMeta({
|
return {
|
||||||
serialize = function (x) return "return " .. doSerialize(x) end,
|
serialize = function (x) return "return " .. doSerialize(x) end,
|
||||||
deserialize = function (s)
|
deserialize = function (s)
|
||||||
local r1, r2 = pcall(function() return load(s, "=serial", "t", {})() end)
|
local r1, r2 = pcall(function()
|
||||||
|
return load(s, "=serial", "t", {})()
|
||||||
|
end)
|
||||||
if r1 then
|
if r1 then
|
||||||
return r2
|
return r2
|
||||||
|
else
|
||||||
|
return nil, tostring(r2)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
})
|
}
|
||||||
|
@ -21,6 +21,10 @@ local actualPolicy = function (pkg, pid, perm)
|
|||||||
if perm:sub(1, 10) == "x.neo.pub." then
|
if perm:sub(1, 10) == "x.neo.pub." then
|
||||||
return "allow"
|
return "allow"
|
||||||
end
|
end
|
||||||
|
-- These signals are harmless, though they identify HW (as does everything in OC...)
|
||||||
|
if perm == "s.h.component_added" or perm == "s.h.component_removed" then
|
||||||
|
return "allow"
|
||||||
|
end
|
||||||
-- This is to ensure the prefix naming scheme is FOLLOWED!
|
-- This is to ensure the prefix naming scheme is FOLLOWED!
|
||||||
-- sys- : System, part of KittenOS NEO and thus tries to present a "unified fragmented interface" in 'neo'
|
-- sys- : System, part of KittenOS NEO and thus tries to present a "unified fragmented interface" in 'neo'
|
||||||
-- app- : Application - these can have ad-hoc relationships. It is EXPECTED these have a GUI
|
-- app- : Application - these can have ad-hoc relationships. It is EXPECTED these have a GUI
|
||||||
|
@ -33,8 +33,10 @@ return {
|
|||||||
"docs/kn-sched",
|
"docs/kn-sched",
|
||||||
"docs/kn-perms",
|
"docs/kn-perms",
|
||||||
"docs/us-perms",
|
"docs/us-perms",
|
||||||
|
"docs/us-nxapp",
|
||||||
"docs/ul-seria",
|
"docs/ul-seria",
|
||||||
"docs/ul-event",
|
"docs/ul-event",
|
||||||
|
"docs/ul-fmttx",
|
||||||
"docs/ul-neoux",
|
"docs/ul-neoux",
|
||||||
"docs/ul-broil",
|
"docs/ul-broil",
|
||||||
"docs/gp-pedan"
|
"docs/gp-pedan"
|
||||||
|
@ -51,7 +51,11 @@ This is a critical memory management
|
|||||||
(This also means libraries can have
|
(This also means libraries can have
|
||||||
security side-effects, but they
|
security side-effects, but they
|
||||||
always can in any system, arguably,
|
always can in any system, arguably,
|
||||||
and it's worth it for the memory.)
|
and it's worth it for the memory.
|
||||||
|
Notably, library values get
|
||||||
|
wrapMeta'd automatically since R2,
|
||||||
|
in order to reduce NEO-specific
|
||||||
|
code.)
|
||||||
|
|
||||||
The processes are applications and
|
The processes are applications and
|
||||||
services, that communicate with the
|
services, that communicate with the
|
||||||
|
@ -78,7 +78,21 @@ unicode is extended with:
|
|||||||
safe to pass to a GPU without any
|
safe to pass to a GPU without any
|
||||||
odd graphical glitches.
|
odd graphical glitches.
|
||||||
|
|
||||||
os is replaced with:
|
The KittenOS NEO kernel also reserves
|
||||||
|
the ability to take advantage of any
|
||||||
|
full de-UTF16'd support for Unicode
|
||||||
|
available on the system, but will
|
||||||
|
not include such support as a shim
|
||||||
|
for memory usage reasons.
|
||||||
|
|
||||||
|
Programs that thus try to work around
|
||||||
|
this problem should delegate this
|
||||||
|
task to a library, in a separate
|
||||||
|
package, which can then be updated
|
||||||
|
as-needed if and when the issue is
|
||||||
|
resolved.
|
||||||
|
|
||||||
|
os is replaced with (wrapMeta'd):
|
||||||
totalMemory = computer.totalMemory,
|
totalMemory = computer.totalMemory,
|
||||||
freeMemory = computer.freeMemory,
|
freeMemory = computer.freeMemory,
|
||||||
energy = computer.energy,
|
energy = computer.energy,
|
||||||
@ -89,9 +103,9 @@ os is replaced with:
|
|||||||
uptime = computer.uptime,
|
uptime = computer.uptime,
|
||||||
address = computer.address
|
address = computer.address
|
||||||
|
|
||||||
The following are just wrapMeta'd
|
The following are just host functions
|
||||||
host functions
|
(*: wrapped for security - these
|
||||||
(*: wrapped for security):
|
functions detect metatable abuse):
|
||||||
|
|
||||||
assert, ipairs, load, next*,
|
assert, ipairs, load, next*,
|
||||||
pairs, pcall, xpcall, select,
|
pairs, pcall, xpcall, select,
|
||||||
@ -99,6 +113,20 @@ The following are just wrapMeta'd
|
|||||||
setmetatable, getmetatable*,
|
setmetatable, getmetatable*,
|
||||||
rawset*, rawget, rawlen, rawequal
|
rawset*, rawget, rawlen, rawequal
|
||||||
|
|
||||||
|
(NOTE: Before you consider that load
|
||||||
|
has no checks: The policy regarding
|
||||||
|
load is taken from the host system.
|
||||||
|
Which means bytecode loading is
|
||||||
|
almost certainly off. If it's not
|
||||||
|
off, then this is the user's fault,
|
||||||
|
as doing so is marked as a security
|
||||||
|
risk for very obvious reasons.
|
||||||
|
As for trying to use the environment
|
||||||
|
to bypass a metatable, I tested.
|
||||||
|
Metatables do apply to environments,
|
||||||
|
including global creation.
|
||||||
|
There is no way to win.)
|
||||||
|
|
||||||
"require" and "neo" are the parts of
|
"require" and "neo" are the parts of
|
||||||
the environment where a NEO-specific
|
the environment where a NEO-specific
|
||||||
nature presents itself.
|
nature presents itself.
|
||||||
@ -107,6 +135,13 @@ require takes a string, and returns
|
|||||||
the value returned by the library at
|
the value returned by the library at
|
||||||
"libs/" .. str .. ".lua" on the
|
"libs/" .. str .. ".lua" on the
|
||||||
primary disk.
|
primary disk.
|
||||||
|
Since R2, the value is automatically
|
||||||
|
wrapMeta'd, just in case.
|
||||||
|
Before R2, libraries did this on
|
||||||
|
their own, but this caused NEO-only
|
||||||
|
code to crop up in libraries that
|
||||||
|
did not need NEO-only code.
|
||||||
|
|
||||||
The library name must be a valid path
|
The library name must be a valid path
|
||||||
component, and the library path must
|
component, and the library path must
|
||||||
also be valid - see
|
also be valid - see
|
||||||
@ -285,4 +320,3 @@ With that, I hope I have documented
|
|||||||
the public domain.
|
the public domain.
|
||||||
-- No warranty is provided,
|
-- No warranty is provided,
|
||||||
implied or otherwise.
|
implied or otherwise.
|
||||||
|
|
||||||
|
55
repository/docs/ul-fmttx
Normal file
55
repository/docs/ul-fmttx
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
The "fmttext" library is used for
|
||||||
|
formatting text in various places in
|
||||||
|
KittenOS NEO.
|
||||||
|
|
||||||
|
It's recommended that you only load
|
||||||
|
this library when you need it, and
|
||||||
|
release the value immediately after,
|
||||||
|
as it is rarely called, and has no
|
||||||
|
sticky objects that could cause
|
||||||
|
duplicated library issues.
|
||||||
|
|
||||||
|
If using neoux, the pad and fmtText
|
||||||
|
functions are proxied there in a
|
||||||
|
load-on-demand form, such that you
|
||||||
|
can call them, and the library is
|
||||||
|
loaded for that call.
|
||||||
|
|
||||||
|
Essentially, it's job is to take some
|
||||||
|
safeTextFormat'd text, and turn it
|
||||||
|
into a column of a given width.
|
||||||
|
|
||||||
|
It has two functions for this task:
|
||||||
|
pad(text, len[, centre[, cut]]):
|
||||||
|
Pads the given safeTextFormat'd
|
||||||
|
string to a given width, returning
|
||||||
|
the resulting string.
|
||||||
|
If centre is true, then the text is
|
||||||
|
centred within the area given -
|
||||||
|
otherwise, it is left-justified.
|
||||||
|
(Values that are not nil or true
|
||||||
|
are reserved for future use.)
|
||||||
|
If cut is true, then the text may
|
||||||
|
be reduced in size if necessary.
|
||||||
|
Otherwise, text that is too long is
|
||||||
|
not reduced.
|
||||||
|
|
||||||
|
fmtText(text, width):
|
||||||
|
Formats the given text to a given
|
||||||
|
width in a wrapping fashion.
|
||||||
|
Returns a series of lines that are
|
||||||
|
padded to the given width.
|
||||||
|
If there are newlines in the text,
|
||||||
|
these newlines are respected.
|
||||||
|
If possible, the wrapping is a word
|
||||||
|
wrap style, but words are broken
|
||||||
|
if necessary.
|
||||||
|
If the width is less than 2, then
|
||||||
|
this function may fail in various
|
||||||
|
ways, up to and including freezes.
|
||||||
|
|
||||||
|
-- This is released into
|
||||||
|
the public domain.
|
||||||
|
-- No warranty is provided,
|
||||||
|
implied or otherwise.
|
||||||
|
|
@ -1,4 +1,49 @@
|
|||||||
Hello World.
|
The "neoux" (aka NeoUX) library is a
|
||||||
|
UI framework for KittenOS NEO, meant
|
||||||
|
to provide a consistent set of
|
||||||
|
controls and a consistent way to
|
||||||
|
navigate the UI in any given case.
|
||||||
|
|
||||||
|
Thus, it's not used by text editing
|
||||||
|
programs such as Neolithic.
|
||||||
|
|
||||||
|
To get ahold of NeoUX in your app,
|
||||||
|
use code similar to:
|
||||||
|
|
||||||
|
local event, neoux
|
||||||
|
event = require("event")(neo)
|
||||||
|
neoux = require("neoux")(event, neo)
|
||||||
|
|
||||||
|
The neo table is used for retrieving
|
||||||
|
the required accesses for APIs.
|
||||||
|
|
||||||
|
The NeoUX API is divided into three
|
||||||
|
parts - the part that connects it to
|
||||||
|
Everest & utility functions, the UI
|
||||||
|
framework's "tcwindow" root, and the
|
||||||
|
basic set of controls.
|
||||||
|
|
||||||
|
The most reliable reference on the
|
||||||
|
API a control implements is given
|
||||||
|
at the top of libs/neoux.lua, and
|
||||||
|
for updatability reasons will not
|
||||||
|
be repeated here, except with the
|
||||||
|
note that "xI"/"yI" is within-char
|
||||||
|
position from 0 to 1.
|
||||||
|
|
||||||
|
TODO, TODO, TODO, TODO, TODO, TODO
|
||||||
|
|
||||||
|
neoux.fileDialog = function (forWrite, callback)
|
||||||
|
neoux.create = function (w, h, title, callback)
|
||||||
|
neoux.pad = require("fmttext").pad
|
||||||
|
neoux.fmtText = function (...)
|
||||||
|
neoux.tcwindow = function (w, h, controls, closing, bg, fg, selIndex)
|
||||||
|
neoux.tcrawview = function (x, y, lines)
|
||||||
|
neoux.tchdivider = function (x, y, w)
|
||||||
|
neoux.tcvdivider = function (x, y, h)
|
||||||
|
neoux.tcbutton = function (x, y, text, callback)
|
||||||
|
neoux.tcfield = function (x, y, w, textprop)
|
||||||
|
neoux.startDialog = function (fmt, title, wait)
|
||||||
|
|
||||||
-- This is released into
|
-- This is released into
|
||||||
the public domain.
|
the public domain.
|
||||||
|
@ -1,4 +1,54 @@
|
|||||||
Hello World.
|
The "serial" library is a library to
|
||||||
|
serialize and deserialize Lua values
|
||||||
|
in a relatively safe* manner.
|
||||||
|
|
||||||
|
* Serialization cannot handle a
|
||||||
|
recursive loop correctly,
|
||||||
|
and may error() if certain values
|
||||||
|
are passed to it.
|
||||||
|
The deserialization has unbounded
|
||||||
|
time and memory only limited by
|
||||||
|
the host. It is possible to kill
|
||||||
|
a process indirectly via a
|
||||||
|
poisonous file, but it is not
|
||||||
|
possible to directly break the
|
||||||
|
sandbox without Lua interpreter
|
||||||
|
bugs.
|
||||||
|
|
||||||
|
It is not recommended to use serial
|
||||||
|
for data that is not from a known
|
||||||
|
source, but it is not dangerous to
|
||||||
|
system security (but certainly to
|
||||||
|
stability) to use it for other
|
||||||
|
data so long as no function that
|
||||||
|
originated from the data is ever
|
||||||
|
executed with objects that can be
|
||||||
|
used to elevate privilege.
|
||||||
|
|
||||||
|
(In other words, don't call any
|
||||||
|
function if you can't tell where it
|
||||||
|
came from. This should be obvious.)
|
||||||
|
|
||||||
|
The serial library has merely two
|
||||||
|
functions available to it.
|
||||||
|
|
||||||
|
serialize(val):
|
||||||
|
Returns the serialized data as a
|
||||||
|
string. The serialized data will
|
||||||
|
be in the form of "return ",
|
||||||
|
followed by a Lua 5.2-parsable
|
||||||
|
value of some sort.
|
||||||
|
|
||||||
|
deserialize(str):
|
||||||
|
Returns the deserialized data as a
|
||||||
|
Lua value.
|
||||||
|
A value of nil is an ambiguity:
|
||||||
|
it could be the actual data, or it
|
||||||
|
could be a deserialization error.
|
||||||
|
Check for this situation by reading
|
||||||
|
the second returned value.
|
||||||
|
If it is not nil, deserialization
|
||||||
|
failed with the given error.
|
||||||
|
|
||||||
-- This is released into
|
-- This is released into
|
||||||
the public domain.
|
the public domain.
|
||||||
|
35
repository/docs/us-nxapp
Normal file
35
repository/docs/us-nxapp
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
A Quick Note On NeoUX Application
|
||||||
|
Structure
|
||||||
|
|
||||||
|
A typical NeoUX application has one
|
||||||
|
window, which it uses .reset on in
|
||||||
|
order to change the window contents
|
||||||
|
to different things.
|
||||||
|
|
||||||
|
This is typically achieved with a
|
||||||
|
callback to regenerate the window,
|
||||||
|
used like this:
|
||||||
|
|
||||||
|
window = neoux.create(mainWin())
|
||||||
|
|
||||||
|
and to regenerate the window:
|
||||||
|
|
||||||
|
window.reset(mainWin())
|
||||||
|
|
||||||
|
This allows a simple way to write big
|
||||||
|
UI trees without going totally nuts.
|
||||||
|
|
||||||
|
A good example of this is app-flash,
|
||||||
|
but unlike most of the examples, it
|
||||||
|
does not change the regeneration
|
||||||
|
callback (it never has to - the
|
||||||
|
labelling window never needs to be
|
||||||
|
regenerated after it's switched to,
|
||||||
|
so the only regeneration is for the
|
||||||
|
main window)
|
||||||
|
|
||||||
|
-- This is released into
|
||||||
|
the public domain.
|
||||||
|
-- No warranty is provided,
|
||||||
|
implied or otherwise.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user