PreviousUpNext

15.4.1427  src/lib/x-kit/widget/edit/strings-millout.pkg

## strings-millout.pkg
#

# Compiled by:
#     src/lib/x-kit/widget/xkit-widget.sublib


stipulate
    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.pkg
herein

    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;





Comments and suggestions to: bugs@mythryl.org

PreviousUpNext