]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/context-def.hh
Run `make grand-replace'.
[lilypond.git] / lily / include / context-def.hh
index 744cd1f8ac22b05fd7eba46b61921bee0af3726b..bceb123ee2d06f016d981fbd4de09683f02512d1 100644 (file)
@@ -1,24 +1,27 @@
-/*   
+/*
   context-def.hh -- declare Context_def
-  
+
   source file of the GNU LilyPond music typesetter
-  
-  (c) 2000--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+
+  (c) 2000--2008 Han-Wen Nienhuys <hanwen@xs4all.nl>
+*/
 
 #ifndef CONTEXT_DEF_HH
 #define CONTEXT_DEF_HH
 
+#include "std-vector.hh"
 #include "lily-proto.hh"
 #include "smobs.hh"
 #include "input.hh"
+#include "virtual-methods.hh"
+#include <set>
+
 
 /*
   The definition of a interpretation context as given in the
   input. The lists are stored in order of definition.
 */
-struct Context_def : public Input
+struct Context_def
 {
 private:
   /*
@@ -31,30 +34,39 @@ private:
   SCM context_name_;
   SCM context_aliases_;
   SCM translator_group_type_;
-  
+  SCM default_child_;
+  SCM input_location_;
 public:
+  Input *origin () const;
   void add_context_mod (SCM);
-  SCM default_child_context_name ();
-  SCM get_context_name () const;
-  SCM get_accepted (SCM) const;
+  SCM get_default_child (SCM user_mods) const;
+  SCM get_context_name () const { return context_name_; }
+  SCM get_accepted (SCM user_mods) const;
   SCM get_property_ops () const { return property_ops_; }
   SCM get_translator_names (SCM) const;
+  SCM get_translator_group_type () const { return translator_group_type_; }
   void set_acceptor (SCM accepts, bool add);
 
-  Link_array<Context_def> path_to_acceptable_context (SCM type_string,
-                                                     Output_def*) const;
-  Context * instantiate (SCM extra_ops, Object_key const*);
+  VIRTUAL_COPY_CONSTRUCTOR(Context_def, Context_def);
+
+  vector<Context_def*> path_to_acceptable_context (SCM type_string,
+                                                  Output_def *,
+                                                  SCM) const;
+  vector<Context_def*> internal_path_to_acceptable_context (SCM type_string,
+                                                           Output_def *,
+                                                           SCM,
+                                                           set<const Context_def *> *seen) const;
+  Context *instantiate (SCM extra_ops);
 
   SCM to_alist () const;
   static SCM make_scm ();
 
-  SCM clone_scm () const;
-  void apply_default_property_operations (Context*);
+  void apply_default_property_operations (Context *);
 
 private:
-  DECLARE_SMOBS (Context_def, foo);
+  DECLARE_SMOBS (Context_def);
   Context_def ();
-  Context_def (Context_def const&);
+  Context_def (Context_def const &);
 };
 
 DECLARE_UNSMOB (Context_def, context_def);