Home My Page Projects Code Snippets Project Openings SML/NJ
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files

SCM Repository

[smlnj] View of /smlnj-lib/releases/release-110.63/Controls/controls.sml
ViewVC logotype

View of /smlnj-lib/releases/release-110.63/Controls/controls.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2371 - (download) (annotate)
Thu Mar 22 21:07:48 2007 UTC (13 years, 7 months ago) by blume
File size: 1717 byte(s)
Release 110.63
(* controls.sml
 *
 * COPYRIGHT (c) 2002 Bell Labs, Lucent Technologies
 *)

structure Controls : CONTROLS =
  struct

    open ControlReps

    fun control {name, pri, obscurity, help, ctl} = Ctl{
	    name = Atom.atom name,
	    get = fn () => !ctl,
	    set = fn SOME v => (fn () => ctl := v)
		   | NONE => let val v = !ctl in fn () => ctl := v end,
	    priority = pri,
	    obscurity = obscurity,
	    help = help
	  }

    fun genControl {name, pri, obscurity, help, default} = control {
	    name = name, pri = pri, obscurity = obscurity, help = help,
	    ctl = ref default
	  }

  (* this exception is raised to communicate that there is a syntax error
   * in a string representation of a control value.
   *)
    exception ValueSyntax of {tyName : string, ctlName : string, value : string}

    fun stringControl {tyName, fromString, toString} (Ctl c) =
	let val {name, get, set, priority, obscurity, help} = c
	    fun fromString' s =
		case fromString s of
		    NONE => raise ValueSyntax { tyName = tyName,
						ctlName = Atom.toString name,
						value = s }
		  | SOME v => v
	in
	    Ctl { name = name,
		  get = toString o get,
		  set = set o Option.map fromString',
		  priority = priority,
		  obscurity = obscurity,
		  help = help }
	end

    fun name (Ctl{name, ...}) = Atom.toString name
    fun get (Ctl{get, ...}) = get()
    fun set (Ctl{set, ...}, v) = set (SOME v) ()
    fun set' (Ctl{set, ...}, v) = set (SOME v)
    fun info (Ctl{priority, obscurity, help, ...}) =
	{ priority = priority, obscurity = obscurity, help = help }

    fun save'restore (Ctl{set,...}) = set NONE

    fun compare (Ctl{priority=p1, ...}, Ctl{priority=p2, ...}) =
	List.collate Int.compare (p1, p2)

  end

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0