<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>

<head>
<meta http-equiv="Content-Type"
content="text/html; charset=iso-8859-1">
<meta name="GENERATOR" content="Microsoft FrontPage 2.0">
<title>Class DS_TABLE</title>
</head>

<body bgcolor="#FFFFFF">

<table border="0" width="100%">
    <tr>
        <td><font size="6"><strong>Class DS_TABLE</strong></font></td>
        <td align="right"><a href="ds_stack.html"><img
        src="../../image/previous.gif" alt="Previous" border="0"
        width="40" height="40"></a><a href="ds_traversable.html"><img
        src="../../image/next.gif" alt="Next" border="0"
        width="40" height="40"></a></td>
    </tr>
</table>

<hr size="1">

<pre><font color="#000080"><em><strong>note</strong></em></font></pre>

<blockquote>
    <pre><em>description</em>:

<font color="#800000"><em>    &quot;Data structures whose items are accessible through keys&quot;

</em></font><em>library:    </em><font color="#800000"><em>&quot;Gobo Eiffel Structure Library&quot;
</em></font><em>author:     </em><font color="#800000"><em>&quot;Eric Bezault &lt;</em></font><a
href="mailto:ericb@gobosoft.com"><font color="#800000"><em>ericb@gobosoft.com</em></font></a><font
color="#800000"><em>&gt;&quot;
</em></font><em>copyright:  </em><font color="#800000"><em>&quot;Copyright (c) 2000-2001, Eric Bezault and others&quot;
</em></font><em>license:   </em><font color="#800000"><em> &quot;MIT License&quot;</em></font></pre>
</blockquote>

<pre><font color="#000080"><em><strong>deferred class interface</strong></em></font></pre>

<blockquote>
    <pre><em>DS_TABLE </em>[<em>G</em>, <em>K</em>]</pre>
</blockquote>

<pre><font color="#000080"><em><strong>inherit</strong></em></font></pre>

<blockquote>
    <pre><a href="ds_container.html"><em>DS_CONTAINER</em></a><em> </em>[<em>G</em>]</pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature</strong></em></font><em> </em>{<em>NONE</em>}<font
color="#008000"> -- Initialization</font></pre>

<blockquote>
    <pre><a name="make_default"><em>make_default</em></a><em>
</em><font color="#008000">        -- Create an empty container.</font><em>
</em><font color="#008000">        -- (From </font><a
href="ds_container.html#make_default"><font color="#008000"><em>DS_CONTAINER</em></font></a><font
color="#008000">.)</font><em>
</em><font color="#000080"><em><strong>    deferred</strong></em></font><em>
    </em><font color="#000080"><em><strong>ensure</strong></em></font><em>
        empty</em>:<em> </em><a href="#is_empty"><em>is_empty</em></a></pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature </strong></em></font><font
color="#008000">-- Access</font></pre>

<blockquote>
    <pre><a name="infix_at"><font color="#000080"><em><strong>infix</strong></em></font><em> </em><font
color="#800000"><em>&quot;@&quot;</em></font></a>,<em> </em><a
name="item"><em>item</em></a><em> </em>(<em>k</em>:<em> K</em>):<em> G
        </em><font color="#008000">-- Item associated with </font><em>k
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        has_k</em>:<em> </em><a href="#has"><em>has</em></a><em> </em>(<em>k</em>)<em>
    </em><font color="#000080"><em><strong>deferred</strong></em></font></pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature</strong></em></font><font
color="#008000"> -- Measurement</font></pre>

<blockquote>
    <pre><a name="count"><em>count</em></a>:<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/integer.html"><em>INTEGER</em></a><font
color="#000080"><em><strong>
        </strong></em></font><font color="#008000">-- Number of items in container
        -- (From </font><a href="ds_container.html#count"><font
color="#008000"><em>DS_CONTAINER</em></font></a><font
color="#008000">.)</font><font color="#000080"><em><strong>
    deferred</strong></em></font></pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature</strong></em></font><font
color="#008000"> -- Status report</font></pre>

<blockquote>
    <pre><a name="is_empty"><em>is_empty</em></a>:<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/boolean.html"><em>BOOLEAN</em></a><font
