]> git.donarmstrong.com Git - lilypond.git/blob - lily/symtable.cc
release: 0.1.11
[lilypond.git] / lily / symtable.cc
1 /*
2   symtable.cc -- implement Symbol_table
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
7 */
8
9 #include "misc.hh"
10 #include "dimen.hh"
11 #include "debug.hh"
12 #include "real.hh"
13 #include "symbol.hh"
14 #include "assoc.hh"
15 #include "assoc-iter.hh"
16 #include "symtable.hh"
17
18 Symtables::Symtables()
19 {
20 }
21
22 Symtables::Symtables (Symtables const &s)
23 {
24   for (Assoc_iter<String, Symtable*>  i (s); i.ok(); i++) 
25     {
26       add (i.key(), new Symtable (*i.val ()));
27     }
28 }
29
30 Symtables::~Symtables()
31 {
32   for (Assoc_iter<String, Symtable*>  i (*this); i.ok(); i++) 
33     {
34       delete i.val();
35     }
36 }
37
38 Symbol 
39 Symtable::lookup (String s) const
40 {
41   if (elt_b (s))
42     return (*this)[s];
43   else 
44     {
45       warning ("Symtable `" + id_str+ "\': unknown symbol `" +s+"'\n");
46       Symbol sy;        
47       return sy;
48     }
49 }
50
51 Symtable* 
52 Symtables::operator()(String s) 
53 {
54   return Assoc<String, Symtable*>::operator[](s);
55
56 void
57 Symtables::print() const
58 {
59   for (Assoc_iter<String, Symtable*>  i (*this); i.ok(); i++) 
60     {
61       DOUT << "table \'" << i.key() << "\' {\n";
62       i.val()->print ();
63       DOUT << "}\n";
64     }
65 }
66 void
67 Symtable::print() const
68 {
69   for (Assoc_iter<String, Symbol>  i (*this); i.ok(); i++) 
70     {
71       DOUT << "\'" << i.key() << "\'->" << i.val ().str () << "\n";
72     }
73 }
74         
75 void
76 Symtables::add (String s, Symtable*p)
77 {
78   p-> id_str = s;
79   Assoc<String, Symtable*>::add (s,p);
80 }