diff options
author | ubq323 <ubq323@ubq323.website> | 2022-11-15 02:50:09 +0000 |
---|---|---|
committer | ubq323 <ubq323@ubq323.website> | 2022-11-15 02:50:09 +0000 |
commit | b3d558481cbddc40327127f87c28ae4d14eb6521 (patch) | |
tree | 25332d8fb94a26e171ff3136c66f23f70d22824c |
conte nt
-rwxr-xr-x | autobuild.sh | 2 | ||||
-rw-r--r-- | bg.png | bin | 0 -> 100 bytes | |||
-rwxr-xr-x | build.sh | 5 | ||||
-rw-r--r-- | h.lua | 102 | ||||
-rw-r--r-- | head.html | 18 | ||||
-rw-r--r-- | index2.lua | 51 | ||||
-rw-r--r-- | me.png | bin | 0 -> 6326 bytes |
7 files changed, 178 insertions, 0 deletions
diff --git a/autobuild.sh b/autobuild.sh new file mode 100755 index 0000000..4c3d3e7 --- /dev/null +++ b/autobuild.sh @@ -0,0 +1,2 @@ +#!/bin/sh +while sleep 1; do find . | entr -d ./build.sh out; done Binary files differdiff --git a/build.sh b/build.sh new file mode 100755 index 0000000..f769b2f --- /dev/null +++ b/build.sh @@ -0,0 +1,5 @@ +#!/bin/sh + +# this will become more advanced later +date +lua index2.lua >index2.html @@ -0,0 +1,102 @@ +-- possible things that thing can be: +-- string: gets escaped +-- safe-str: returned as is +-- table list: concatentated +-- tag: printified + + +-- maths +local el=math.exp(-4.79) +function blorem() local o={} for i=1,math.random(25,150) do local i,u=0,1 repeat i=i+1 u=u*math.random() until u<el table.insert(o, ("b"):rep(i)) end return table.concat(o," ") end + +local function fmt_attrs(attrs) + local function fmt_attr(k,v) + if v == true then + return k + else + if type(v) == "table" then v = table.concat(v," ") end + return ('%s="%s"'):format(k,v) + end + end + + local o = "" + for k,v in pairs(attrs) do + o = o .. " " .. fmt_attr(k,v) + end + return o +end + +local function fmt_tag(tag) + local a = tag.attrs and fmt_attrs(tag.attrs) or "" + local bf + if type(tag.body) == "string" or (type(tag.body) == "table" and tag.body.tag) then + bf = "%s" + else + bf = "\n%s" + end + return ("<%s%s>"..bf.."</%s>"):format(tag.tname,a,html(tag.body),tag.tname) +end + +function tag(tname, a1, a2) + local body, attrs + if a2 then attrs=a1 body=a2 else attrs=nil body=a1 end + return setmetatable({tag=true,tname=tname,attrs=attrs,body=body},{__tostring=fmt_tag}) +end + +function safe(s) + -- marks s as safe, doesn't escape it + assert(type(s) == "string","can only mark string as safe") + return setmetatable({safe=true,s=s},{__tostring=function(x)return x.s end}) +end + +function escape(s) + s=s:gsub("&","&") + s=s:gsub("<","<") + s=s:gsub(">",">") + s=s:gsub('"',""") + return safe(s) +end + + +function html(x) + if type(x) == "string" then + return escape(x) + elseif type(x) == "table" then + if x.safe then + -- safestr. already escaped + return x + elseif x.tag then + -- it's a tag + return safe( tostring(x) ) + else + -- just a regular list + local o = "" + for _,item in ipairs(x) do + o = o .. tostring(html(item)) .. "\n" + end + return safe(o) + end + end +end + +function tagfn(tname) + return function(a1,a2) return tag(tname,a1,a2) end +end +function qw(s) + local t = {} + for a in s:gmatch("%w+") do table.insert(t,a) end + return t +end +local tnames = qw"h1 h2 p b ul li dl dt dd div section header figure figcaption" +for _,n in ipairs(tnames) do + _G[n] = tagfn(n) +end +function a(b,href) return tag("a",{href=href},b) end + +function readf(fname) + local f = io.open(fname,"r") + local c = f:read("a") + f:close() + return c +end +function safereadf(fname) return safe(readf(fname)) end diff --git a/head.html b/head.html new file mode 100644 index 0000000..d3c2d34 --- /dev/null +++ b/head.html @@ -0,0 +1,18 @@ +<!DOCTYPE html> +<meta charset="utf-8" /> +<meta name="viewport" content="width=device-width, initial-scale=1" /> +<link rel="icon" href="/m/interesting3.png"> +<style> +body {font-family: sans-serif;font-size:larger;max-width:60ch;margin:auto} +body {background-image: url("bg.png")} +h1 {color:#e79e00; text-shadow: 0 0 1px #000, 0 0 1px #000, 0 0 1px #000, 0 0 1px #000, 0 0 1px #000, 0 0 1px #000;} +section {margin:20px 0;padding:20px;border-radius:20px;border:1px solid rebeccapurple;background-color:white} +header {border: 2px solid black;max-width:100%;margin:1em;background-color:white} +header {display:grid;grid-template-columns:1fr 3fr;} +#me {max-width:100%;grid-row: 1/3;grid-column:1;margin:auto} +header * {margin:auto} +header p {padding:1em} + +#things {display:flex} +#things div {flex:1;border:1px solid black} +</style> diff --git a/index2.lua b/index2.lua new file mode 100644 index 0000000..afb653a --- /dev/null +++ b/index2.lua @@ -0,0 +1,51 @@ +require"h" + +head ={ safereadf "head.html", tag("title","ubq323's website") } +top = header { + tag("img",{id="me",src="me.png"},""), + h1 "ubq323's website", + p [[rebecca, "ubq323" (she/her, 20) - eminently engromulent]], +} + +function l(text,path) return li(a(text,path or "/"..text)) end +mainsect = section { + p [[hello, i am rebecca, and this is my website. on it are some things:]]; + ul { + l(",flappy fly bird man?","/ffbm"); + l "morrison"; + li "blog"; + li "microblog"; + l("apioforum","//a.gh0.pw"); + l("ubq323 git","//g.gh0.pw"); + l("some music","//ubq323.bandcamp.com"); + li "projects"; + }; + p [[(if a link is missing, it is because i haven't created that thing yet)]] +} + + + +contact = section { + h2 "contact"; + + p "i enjoy it when people contact me. if you are cool, please contact me."; + ul { + li [[email: ubq323@ubq323.website]], + li [[xmpp: ubq323@ubq323.website]], + li { [[irc: ubq323 on ]], a("apionet","irc:ubq323.website/#a") }, + li [[discord (if you must): ubq323#9691]], + }, +} +footer = safe [[ +<hr> + +<!-- GEORGE --> +<iframe height="50" src="https://george.gh0.pw/embed.cgi?ubq323" style="border:none;width:100%"></iframe> +<!-- johnvertisements --> +<iframe src="https://john.mondecitronne.com/embed?ref=ubq323.website" style="margin-left:auto;display:block;margin-right:auto;max-width:732px;width:100%;height:12.367%;border:none;"></iframe> +]] + + +print(html{ + head, top, mainsect, things, contact, footer +}) Binary files differ |