Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > d07d7ab417d79053e7e0155c99e1a1c8 > files > 2723

mlton-20100608-3.fc15.i686.rpm

<!-- queue.mldoc -->
<!-- Entities.sgml entry 
<!ENTITY Queue SDATA "queue-sig.sml">
 -->

<!DOCTYPE ML-DOC SYSTEM>

<COPYRIGHT OWNER="Bell Labs, Lucent Technologies" YEAR=1998>
<VERSION VERID="1.0" YEAR=1998 MONTH=5 DAY=14>
<TITLE>The Queue structure</TITLE>

<INTERFACE>
<HEAD>The <CD/Queue/ structure</HEAD>
<SEEALSO>
  <STRREF TOPID/Fifo/
</SEEALSO>

<PP>
The <STRREF NOLINK/Queue/ structure provides a simple implementation
of mutable queues.
The current implementation relies on the applicative queues defined
in <STRREF NOLINK/Fifo/, and therefore has similar performance.

<STRUCTURE STRID="Queue">
  <SIGBODY SIGID="QUEUE" FILE=QUEUE>
    <SPEC>
      <TYPE><TYPARAM>'a<ID>queue
    <SPEC>
      <EXN>Dequeue
    <SPEC>
      <VAL>mkQueue<TY>unit -> 'a queue
        <COMMENT>
          <PROTOTY>
          mkQueue <ARG/()/
          </PROTOTY>
          returns an empty queue.
    <SPEC>
      <VAL>clear<TY>'a queue -> unit
        <COMMENT>
          <PROTOTY>
          clear <ARG/qu/
          </PROTOTY>
          removes all the elements in <ARG/qu/.
    <SPEC>
      <VAL>isEmpty<TY>'a queue -> bool
        <COMMENT>
          <PROTOTY>
          isEmpty <ARG/qu/
          </PROTOTY>
          returns true if <ARG/qu/ is empty.
    <SPEC>
      <VAL>enqueue<TY>('a queue * 'a) -> unit
        <COMMENT>
          <PROTOTY>
          enqueue (<ARG/qu/, <ARG/a/)
          </PROTOTY>
          appends <ARG/a/ to the end of <ARG/qu/.
    <SPEC>
      <VAL>dequeue<TY>'a queue -> 'a
      <RAISES><EXNREF STRID="Queue"/Dequeue/
        <COMMENT>
          <PROTOTY>
          dequeue <ARG/qu/
          </PROTOTY>
          removes and returns the head element in <ARG/qu/.
          Raises the exception <EXNREF STRID="Queue"/Dequeue/
          if <ARG/qu/ is empty.
    <SPEC>
      <VAL>delete<TY>('a queue * ('a -> bool)) -> unit
        <COMMENT>
          <PROTOTY>
          delete (<ARG/qu/, <ARG/f/)
          </PROTOTY>
          deletes all elements in <ARG/qu/ satisfying the predicate <ARG/f/.
    <SPEC>
      <VAL>head<TY>'a queue -> 'a
      <RAISES><EXNREF STRID="Queue"/Dequeue/
        <COMMENT>
          <PROTOTY>
          head <ARG/qu/
          </PROTOTY>
          returns the head of <ARG/qu/ without removing it.
          Raises the exception <EXNREF STRID="Queue"/Dequeue/
          if <ARG/qu/ is empty.
    <SPEC>
      <VAL>peek<TY>'a queue -> 'a option
        <COMMENT>
          <PROTOTY>
          peek <ARG/qu/
          </PROTOTY>
          returns the head of <ARG/qu/ if it exists; otherwise, returns
          <CONREF STRID="Option" DOCUMENT=SML-BASIS-DOC/NONE/.
    <SPEC>
      <VAL>length<TY>'a queue -> int
        <COMMENT>
          <PROTOTY>
          length <ARG/qu/
          </PROTOTY>
          returns the number of elements in <ARG/qu/. At present, this
          is a linear time operation.
    <SPEC>
      <VAL>contents<TY>'a queue -> 'a list
        <COMMENT>
          <PROTOTY>
          contents <ARG/qu/
          </PROTOTY>
          returns the elements in <ARG/qu/ in queue order. This
          is a linear time operation.
    <SPEC>
      <VAL>app<TY>('a -> unit) -> 'a queue -> unit
        <COMMENT>
          <PROTOTY>
          app <ARG/f/ <ARG/qu/
          </PROTOTY>
          applies the function <ARG/f/ to the elements in <ARG/qu/ in
          queue order. This is equivalent to:
          <CODE>
            List.app f (contents qu)
          </CODE>
    <SPEC>
      <VAL>map<TY>('a -> 'b) -> 'a queue -> 'b queue
        <COMMENT>
          <PROTOTY>
          map <ARG/f/ <ARG/qu/
          </PROTOTY>
          creates a new queue by mapping the elements in <ARG/qu/ by
          <ARG/f/. This is equivalent to:
          <CODE>
            let
              val newq = mkQueue ()
            in
              app (fn v => enqueue(newq,f v)) qu;
              newq
            end
          </CODE>
    <SPEC>
      <VAL>foldl<TY>(('a * 'b) -> 'b) -> 'b -> 'a queue -> 'b
        <COMMENT>
          <PROTOTY>
          foldl <ARG/f/ <ARG/a/ <ARG/qu/
          </PROTOTY>
          folds the elements of the queue from the head to the tail.
           This is equivalent to:
          <CODE>
            List.foldl f a (contents qu))
          </CODE>
    <SPEC>
      <VAL>foldr<TY>(('a * 'b) -> 'b) -> 'b -> 'a queue -> 'b
        <COMMENT>
          <PROTOTY>
          foldr <ARG/f/ <ARG/a/ <ARG/qu/
          </PROTOTY>
          folds the elements of the queue from the tail to the head.
           This is equivalent to:
          <CODE>
            List.foldr f a (contents qu))
          </CODE>
</STRUCTURE>

</INTERFACE>