X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fgrob.hh;h=7a74d8baee991071ee093ab864e543134622c867;hb=0f7c7f4503011bc1e191933cb8a9f0ba1f95aceb;hp=028f5a14b7aea480942003778bfe0cc3a03a65f7;hpb=352fd1005d930ced9e8631cd69f6ce439ceff512;p=lilypond.git diff --git a/lily/include/grob.hh b/lily/include/grob.hh index 028f5a14b7..7a74d8baee 100644 --- a/lily/include/grob.hh +++ b/lily/include/grob.hh @@ -1,191 +1,153 @@ /* grob.hh -- declare Grob - (c) 1996-1999--2002 Han-Wen Nienhuys + source file of the LilyPond music typesetter + + (c) 1996--2005 Han-Wen Nienhuys */ -#ifndef STAFFELEM_HH -#define STAFFELEM_HH +#ifndef GROB_HH +#define GROB_HH -#include "parray.hh" #include "virtual-methods.hh" -#include "lily-guile.hh" -#include "lily-proto.hh" -#include "smobs.hh" #include "dimension-cache.hh" +#include "grob-interface.hh" +#include "object-key.hh" -/** - for administration of what was done already - */ -enum Grob_status { - ORPHAN=0, // not yet added to Paper_score - VIRGIN, - PRECALCING, - PRECALCED, // calcs before spacing done - POSTCALCING, // busy calculating. This is used to trap cyclic deps. - POSTCALCED, // after spacing calcs done -}; - -typedef void (Grob::*Grob_method_pointer) (void); +typedef void (Grob:: *Grob_method_pointer) (void); +class Grob +{ +private: + DECLARE_SMOBS (Grob, foo); + void init (); -#define get_grob_property(x) internal_get_grob_property(ly_symbol2scm(x)) -#define set_grob_property(x,y) internal_set_grob_property(ly_symbol2scm(x),y) - -/* - Basic output object. -*/ -class Grob { -public: +protected: + Object_key const *key_; SCM immutable_property_alist_; - - // rename me to ``property_alist_'' SCM mutable_property_alist_; + SCM object_alist_; + SCM property_callbacks_; - Grob *original_l_; + /* + If this is a property, it accounts for 25% of the property + lookups. + */ + SCM interfaces_; + + /* BARF */ + friend class Spanner; + friend SCM ly_grob_properties (SCM); + friend SCM ly_grob_basic_properties (SCM); + friend void check_interfaces_for_property (Grob const *, SCM); + void substitute_object_links (SCM, SCM); + char status_; + + DECLARE_CLASSNAME(Grob); +public: + DECLARE_SCHEME_CALLBACK(same_axis_parent_positioning, (SCM, SCM)); + DECLARE_SCHEME_CALLBACK(other_axis_parent_positioning, (SCM, SCM)); - /** - Administration: Where are we?. This is mainly used by Super_element and - Grob::calcalute_dependencies () + Object_key const *get_key () const; - 0 means ORPHAN, - */ - char status_c_; - String name () const; + Grob *original_; - /* - IDEA: make this a global variable. This is the same for all - elements, I think it is safe to assume that we will not have - scores being formatted multithreadedly. - */ - Paper_score *pscore_l_; + /* TODO: junk this member. */ + Paper_score *pscore_; - Grob (SCM basic_props); - Grob (Grob const&); + Dimension_cache dim_cache_[NO_AXES]; - /* - properties - */ - SCM internal_get_grob_property (SCM) const; - void internal_set_grob_property (SCM, SCM val); - -#if 0 - void set_immutable_grob_property (const char * , SCM val); - void set_immutable_grob_property (SCM key, SCM val); -#endif + Grob (SCM basic_props, Object_key const *); + Grob (Grob const &, int copy_count); - void warning (String); + virtual Grob *clone (int count) const; + DECLARE_SCHEME_CALLBACK (stencil_extent, (SCM smob, SCM axis)); - void set_elt_pointer (const char*, SCM val); - friend class Property_engraver; // UGHUGHUGH. - SCM remove_grob_property (const char* nm); + String name () const; + /* + Properties + */ + SCM internal_get_property (SCM symbol) const; + SCM get_property_data (SCM symbol) const; + SCM internal_get_object (SCM symbol) const; + + void internal_set_property (SCM sym, SCM val); + void internal_set_object (SCM sym, SCM val); + SCM try_callback (SCM); /* - related classes. - */ - Paper_def *paper_l () const; - - /** - add a dependency. It may be the 0 pointer, in which case, it is ignored. - */ - void add_dependency (Grob*); - virtual System * line_l () const; - bool linked_b () const; - - - VIRTUAL_COPY_CONS (Grob); - - /** - Recursively track all dependencies of this Grob. The - status_c_ field is used as a mark-field. It is marked with - #busy# during execution of this function, and marked with #final# - when finished. - - #funcptr# is the function to call to update this element. - */ + JUNKME. + */ + void add_to_list_property (SCM, SCM); + void add_to_object_list (SCM sym, SCM thing); + + SCM get_property_alist_chain (SCM) const; + static SCM ly_grob_set_property (SCM, SCM, SCM); + static SCM ly_grob_property (SCM, SCM); + + void warning (String) const; + void programming_error (String) const; + + Output_def *get_layout () const; + void add_dependency (Grob *); + virtual System *get_system () const; + void calculate_dependencies (int final, int busy, SCM funcname); - static SCM handle_broken_grobs(SCM, SCM criterion); virtual void do_break_processing (); - virtual Grob *find_broken_piece (System*) const; + virtual Grob *find_broken_piece (System *) const; virtual void discretionary_processing (); - virtual SCM do_derived_mark (); - - Molecule * get_molecule () const; - SCM get_uncached_molecule () const; - - void suicide (); - - DECLARE_SCHEME_CALLBACK (preset_extent, (SCM smob, SCM axis)); - DECLARE_SCHEME_CALLBACK (point_dimension_callback, (SCM smob, SCM axis)); - DECLARE_SCHEME_CALLBACK (molecule_extent, (SCM smob, SCM axis)); + virtual void derived_mark () const; + Stencil *get_stencil () const; + Stencil get_print_stencil () const; - static SCM ly_set_grob_property (SCM, SCM,SCM); - static SCM ly_get_grob_property (SCM, SCM); + void suicide (); + bool is_live () const; + bool is_empty (Axis a) const; - bool has_interface (SCM intf); - void set_interface (SCM intf); + bool internal_has_interface (SCM intf); + static bool has_interface (Grob *me); virtual void handle_broken_dependencies (); virtual void handle_prebroken_dependencies (); + Interval extent (Grob *refpoint, Axis) const; - DECLARE_SMOBS (Grob,foo); - - void init (); - - Dimension_cache dim_cache_[NO_AXES]; - -public: - bool empty_b (Axis a) const; - - Interval extent (Grob * refpoint, Axis) const; - - /** - translate in one direction - */ - void translate_axis (Real, Axis); - - /** - Find the offset relative to D. If D equals THIS, then it is 0. - Otherwise, it recursively defd as - - OFFSET_ + PARENT_L_->relative_coordinate (D) - */ - Real relative_coordinate (Grob const* refp, Axis) const; - /** - Find the group-element which has both #this# and #s# - */ - Grob*common_refpoint (Grob const* s, Axis a) const; - Grob*common_refpoint (SCM elt_list, Axis a) const; + Real relative_coordinate (Grob const *refp, Axis) const; + Grob *common_refpoint (Grob const *s, Axis a) const; // duh. slim down interface here. (todo) - bool has_offset_callback_b (SCM callback, Axis)const; + void set_callback (SCM sym, SCM proc); + bool has_offset_callback (SCM callback, Axis) const; void add_offset_callback (SCM callback, Axis); - bool has_extent_callback_b (SCM, Axis)const; - void set_extent_callback (SCM , Axis); - bool has_extent_callback_b (Axis) const; - - - /** - Invoke callbacks to get offset relative to parent. - */ + bool has_extent_callback (SCM, Axis) const; + void flush_extent_cache (Axis); + void set_extent (SCM, Axis); + void set_extent_callback (SCM, Axis); Real get_offset (Axis a) const; - /** - Set the parent refpoint of THIS to E - */ - void set_parent (Grob* e, Axis); - - Grob *get_parent (Axis a) const { return dim_cache_[a].parent_l_; } - DECLARE_SCHEME_CALLBACK (fixup_refpoint, (SCM)); + + void set_parent (Grob *e, Axis); + + // URG + Grob *get_parent (Axis a) const; + void fixup_refpoint (); }; -DECLARE_UNSMOB(Grob,grob); -Spanner* unsmob_spanner (SCM ); -Item* unsmob_item (SCM ); +DECLARE_UNSMOB (Grob, grob); +Spanner *unsmob_spanner (SCM); +Item *unsmob_item (SCM); + +Grob *common_refpoint_of_list (SCM elt_list, Grob *, Axis a); +Grob *common_refpoint_of_array (Link_array const &, Grob *, Axis a); + +void set_break_subsititution (SCM criterion); +SCM substitute_object_alist (SCM alist, SCM dest); +Link_array ly_scm2grobs (SCM ell); +SCM ly_grobs2scm (Link_array a); -#endif // STAFFELEM_HH +Interval robust_relative_extent (Grob *, Grob *, Axis); +#endif /* GROB_HH */