#include <map>
#include "lily-guile.hh"
-#include "hash-table.hh"
#include "smobs.hh"
-#define usestl
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
{
public:
-#ifndef usestl
- // bool elem_b (SCM k) const;
- Hash_table<SCM,SCM>::try_retrieve;
- Hash_table<SCM,SCM>::elem_b;
-#else
bool try_retrieve (SCM key, SCM *val);
bool elem_b (SCM key) const;
-#endif
-
/**
WARNING: putting something in assumes responsibility for cleaning
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 */