color="#000080"><em><strong>
       </strong></em></font><font color="#008000"> -- Is container empty?
        -- (From </font><a href="ds_container.html#is_empty"><font
color="#008000"><em>DS_CONTAINER</em></font></a><font
color="#008000">.)</font></pre>
    <pre><a name="valid_key"><em>valid_key</em></a><em> </em>(<em>k</em>:<em> K</em>):<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/boolean.html"><em>BOOLEAN</em></a><em>
        </em><font color="#008000">-- Is </font><em>k</em><font
color="#008000"> a valid key?</font><em>
    </em><font color="#000080"><em><strong>deferred</strong></em></font></pre>
    <pre><a name="has"><em>has</em></a><em> </em>(<em>k</em>:<em> K</em>):<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/boolean.html"><em>BOOLEAN</em></a><em>
</em><font color="#008000">        -- Is there an item associated with </font><em>k</em><font
color="#008000">?</font><em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        valid_key</em>:<em> </em><font color="#008080"><em>Result</em></font><em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em><a
href="#valid_key"><em>valid_key</em></a><em> </em>(<em>k</em>)</pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature</strong></em></font><font
color="#008000"> -- Comparison</font></pre>

<blockquote>
    <pre><a name="is_equal"><em>is_equal</em></a><em> </em>(<em>other</em>:<em> </em><font
color="#000080"><em><strong>like</strong></em></font><em> </em><font
color="#008080"><em>Current</em></font><em>)</em>:<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/boolean.html"><em>BOOLEAN</em></a><em>
        </em><font color="#008000">-- Is current container equal to </font><em>other</em><font
color="#008000">?</font><em>
        </em><font color="#008000">-- (From </font><a
href="http://www.gobosoft.com/eiffel/nice/elks95/general.html#is_equal"><font
color="#008000"><em>GENERAL</em></font></a><font color="#008000">.)</font><em>
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        other_not_void</em>:<em> other </em>/=<em> </em><font
color="#008080"><em>Void</em></font><em>
    </em><font color="#000080"><em><strong>deferred</strong></em></font><em>
    </em><font color="#000080"><em><strong>ensure</strong></em></font><em>
        consistent</em>:<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/general.html#standard_is_equal"><em>standard_is_equal</em></a><em> </em>(<em>other</em>)<em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em><font
color="#008080"><em>Result</em></font><em>
        same_type</em>:<em> </em><font color="#008080"><em>Result</em></font><em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/general.html#same_type"><em>same_type</em></a><em> </em>(<em>other</em>)<em>
        symmetric</em>:<em> </em><font color="#008080"><em>Result</em></font><em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> other</em>.<a
href="#is_equal"><em>is_equal</em></a><em> </em>(<font
color="#008080"><em>Current</em></font>)<em>
        same_count</em>:<em> </em><font color="#008080"><em>Result</em></font><em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> count </em>=<em> other</em>.<a
href="#count"><em>count</em></a></pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature</strong></em></font> <font
color="#008000">-- Duplication</font></pre>

<blockquote>
    <pre><a name="copy"><em>copy</em></a><em> </em>(<em>other</em>:<em> </em><font
color="#000080"><em><strong>like</strong></em></font><em> </em><font
color="#008080"><em>Current</em></font>)<em>
        </em><font color="#008000">-- Copy </font><em>other</em><font
color="#008000"> to current container.
        -- (From </font><a
href="http://www.gobosoft.com/eiffel/nice/elks95/general.html#copy"><font
color="#008000"><em>GENERAL</em></font></a><font color="#008000">.)</font><em>
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        other_not_void</em>:<em> other </em>/= <font
color="#008080"><em>Void</em></font><em>
        type_identity</em>:<em> </em><a
href="http://www.gobosoft.com/eiffel/nice/elks95/general.html#same_type"><em>same_type</em></a><em> </em>(<em>other</em>)<em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        is_equal</em>:<em> </em><a href="#is_equal"><em>is_equal</em></a><em> </em>(<em>other</em>)</pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature </strong></em></font><font
color="#008000">-- Element change</font></pre>

