X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fcontext.hh;h=8b464f7175b95a7afd1009c423ba15ca4576dfdd;hb=d98ccb8e9a3793207cacd4b83d6034458299bb88;hp=fd3c75b3f0f5daa28ca22def92188c1bcc8bf319;hpb=0c5bcc9f980e3dc40b53543a957bbf353d7c2308;p=lilypond.git diff --git a/lily/include/context.hh b/lily/include/context.hh index fd3c75b3f0..8b464f7175 100644 --- a/lily/include/context.hh +++ b/lily/include/context.hh @@ -1,18 +1,30 @@ /* - context.hh -- declare Context + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 2004--2009 Han-Wen Nienhuys - (c) 2004--2006 Han-Wen Nienhuys + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . */ #ifndef CONTEXT_HH #define CONTEXT_HH -#include "context-key-manager.hh" +#include "duration.hh" #include "lily-proto.hh" #include "listener.hh" #include "moment.hh" +#include "scm-hash.hh" #include "std-vector.hh" #include "virtual-methods.hh" @@ -21,7 +33,7 @@ class Context Scheme_hash_table *properties_dict () const; Context (Context const &src); - DECLARE_SMOBS (Context, dummy); + DECLARE_SMOBS (Context); DECLARE_CLASSNAME(Context); void terminate (); @@ -38,7 +50,6 @@ protected: SCM definition_; /* Additions to the Context_def, given by \with */ SCM definition_mods_; - Context_key_manager key_manager_; SCM properties_scm_; SCM context_list_; @@ -60,15 +71,11 @@ protected: friend class Context_def; // UGH! initialises implementation_ friend SCM ly_make_global_translator (SCM); - void clear_key_disambiguations (); DECLARE_LISTENER (set_property_from_event); DECLARE_LISTENER (unset_property_from_event); public: - Object_key const *get_grob_key (string name); - Object_key const *get_context_key (string name, string id); - string id_string () const { return id_string_; } SCM children_contexts () const { return context_list_; } SCM default_child_context_name () const; @@ -82,7 +89,7 @@ public: Translator_group *implementation () const { return implementation_; } Context *get_parent_context () const; - Context (Object_key const *); + Context (); /* properties: */ SCM internal_get_property (SCM name_sym) const; @@ -90,11 +97,8 @@ public: Context *where_defined (SCM name_sym, SCM *value) const; void unset_property (SCM var_sym); -#ifndef NDEBUG - void internal_set_property (SCM var_sym, SCM value, char const *file, int line, char const *fun); -#else + void instrumented_set_property (SCM, SCM, const char*, int, const char*); void internal_set_property (SCM var_sym, SCM value); -#endif Context *create_context (Context_def *, string, SCM); DECLARE_LISTENER (create_context_from_event); @@ -122,8 +126,7 @@ public: string id, SCM ops); Context *create_unique_context (SCM context_name, string context_id, SCM ops); - vector path_to_acceptable_context (SCM alias, - Output_def *) const; + vector path_to_acceptable_context (SCM alias) const; }; /* @@ -131,8 +134,11 @@ public: */ void apply_property_operations (Context *tg, SCM pre_init_ops); +void execute_revert_property (Context *context, + SCM context_property, + SCM grob_property_path); void execute_pushpop_property (Context *trg, SCM prop, SCM eltprop, SCM val); -void execute_general_pushpop_property (Context *context, +void sloppy_general_pushpop_property (Context *context, SCM context_property, SCM grob_property_path, SCM val); SCM updated_grob_properties (Context *tg, SCM sym); Context *find_context_below (Context *where, @@ -145,7 +151,9 @@ Grob *get_current_rest (Context *voice); DECLARE_UNSMOB (Context, context); Moment measure_position (Context const *context); +Moment measure_position (Context const *context, Duration const *dur); Rational measure_length (Context const *context); +int measure_number (Context const *context); void set_context_property_on_children (Context *trans, SCM sym, SCM val); /* Shorthand for creating and broadcasting stream events. */ @@ -155,5 +163,9 @@ void set_context_property_on_children (Context *trans, SCM sym, SCM val); ctx->internal_send_stream_event (ly_symbol2scm (type), origin, props); \ } +SCM nested_property_alist (SCM alist, SCM prop_path, SCM value); +SCM nested_property_revert_alist (SCM alist, SCM prop_path); +SCM evict_from_alist (SCM, SCM, SCM); + #endif /* CONTEXT_HH */