X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fgrob.hh;h=5da4dff74ec6107c242754e6c60b2eddefa90848;hb=024c0e02b523df0f1de0203cae949c3ad864d26c;hp=05b8f278ba3ff2856666508856986d076c734168;hpb=89b7e75f6888d2020f7fe8b258e818c0c5e7a223;p=lilypond.git diff --git a/lily/include/grob.hh b/lily/include/grob.hh index 05b8f278ba..5da4dff74e 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--2012 Han-Wen Nienhuys + Copyright (C) 1996--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 @@ -27,10 +27,14 @@ #include -class Grob +class Grob : public Smob { +public: + int print_smob (SCM, scm_print_state *) const; + SCM mark_smob () const; + static const char * const type_p_name_; + virtual ~Grob (); private: - DECLARE_SMOBS (Grob); DECLARE_CLASSNAME (Grob); void init (); @@ -69,13 +73,18 @@ public: /* standard callbacks */ DECLARE_SCHEME_CALLBACK (x_parent_positioning, (SCM)); DECLARE_SCHEME_CALLBACK (y_parent_positioning, (SCM)); + DECLARE_SCHEME_CALLBACK (pure_stencil_height, (SCM smob, SCM, SCM)); DECLARE_SCHEME_CALLBACK (stencil_height, (SCM smob)); DECLARE_SCHEME_CALLBACK (stencil_width, (SCM smob)); - DECLARE_SCHEME_CALLBACK (simple_vertical_skylines_from_stencil, (SCM smob)); + DECLARE_SCHEME_CALLBACK (pure_simple_vertical_skylines_from_extents, (SCM smob, SCM, SCM)); + DECLARE_SCHEME_CALLBACK (simple_vertical_skylines_from_extents, (SCM smob)); DECLARE_SCHEME_CALLBACK (vertical_skylines_from_stencil, (SCM smob)); + DECLARE_SCHEME_CALLBACK (pure_vertical_skylines_from_element_stencils, (SCM smob, SCM, SCM)); DECLARE_SCHEME_CALLBACK (vertical_skylines_from_element_stencils, (SCM smob)); - DECLARE_SCHEME_CALLBACK (simple_horizontal_skylines_from_stencil, (SCM smob)); + DECLARE_SCHEME_CALLBACK (pure_simple_horizontal_skylines_from_extents, (SCM smob, SCM, SCM)); + DECLARE_SCHEME_CALLBACK (simple_horizontal_skylines_from_extents, (SCM smob)); DECLARE_SCHEME_CALLBACK (horizontal_skylines_from_stencil, (SCM smob)); + DECLARE_SCHEME_CALLBACK (pure_horizontal_skylines_from_element_stencils, (SCM smob, SCM, SCM)); DECLARE_SCHEME_CALLBACK (horizontal_skylines_from_element_stencils, (SCM smob)); /* R/O access */ @@ -109,8 +118,8 @@ public: void internal_set_property (SCM sym, SCM val); /* messages */ - void warning (string) const; - void programming_error (string) const; + void warning (const string&) const; + void programming_error (const string&) const; /* class hierarchy */ virtual System *get_system () const; @@ -128,18 +137,18 @@ public: /* interfaces */ bool internal_has_interface (SCM intf); - DECLARE_GROB_INTERFACE (); /* offsets */ void translate_axis (Real, Axis); Real relative_coordinate (Grob const *refp, Axis) const; + Real parent_relative (Grob const *refp, Axis) const; Real pure_relative_y_coordinate (Grob const *refp, int start, int end); Real maybe_pure_coordinate (Grob const *refp, Axis a, bool pure, int start, int end); /* extents */ Interval extent (Grob *refpoint, Axis) const; void flush_extent_cache (Axis); - virtual Interval pure_height (Grob *refpoint, int start_col, int end_col); + virtual Interval pure_y_extent (Grob *refpoint, int start, int end); Interval maybe_pure_extent (Grob *refpoint, Axis, bool pure, int start, int end); /* refpoints */ @@ -161,14 +170,19 @@ public: virtual bool pure_is_visible (int start, int end) const; bool check_cross_staff (Grob *common); static bool less (Grob *g1, Grob *g2); - static SCM internal_simple_skylines_from_stencil (SCM, Axis); + static SCM maybe_pure_internal_simple_skylines_from_extents (Grob *, Axis, bool, int, int, bool, bool); + static SCM internal_skylines_from_element_stencils (Grob *me, Axis a, bool pure, int beg, int end); static SCM internal_skylines_from_element_stencils (SCM, Axis); }; -/* smob utilities */ -DECLARE_UNSMOB (Grob, grob); -Spanner *unsmob_spanner (SCM); -Item *unsmob_item (SCM); +template +inline bool has_interface(Grob *g) +{ + return g && g->internal_has_interface (Grob_interface::interface_symbol_); +} + +/* unification */ +void uniquify (vector &); /* refpoints */ Grob *common_refpoint_of_list (SCM elt_list, Grob *, Axis a); @@ -177,8 +191,6 @@ Grob *common_refpoint_of_array (set const &, Grob *, Axis a); System *get_root_system (Grob *me); /* extents */ -Interval maybe_pure_robust_relative_extent (Grob *, Grob *, Axis, bool, int, int); -Interval pure_robust_relative_extent (Grob *, Grob *, int, int); Interval robust_relative_extent (Grob *, Grob *, Axis); /* offset/extent callbacks. */