]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/scm-hash.hh
Merge branch 'master' of git+ssh://jneem@git.sv.gnu.org/srv/git/lilypond
[lilypond.git] / lily / include / scm-hash.hh
index ba13e2ef06188824637ca80068fdced953058350..6ced1f5e216e389a39f0cfed47939a8b342f00ac 100644 (file)
@@ -1,76 +1,61 @@
-/*   
+/*
   scm-hash.hh -- declare Scheme hasher.
-  
+
   source file of the GNU LilyPond music typesetter
-  
-  (c) 1999--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+
+  (c) 1999--2007 Han-Wen Nienhuys <hanwen@xs4all.nl>
+*/
 
 #ifndef SCM_HASH_HH
 #define SCM_HASH_HH
 
-
-#include "lily-guile.hh"
 #include "smobs.hh"
 
-
 /**
-   auto resizing hash table. 
+   auto resizing hash table.
 
    1. ALWAYS USE THIS AS VIA A POINTER, i.e.
 
    class Foo {
-    Scheme_hash_table * tab;
+   Scheme_hash_table * tab;
    };
 
    and NOT
 
    class Foo {
-    Scheme_hash_table tab;
+   Scheme_hash_table tab;
    }
 
 
    2. UPON DESTRUCTION, DO
 
    scm_gc_unprotect_object (tab->self_scm_);
-
-
-
-
-   TODO:
-
-  - This should come from GUILE. We're typically doing double work,
-   because KEY already is a symbol, and is looked up in a symbol
-   hashtable.
-
-  - use GUILE hashtables iso STL.
- */
+*/
 
 class Scheme_hash_table
-{  
+{
 public:
   bool try_retrieve (SCM key, SCM *val);
-  bool elem_b (SCM key) const;
+  bool contains (SCM key) const;
 
   /**
      WARNING: putting something in assumes responsibility for cleaning
      up.  */
   void set (SCM k, SCM v);
-  SCM get (SCM k) const; 
+  SCM get (SCM k) const;
   void remove (SCM k);
   Scheme_hash_table ();
-  void operator = (Scheme_hash_table const &); 
+  void operator = (Scheme_hash_table const &);
   Scheme_hash_table (Scheme_hash_table const &);
 
   SCM to_alist () const;
+
 private:
   SCM hash_tab_;
   unsigned elt_count_;
-  
-  DECLARE_SMOBS (Scheme_hash_table,foo);
-};
 
+  DECLARE_SMOBS (Scheme_hash_table);
+};
 
 #endif /* SCM_HASH_HH */