## ints-millout.pkg
#
# Compiled by:
#
src/lib/x-kit/widget/xkit-widget.sublibstipulate
include package threadkit; # threadkit is from
src/lib/src/lib/thread-kit/src/core-thread-kit/threadkit.pkg #
package mt = millboss_types; # millboss_types is from
src/lib/x-kit/widget/edit/millboss-types.pkg# package im = int_red_black_map; # int_red_black_map is from
src/lib/src/int-red-black-map.pkg# package is = int_red_black_set; # int_red_black_set is from
src/lib/src/int-red-black-set.pkg package sm = string_map; # string_map is from
src/lib/src/string-map.pkg nb = log::note_on_stderr; # log is from
src/lib/std/src/log.pkgherein
package ints_millout #
{
Ints
=
{ units: Null_Or(String),
ints: sm::Map(Int)
};
Ints_Millout
=
{ note_watcher: (mt::Inport, Null_Or(mt::Millin), (mt::Outport, Ints) -> Void) -> Void, # Second arg will be NULL if watcher is not another mill (e.g. a pane).
drop_watcher: mt::Inport -> Void # The mt::Inport must match that given to note_watcher.
};
exception INTS_MILLOUT Ints_Millout; # We'll never 'raise' this exception: It is purely a datastructure to hide the Int_Millout type from millboss-imp.pkg, in the interests of good modularity.
#
#
fun maybe_unwrap__ints_millout (watchable: mt::Millout): Fail_Or( Ints_Millout )
=
case watchable.crypt
#
INTS_MILLOUT
ints_millout
=>
WORK ints_millout;
_ => FAIL (sprintf "maybe_unwrap__ints_millout: Unknown Millout value, port_type='%s', data_type='%s' info='%s' --ints-millout.pkg"
watchable.port_type
watchable.data_type
watchable.info
);
esac;
fun unwrap__ints_millout (watchable: mt::Millout): Ints_Millout
=
case watchable.crypt
#
INTS_MILLOUT
ints_millout
=>
ints_millout;
_ => { msg = (sprintf "maybe_unwrap__ints_millout: Unknown Millout value, port_type='%s', data_type='%s' info='%s' --ints-millout.pkg"
watchable.port_type
watchable.data_type
watchable.info
);
log::fatal msg; # Won't return.
raise exception DIE msg; # Just to keep compiler happy.
};
esac;
port_type = "ints_millout::Ints_Millout"; # Export so clients can use this value by reference instead of duplication (with attendant maintenance issues).
fun wrap__ints_millout
(
outport: mt::Outport,
ints_millout: Ints_Millout
): mt::Millout
=
{ outport,
port_type,
data_type => "ints_millout::Ints",
info => "Wrapped by ints_millout::wrap__ints_millout.",
crypt => INTS_MILLOUT ints_millout,
counter => REF 0
};
};
end;