X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fgrob.hh;h=5ca85402e0468d8cb21aee93488e206f835d2f03;hb=4a401ca1c60f428daa242dbdd102fdb3f327ebfb;hp=f80162efe536bb3c67f55e57ee9fef046140bd6c;hpb=b7a0cffbf9d1069860368f289a5b50e9d1d90ba8;p=lilypond.git diff --git a/lily/include/grob.hh b/lily/include/grob.hh index f80162efe5..5ca85402e0 100644 --- a/lily/include/grob.hh +++ b/lily/include/grob.hh @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 1996--2009 Han-Wen Nienhuys + Copyright (C) 1996--2011 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 @@ -29,8 +29,8 @@ class Grob { private: DECLARE_SMOBS (Grob); - DECLARE_CLASSNAME(Grob); - + DECLARE_CLASSNAME (Grob); + void init (); protected: @@ -43,13 +43,13 @@ protected: SCM immutable_property_alist_; SCM mutable_property_alist_; SCM object_alist_; - + /* If this is a property, it accounts for 25% of the property lookups. */ SCM interfaces_; - + void substitute_object_links (SCM, SCM); Real get_offset (Axis a) const; SCM try_callback (SCM, SCM); @@ -57,7 +57,7 @@ protected: void internal_set_value_on_alist (SCM *alist, SCM sym, SCM val); public: - + /* friends */ friend class Spanner; friend class System; @@ -75,7 +75,7 @@ public: Grob *original () const { return original_; } SCM interfaces () const { return interfaces_; } - /* life & death */ + /* life & death */ Grob (SCM basic_props); Grob (Grob const &); virtual Grob *clone () const; @@ -91,20 +91,22 @@ public: SCM get_property_alist_chain (SCM) const; SCM internal_get_property (SCM symbol) const; SCM internal_get_property_data (SCM symbol) const; + SCM internal_get_pure_property (SCM symbol, int start, int end) const; + SCM internal_get_maybe_pure_property (SCM symbol, bool pure, int start, int end) const; SCM internal_get_non_callback_marker_property_data (SCM symbol) const; SCM internal_get_object (SCM symbol) const; void internal_set_object (SCM sym, SCM val); void internal_del_property (SCM symbol); - void instrumented_set_property (SCM, SCM, char const*, int, char const*); + void instrumented_set_property (SCM, SCM, char const *, int, char const *); void internal_set_property (SCM sym, SCM val); - /* messages */ + /* messages */ void warning (string) const; void programming_error (string) const; - /* class hierarchy */ virtual System *get_system () const; + static System *get_system (Grob *); virtual void do_break_processing (); virtual Grob *find_broken_piece (System *) const; virtual void discretionary_processing (); @@ -118,7 +120,7 @@ public: /* interfaces */ bool internal_has_interface (SCM intf); - DECLARE_GROB_INTERFACE(); + DECLARE_GROB_INTERFACE (); /* offsets */ void translate_axis (Real, Axis); @@ -139,7 +141,9 @@ public: void fixup_refpoint (); virtual Interval_t spanned_rank_interval () const; + virtual bool pure_is_visible (int start, int end) const; bool check_cross_staff (Grob *common); + static bool less (Grob *g1, Grob *g2); }; /* smob utilities */ @@ -149,10 +153,10 @@ Item *unsmob_item (SCM); /* refpoints */ Grob *common_refpoint_of_list (SCM elt_list, Grob *, Axis a); -Grob *common_refpoint_of_array (vector const &, Grob *, Axis a); +Grob *common_refpoint_of_array (vector const &, Grob *, Axis a); System *get_root_system (Grob *me); -/* extents */ +/* extents */ Interval robust_relative_extent (Grob *, Grob *, Axis); /* offset/extent callbacks. */