<blockquote>
    <pre><a name="replace"><em>replace</em></a><em> </em>(<em>v</em>:<em> G</em>;<em> k</em>:<em> K</em>)<em>
        </em><font color="#008000">-- Replace item associated with </font><em>k</em><font
color="#008000"> by </font><em>v</em><font color="#008000">.</font><em>
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        has_k</em>:<em> </em><a href="#has"><em>has</em></a><em> </em>(<em>k</em>)<em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        replaced</em>:<em> </em><a href="#item"><em>item</em></a><em> </em>(<em>k</em>) =<em> v
        same_count</em>:<em> </em><a href="#count"><em>count</em></a><em> </em>= <font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a></pre>
    <pre><a name="put"><em>put</em></a><em> </em>(<em>v</em>:<em> G</em>;<em> k</em>:<em> K</em>)<em>
        </em><font color="#008000">-- Associate </font><em>v</em><font
color="#008000"> with key </font><em>k</em><font color="#008000">.</font><em>
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        valid_key</em>:<em> </em><a href="#valid_key"><em>valid_key</em></a><em> </em>(<em>k</em>)<em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        inserted</em>:<em> </em><a href="#has"><em>has</em></a><em> </em>(<em>k</em>)<em> </em><font
color="#000080"><em><strong>and then</strong></em></font><em> </em><a
href="#item"><em>item</em></a><em> </em>(<em>k</em>) =<em> v
        same_count</em>: (<font color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#has"><em>has</em></a><em> </em>(<em>k</em>))<em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em>(<a
href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a>)<em>
        one_more</em>: (<font color="#000080"><em><strong>not old</strong></em></font><em> </em><a
href="#has"><em>has</em></a><em> </em>(<em>k</em>))<em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em>(<a
href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a><em> </em>+<em> </em><font
color="#808000"><em>1</em></font>)</pre>
    <pre><a name="put_new"><em>put_new</em></a> (<em>v</em>: <em>G</em>; <em>k</em>: <em>K</em>)
        <font color="#008000">-- Associate </font><em>v</em><font
color="#008000"> with key </font><em>k</em><font color="#008000">.
</font><em>    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        valid_key</em>:<em> </em><a href="#valid_key"><em>valid_key</em></a><em> </em>(<em>k</em>)<em>
        new_item</em>: <font color="#000080"><em><strong>not</strong></em></font> <a
href="#has"><em>has</em></a><em> </em>(<em>k</em>)<em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        one_more</em>: <a href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a><em> </em>+<em> </em><font
color="#808000"><em>1</em></font>
<em>        inserted</em>:<em> </em><a href="#has"><em>has</em></a><em> </em>(<em>k</em>)<em> </em><font
color="#000080"><em><strong>and then</strong></em></font><em> </em><a
href="#item"><em>item</em></a><em> </em>(<em>k</em>) =<em> v</em></pre>
    <pre><a name="swap"><em>swap</em></a><em> </em>(<em>k</em>,<em> l</em>:<em> K</em>)<em>
        </em><font color="#008000">-- Exchange items associated with </font><em>k</em><font
color="#008000"> and </font><em>l</em><font color="#008000">.</font><em>
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        valid_k</em>:<em> </em><a href="#has"><em>has</em></a><em> </em>(<em>k</em>)<em>
        valid_l</em>:<em> </em><a href="#has"><em>has</em></a><em> </em>(<em>l</em>)<em>
    </em><font color="#000080"><em><strong>ensure</strong></em></font><em>
        same_count</em>:<em> </em><a href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a><em>
        new_k</em>:<em> </em><a href="#item"><em>item</em></a><em> </em>(<em>k</em>) =<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#item"><em>item</em></a><em> </em>(<em>l</em>)<em>
        new_l</em>:<em> </em><a href="#item"><em>item</em></a><em> </em>(<em>l</em>) =<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#item"><em>item</em></a><em> </em>(<em>k</em>)</pre>
</blockquote>

<pre><font color="#000080"><em><strong>feature</strong></em></font><font
color="#008000"> -- Removal</font></pre>

