+LY_DEFINE (ly_grob_suicide, "ly:grob-suicide",
+ 1, 0, 0, (SCM g),
+ "Kill @var{g}.")
+{
+ Grob *me = unsmob_grob (g);
+ SCM_ASSERT_TYPE (me, g, SCM_ARG1, __FUNCTION__, "grob");
+
+ me->suicide ();
+ return SCM_UNDEFINED;
+}
+
+LY_DEFINE (ly_grob_translate_axis_x, "ly:grob-translate-axis!",
+ 3, 0, 0, (SCM g, SCM d, SCM a),
+ "Translate @var{g} on axis @var{a} over distance @var{d}.")
+{
+ Grob *me = unsmob_grob (g);
+ SCM_ASSERT_TYPE (me, g, SCM_ARG1, __FUNCTION__, "grob");
+ SCM_ASSERT_TYPE (gh_number_p (d), d, SCM_ARG2, __FUNCTION__, "dimension");
+ SCM_ASSERT_TYPE (is_axis (a), a, SCM_ARG3, __FUNCTION__, "axis");
+
+ me->translate_axis (gh_scm2double (d), Axis (gh_scm2int (a)));
+ return SCM_UNDEFINED;
+}
+
+LY_DEFINE (ly_spanner_p, "ly:spanner?",
+ 1, 0, 0, (SCM g),
+ "Is @var{g} a spanner object?")
+{
+ Grob *me = unsmob_grob (g);
+ bool b = dynamic_cast<Spanner*> (me);
+
+ return gh_bool2scm (b);
+}
+
+LY_DEFINE (ly_item_p, "ly:item?",
+ 1, 0, 0, (SCM g),
+ "Is @var{g} a item object?")
+{
+ Grob *me = unsmob_grob (g);
+ bool b = dynamic_cast<Item*> (me);
+ return gh_bool2scm (b);
+}
+
+LY_DEFINE (ly_item_break_dir, "ly:item-break-dir",
+ 1, 0, 0, (SCM it),
+ "The break status dir of @var{it}.")
+{
+ Item *me = dynamic_cast<Item*> ( unsmob_grob (it));
+ SCM_ASSERT_TYPE (me, it, SCM_ARG1, __FUNCTION__, "Item");
+ return gh_int2scm (me->break_status_dir ());
+}