X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fcontext-def.hh;h=dd4df4c802061b355fe7ae44b2c104b20c67753a;hb=f9214bac21e9926dc3248416f58190c98c4167a9;hp=df69f257dd6f1a62bfec6ab46a2901bc22cbb087;hpb=b3cf2199183a184c7eef9a9f8f3c9a691db1f0ad;p=lilypond.git diff --git a/lily/include/context-def.hh b/lily/include/context-def.hh index df69f257dd..dd4df4c802 100644 --- a/lily/include/context-def.hh +++ b/lily/include/context-def.hh @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 2000--2006 Han-Wen Nienhuys + (c) 2000--2007 Han-Wen Nienhuys */ #ifndef CONTEXT_DEF_HH @@ -13,12 +13,14 @@ #include "lily-proto.hh" #include "smobs.hh" #include "input.hh" +#include "virtual-methods.hh" + /* 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: /* @@ -32,8 +34,9 @@ private: SCM context_aliases_; SCM translator_group_type_; SCM default_child_; - + SCM input_location_; public: + Input *origin () const; void add_context_mod (SCM); SCM get_default_child (SCM user_mods) const; SCM get_context_name () const { return context_name_; } @@ -43,18 +46,19 @@ public: SCM get_translator_group_type () const { return translator_group_type_; } void set_acceptor (SCM accepts, bool add); + VIRTUAL_COPY_CONSTRUCTOR(Context_def, Context_def); + vector path_to_acceptable_context (SCM type_string, Output_def *) const; - Context *instantiate (SCM extra_ops, Object_key const *); + Context *instantiate (SCM extra_ops); SCM to_alist () const; static SCM make_scm (); - SCM clone_scm () const; void apply_default_property_operations (Context *); private: - DECLARE_SMOBS (Context_def, foo); + DECLARE_SMOBS (Context_def); Context_def (); Context_def (Context_def const &); };