X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrob-interface-scheme.cc;h=0472d5bef6794aeee6d76e19761725ebe41b7440;hb=8574d4349026c4ac5a15a27c50e264bf548e29fb;hp=633db2b115c46cc783d97a4f4a01f61379de688a;hpb=93f049e9a8e11ed1eabd82103636a227d8902cb8;p=lilypond.git diff --git a/lily/grob-interface-scheme.cc b/lily/grob-interface-scheme.cc index 633db2b115..0472d5bef6 100644 --- a/lily/grob-interface-scheme.cc +++ b/lily/grob-interface-scheme.cc @@ -3,21 +3,17 @@ source file of the GNU LilyPond music typesetter - (c) 2005 Han-Wen Nienhuys + (c) 2005--2009 Han-Wen Nienhuys */ #include "lily-guile.hh" -#include "string.hh" +#include "std-string.hh" static SCM all_ifaces; -LY_DEFINE (ly_add_interface, "ly:add-interface", - 3, 0, 0, (SCM a, SCM b, SCM c), - "Add an interface description.") +void +internal_add_interface (SCM a, SCM b, SCM c) { - SCM_ASSERT_TYPE (scm_is_symbol (a), a, SCM_ARG1, __FUNCTION__, "symbol"); - SCM_ASSERT_TYPE (scm_is_string (b), b, SCM_ARG2, __FUNCTION__, "string"); - SCM_ASSERT_TYPE (ly_is_list (c), c, SCM_ARG3, __FUNCTION__, "list of syms"); if (!all_ifaces) { SCM tab = scm_c_make_hash_table (59); @@ -28,6 +24,17 @@ LY_DEFINE (ly_add_interface, "ly:add-interface", SCM entry = scm_list_n (a, b, c, SCM_UNDEFINED); scm_hashq_set_x (all_ifaces, a, entry); +} + +LY_DEFINE (ly_add_interface, "ly:add-interface", + 3, 0, 0, (SCM a, SCM b, SCM c), + "Add an interface description.") +{ + LY_ASSERT_TYPE (ly_is_symbol, a, 1); + LY_ASSERT_TYPE (scm_is_string, b, 2); + LY_ASSERT_TYPE (ly_is_list, c, 3); + + internal_add_interface (a,b,c); return SCM_UNSPECIFIED; }