X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fcontext.hh;h=dc13314277be9541b4f9ceac41084edbc00b7cf5;hb=47db9a3883d726ca53e2133a3b2298f78dd6a32e;hp=5543235c25d4b668d2140300697bcb2914a68799;hpb=233fb6a8b3b6e31de1841641dbbd4c4f43423151;p=lilypond.git diff --git a/lily/include/context.hh b/lily/include/context.hh index 5543235c25..dc13314277 100644 --- a/lily/include/context.hh +++ b/lily/include/context.hh @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 2004--2012 Han-Wen Nienhuys + Copyright (C) 2004--2015 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 @@ -28,12 +28,17 @@ #include "std-vector.hh" #include "virtual-methods.hh" -class Context +class Context : public Smob { +public: + SCM mark_smob (); + int print_smob (SCM, scm_print_state *); + static const char type_p_name_[]; + virtual ~Context (); +private: Scheme_hash_table *properties_dict () const; - Context (Context const &src); + Context (Context const &src); // Do not define! Not copyable! - DECLARE_SMOBS (Context); DECLARE_CLASSNAME (Context); void terminate (); @@ -55,6 +60,7 @@ protected: SCM properties_scm_; SCM context_list_; SCM accepts_list_; + SCM default_child_; SCM aliases_; Translator_group *implementation_; string id_string_; @@ -96,12 +102,13 @@ public: SCM internal_get_property (SCM name_sym) const; SCM properties_as_alist () const; Context *where_defined (SCM name_sym, SCM *value) const; + bool here_defined (SCM name_sym, SCM *value) const; void unset_property (SCM var_sym); void instrumented_set_property (SCM, SCM, const char *, int, const char *); void internal_set_property (SCM var_sym, SCM value); - Context *create_context (Context_def *, string, SCM); + Context *create_context (Context_def *, const string&, SCM); DECLARE_LISTENER (create_context_from_event); DECLARE_LISTENER (acknowledge_infant); DECLARE_LISTENER (remove_context); @@ -115,14 +122,7 @@ public: virtual Context *get_score_context () const; virtual Output_def *get_output_def () const; virtual Moment now_mom () const; - virtual Context *get_default_interpreter (string context_id = ""); - - // It would make some sense to have the following just available in - // a global context. It would be decidedly tricky, however, to have - // it initialized before the constructor of its Context base class - // was able to trigger garbage collection. - SCM ancestor_lookup_; - SCM make_event_class (SCM); + virtual Context *get_default_interpreter (const string &context_id = ""); bool is_alias (SCM) const; void add_alias (SCM); @@ -131,8 +131,8 @@ public: bool is_removable () const; Context *find_create_context (SCM context_name, - string id, SCM ops); - Context *create_unique_context (SCM context_name, string context_id, + const string &id, SCM ops); + Context *create_unique_context (SCM context_name, const string &context_id, SCM ops); vector path_to_acceptable_context (SCM alias) const; }; @@ -142,21 +142,15 @@ 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 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, - SCM type_sym, string id); + SCM type_sym, const string &id); bool melisma_busy (Context *); Context *get_voice_to_lyrics (Context *lyrics); -Grob *get_current_note_head (Context *voice, bool include_grace_notes); +Grob *get_current_note_head (Context *voice); 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); @@ -175,7 +169,9 @@ void set_context_property_on_children (Context *trans, SCM sym, SCM val); } SCM nested_property_alist (SCM alist, SCM prop_path, SCM value); -SCM nested_property_revert_alist (SCM alist, SCM prop_path); +SCM nested_create_alist (SCM prop_path, SCM value); +SCM partial_list_copy (SCM alist, SCM tail, SCM newtail); SCM evict_from_alist (SCM, SCM, SCM); +SCM nalist_to_alist (SCM nalist, int nested); #endif /* CONTEXT_HH */