]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/scm-hash.hh
release: 1.3.92
[lilypond.git] / lily / include / scm-hash.hh
index ca63614042e65b3e00664aaab14fba186d57d203..a19ed279e777a8b415063979328fbd1cd6fe2eaf 100644 (file)
@@ -14,7 +14,6 @@
 #include <map>
 
 #include "lily-guile.hh"
-#include "hash-table.hh"
 #include "smobs.hh"
 
 
@@ -29,7 +28,34 @@ struct SCM_less
 typedef map<SCM,SCM, SCM_less> Scm_stl_map;
 
 /**
-   auto resizing hash table. This should come from GUILE.
+   auto resizing hash table. 
+
+   1. ALWAYS USE THIS AS VIA A POINTER, i.e.
+
+   class Foo {
+    Scheme_hash_table * tab;
+   };
+
+   and NOT
+
+   class Foo {
+    Scheme_hash_table tab;
+   }
+
+
+   2. UPON DESTRUCTION, DO
+
+   scm_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.
+   
  */
 class Scheme_hash_table :  private Scm_stl_map
 {
@@ -46,9 +72,9 @@ public:
   Scheme_hash_table ();
   void operator = (Scheme_hash_table const &); 
   Scheme_hash_table (Scheme_hash_table const &);
-  virtual ~Scheme_hash_table ();
-  DECLARE_SMOBS;
+
   SCM to_alist () const;
+  DECLARE_SMOBS(Scheme_hash_table,foo);
 };
 
 #endif /* SCM_HASH_HH */