summaryrefslogtreecommitdiff
path: root/pkg/perp/gen.lua
diff options
context:
space:
mode:
Diffstat (limited to 'pkg/perp/gen.lua')
-rw-r--r--pkg/perp/gen.lua102
1 files changed, 102 insertions, 0 deletions
diff --git a/pkg/perp/gen.lua b/pkg/perp/gen.lua
new file mode 100644
index 00000000..7d0dd246
--- /dev/null
+++ b/pkg/perp/gen.lua
@@ -0,0 +1,102 @@
+cflags{
+ '-I $srcdir/lasagna',
+ '-I $outdir',
+}
+
+sub('tools.ninja', function()
+ toolchain 'host'
+ exe('mk_outvec', {'lasagna/outvec/mk_outvec.c'})
+ exe('mk_rlimit', {'lasagna/rlimit/mk_rlimit.c'})
+ exe('mksysstr', {'lasagna/sysstr/mksysstr.c'})
+end)
+
+rule('outvec', '$outdir/mk_outvec >$out.tmp && mv $out.tmp $out')
+build('outvec', '$outdir/outvec_STDOUT.h', {'|', '$outdir/mk_outvec'})
+
+rule('rlimit', '$outdir/mk_rlimit >$out.tmp && mv $out.tmp $out')
+build('rlimit', '$outdir/rlimit_defs.c.in', {'|', '$outdir/mk_rlimit'})
+
+rule('sysstr', '$outdir/mksysstr $type >$out.tmp && mv $out.tmp $out')
+build('sysstr', '$outdir/sysstr_errno.c.in', {'|', '$outdir/mksysstr'}, {type='errno'})
+build('sysstr', '$outdir/sysstr_signo.c.in', {'|', '$outdir/mksysstr'}, {type='signo'})
+
+pkg.deps = {
+ '$outdir/outvec_STDOUT.h',
+ '$outdir/rlimit_defs.c.in',
+ '$outdir/sysstr_errno.c.in',
+ '$outdir/sysstr_signo.c.in',
+}
+
+lib('libasagna.a', [[lasagna/(
+ buf/buf_(cmp copy fill ndx rcopy rndx).c
+ cstr/cstr_(cat chop cmp cmpi contains copy dup lcat lcpy len ltrim match matchi ncmp pos rpos rtrim trim vcat_ vcopy_ vlen_).c
+ cdb/(cdb_(find cc clear close distance dynget dynread get hashpart init open read seq) cdbmk_(add addioq addrec clear finish init _update)).c
+ devout/devout.c
+ domsock/domsock_(accept close connect create).c
+ dynbuf/(dynbuf.c dynbuf_(clear copy free freebuf grow need new pack put putb).c)
+ dynstr/(dynstr.c dynstr_(chop clear copy copys free freestr grow need new put putc putn puts set vputs_).c)
+ dynstuf/dynstuf_(find free get grow init isempty items new peek pop push replace reverse set slots sort stuf visit).c
+ execvx/execvx.c
+ fd/fd_(blocking cloexec dupe move nonblock).c
+ hdb/hdb_(find cc clear close distance dynget dynread get hashpart init open read seq).c
+ hdb/hdbmk_(add addioq addrec clear finish start _update).c
+ hfunc/hfunc_(djba djbm djbx elf1 fnva fnvm ghfa ghfm ghfx jsw1 kp37 kr31 kx17 murm oat1 p50a pjw1 rsuh rot1 rotm sax1 sdbm sfh1 postmix32).c
+ ioq/ioq_(get getln init put putfd putfile stderr stdin stdout vputs_).c
+ newenv/newenv.c
+ nextopt/(nextopt nextopt_progname).c
+ nfmt/nfmt_(uint32 uint32_pad uint32_pad_ uint32_pad0 uint32_pad0_ uint32o uint32o_pad0 uint32o_pad0_ uint32x uint32x_pad uint32x_pad_ uint32x_pad0 uint32x_pad0_ uint64 uint64_pad uint64_pad_ uint64_pad0 uint64_pad0_).c
+ nuscan/nuscan_(uint32 uint32o).c
+ outvec/outvec_(STDERR STDOUT flush put puts vputs_).c
+ packet/packet_(read write).c
+ padlock/padlock_(exbyte exlock extest fcntl shbyte shlock shtest unbyte unlock).c
+ pidlock/pidlock_(check set).c
+ pkt/pkt_(load read write).c
+ pollio/pollio.c
+ rlimit/rlimit.c
+ sig/sig_(block catch catchr unblock).c
+ sysstr/sysstr_(errno signal).c
+ tain/tain_(assign iszero less load load_msecs load_utc minus now pack packhex pause plus tai_pack tai_unpack uptime to_float to_msecs to_utc unpack unpackhex).c
+ tx64/(base64_vec tx64_encode).c
+ ufunc/ufunc_(u32add u48add).c
+ upak/upak_vpack.c
+ upak/(upak upak(16 24 32 48 64))_pack.c
+ upak/(upak upak(16 24 32 48 64))_unpack.c
+)]])
+
+exe('perpd', 'perp/(perpd.c perpd_conn.c perpd_svdef.c) libasagna.a')
+file('bin/perpd', '755', '$outdir/perpd')
+man{'perp/man/perpd.8'}
+
+for _, cmd in ipairs{'perpboot', 'perpctl', 'perphup', 'perpls', 'perpok', 'perpstat'} do
+ file('bin/'..cmd, '755', exe(cmd, {'perp/'..cmd..'.c', 'libasagna.a'}))
+ man{'perp/man/'..cmd..'.8'}
+end
+
+cc('perp/tinylog.c', nil, {
+ cflags='$cflags -D \'TINYLOG_ZIP="/bin/gzip"\' -D \'ZIP_EXT=".gz"\'',
+})
+link('tinylog', {'perp/tinylog.c.o', 'libasagna.a'})
+file('bin/tinylog', '755', '$outdir/tinylog')
+man{'perp/man/tinylog.8'}
+
+local tools = {
+ 'runargs', 'runargv0', 'runchoom', 'rundetach', 'rundeux', 'runenv',
+ 'runfile', 'runlimit', 'runlock', 'runpause', 'runsession', 'runtool',
+ 'runtrap', 'runuid',
+
+ 'catargs', 'catenv', 'catlimits', 'catuid',
+}
+for _, tool in ipairs(tools) do
+ file('bin/'..tool, '755', exe(tool, {'runtools/'..tool..'.c', 'libasagna.a'}))
+ if not tool:hasprefix('cat') then
+ man{'runtools/man/'..tool..'.8'}
+ end
+end
+
+man{
+ 'perp/man/perpetrate.5',
+ 'perp/man/perp_intro.8',
+ 'runtools/man/runtools_intro.8',
+}
+
+fetch 'curl'