code: purgatorio

ref: a8083462e62459b2ae8a243dc4ba88416eba03b1
dir: /module/fslib.m/

View raw version
Fslib: module {
	PATH: con "/dis/lib/fslib.dis";
	Value: adt {
		x:	fn(v: self ref Value): ref Value.X;
		p:	fn(v: self ref Value): ref Value.P;
		s:	fn(v: self ref Value): ref Value.S;
		c:	fn(v: self ref Value): ref Value.C;
		t:	fn(v: self ref Value): ref Value.T;
		v:	fn(v: self ref Value): ref Value.V;
		m:	fn(v: self ref Value): ref Value.M;
		typec: fn(v: self ref Value): int;
		discard: fn(v: self ref Value);
		pick {
		X =>
			i: Fschan;
		T =>
			i: Entrychan;
		P =>
			i: Gatechan;
		C =>
			i: ref Sh->Cmd;
		S =>
			i: string;
		V =>
			i: chan of int;		# sync channel for void-valued processes
		M =>
			i: Cmpchan;
		}
	};
	init:			fn();
	typecompat:	fn(t, act: string): int;
	sendnulldir:	fn(c: Fschan): int;
	quit:			fn(errorc: chan of string);
	report:		fn(errorc: chan of string, err: string);
	copy:		fn(src, dst: Fschan): int;

	cmdusage:	fn(cmd, t: string): string;
	type2s:		fn(t: int): string;
	opttypes:		fn(opt: int, opts: string): (int, string);
	splittype:		fn(t: string): (int, string, string);

	Report: adt {

		reportc: chan of string;
		startc: chan of (string, chan of string);
		enablec: chan of int;
	
		new:		fn(): ref Report;
		enable:	fn(r: self ref Report);
		start:		fn(r: self ref Report, name: string): chan of string;
	};
	Option: adt {
		opt: int;
		args: list of ref Value;
	};
	Entrychan: adt {
		sync: chan of int;
		c: chan of Entry;
	};
	Cmpchan: type chan of (ref Sys->Dir, ref Sys->Dir, chan of int);
	Entry: type (ref Sys->Dir, string, int);
	Gatequery: type (Entry, chan of int);
	Gatechan: type chan of Gatequery;
	Fsdata: adt {
		dir: ref Sys->Dir;
		data: array of byte;
	};
	Fschan: type chan of (Fsdata, chan of int);
	Next, Down, Skip, Quit: con iota;

	Nilentry: con (nil, nil, 0);
};

Fsmodule: module {
	types: fn(): string;
	init:	fn();
	run: fn(ctxt: ref Draw->Context, r: ref Fslib->Report,
		opts: list of Fslib->Option, args: list of ref Fslib->Value): ref Fslib->Value;
};

Fsfilter: module {
	PATH: con "/dis/lib/fsfilter.dis";
	filter: fn[T](t: T, src, dst: Fslib->Fschan)
		for{
		T =>
			query: fn(t: self T, d: ref Sys->Dir, name: string, depth: int): int;
		};
};