<blockquote>
    <pre><a name="remove"><em>remove</em></a><em> </em>(<em>k</em>:<em> K</em>)<em>
        </em><font color="#008000">-- Remove item associated with </font><em>k</em><font
color="#008000">.</font><em>
    </em><font color="#000080"><em><strong>require</strong></em></font><em>
        valid_key</em>:<em> </em><a href="#valid_key"><em>valid_key</em></a><em> </em>(<em>k</em>)<em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        same_count</em>:<em> </em>(<font color="#000080"><em><strong>not old</strong></em></font><em> </em><a
href="#has"><em>has</em></a><em> </em>(<em>k</em>))<em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em>(<a
href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a>)<em>
        one_less</em>:<em> </em>(<font color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#has"><em>has</em></a><em> </em>(<em>k</em>))<em> </em><font
color="#000080"><em><strong>implies</strong></em></font><em> </em>(<a
href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#000080"><em><strong>old</strong></em></font><em> </em><a
href="#count"><em>count</em></a><em> </em>- <font color="#808000"><em>1</em></font>)<em>
        removed</em>:<em> </em><font color="#000080"><em><strong>not</strong></em></font><em> </em><a
href="#has"><em>has</em></a><em> </em>(<em>k</em>)</pre>
    <pre><a name="wipe_out"><em>wipe_out</em></a><em>
        </em><font color="#008000">-- Remove all items from container.
        -- (From </font><a href="ds_container.html#wipe_out"><font
color="#008000"><em>DS_CONTAINER</em></font></a><font
color="#008000">.)</font><em>
    </em><font color="#000080"><em><strong>deferred
    ensure</strong></em></font><em>
        wiped_out</em>:<em> </em><a href="#is_empty"><em>is_empty</em></a></pre>
</blockquote>

<pre><a name="invariant"><font color="#000080"><em><strong>invariant</strong></em></font></a></pre>

<blockquote>
    <pre><em>positive_count</em>:<em> </em><a href="#count"><em>count</em></a><em> </em>&gt;=<em> </em><font
color="#808000"><em>0</em></font><em>
empty_definition</em>:<em> </em><a href="#is_empty"><em>is_empty</em></a><em> </em>= (<a
href="#count"><em>count</em></a><em> </em>=<em> </em><font
color="#808000"><em>0</em></font>)
    <font color="#008000">-- (From </font><a
href="ds_container.html#invariant"><font color="#008000"><em>DS_CONTAINER</em></font></a><font
color="#008000">.)</font></pre>
</blockquote>

<pre><font color="#000080"><em><strong>end</strong></em></font><font
color="#008000"> -- class DS_TABLE</font></pre>

<hr size="1">

<table border="0" width="100%">
    <tr>
        <td><address>
            <font size="2"><b>Copyright © 2000-2001</b></font><font
            size="1"><b>, </b></font><font size="2"><strong>Eric
            Bezault</strong></font><strong> </strong><font
            size="2"><br>
            <strong>mailto:</strong></font><a
            href="mailto:ericb@gobosoft.com"><font size="2">ericb@gobosoft.com</font></a><font
            size="2"><br>
            <strong>http:</strong></font><a
            href="http://www.gobosoft.com"><font size="2">//www.gobosoft.com</font></a><font
            size="2"><br>
            <strong>Last Updated:</strong> 31 March 2001</font><br>
            <!--webbot bot="PurpleText"
            preview="
$Date$
$Revision$"
            -->
        </address>
        </td>
        <td align="right" valign="top"><a
        href="http://www.gobosoft.com"><img
        src="../../image/home.gif" alt="Home" border="0"
        width="40" height="40"></a><a href="index.html"><img
        src="../../image/toc.gif" alt="Toc" border="0" width="40"
        height="40"></a><a href="ds_stack.html"><img
        src="../../image/previous.gif" alt="Previous" border="0"
        width="40" height="40"></a><a href="ds_traversable.html"><img
        src="../../image/next.gif" alt="Next" border="0"
        width="40" height="40"></a></td>
    </tr>
</table>
</body>
</html>
