## strings-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 strings_millout #
{
Strings = sm::Map(String);
#
Strings_Millout
=
{ note_watcher: (mt::Inport, Null_Or(mt::Millin), (mt::Outport, Strings) -> 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 STRINGS_MILLOUT Strings_Millout; # We'll never 'raise' this exception: It is purely a datastructure to hide the String_Millout type from millboss-imp.pkg, in the interests of good modularity.
#
#
fun maybe_unwrap__strings_millout (watchable: mt::Millout): Fail_Or( Strings_Millout )
=
case watchable.crypt
#
STRINGS_MILLOUT
strings_millout
=>
WORK strings_millout;
_ => FAIL (sprintf "maybe_unwrap__strings_millout: Unknown Millout value, port_type='%s', data_type='%s' info='%s' --strings-millout.pkg"
watchable.port_type
watchable.data_type
watchable.info
);
esac;
fun unwrap__strings_millout (watchable: mt::Millout): Strings_Millout
=
case watchable.crypt
#
STRINGS_MILLOUT
strings_millout
=>
strings_millout;
_ => { msg = (sprintf "maybe_unwrap__strings_millout: Unknown Millout value, port_type='%s', data_type='%s' info='%s' --strings-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 = "strings_millout::Strings_Millout"; # Export so clients can use this value by reference instead of duplication (with attendant maintenance issues).
fun wrap__strings_millout
(
outport: mt::Outport,
strings_millout: Strings_Millout
): mt::Millout
=
{ outport,
port_type,
data_type => "strings_millout::Strings",
info => "Wrapped by strings_millout::wrap__strings_millout.",
crypt => STRINGS_MILLOUT strings_millout,
counter => REF 0
};
};
end;