X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fsource-file.cc;h=14fdf2beb3b6ef4c10ff835c60deeca2a5811157;hb=77267b700c377fd170abcbf4863728937038eb5e;hp=69b18e90e5440bc6a5d4a643e91b38fee84ee1fe;hpb=47db9a3883d726ca53e2133a3b2298f78dd6a32e;p=lilypond.git diff --git a/lily/source-file.cc b/lily/source-file.cc index 69b18e90e5..14fdf2beb3 100644 --- a/lily/source-file.cc +++ b/lily/source-file.cc @@ -148,7 +148,10 @@ Source_file::Source_file (const string &filename_string) void Source_file::init_port () { - SCM str = scm_from_locale_string (c_str ()); + // This is somewhat icky: the string will in general be in utf8, but + // we do our own utf8 encoding and verification in the parser, so we + // use the no-conversion equivalent of latin1 + SCM str = scm_from_latin1_string (c_str ()); str_port_ = scm_mkstrport (SCM_INUM0, str, SCM_OPN | SCM_RDNG, __FUNCTION__); scm_set_port_filename_x (str_port_, ly_string2scm (name_)); } @@ -359,16 +362,16 @@ Source_file::get_port () const /****************************************************************/ -const char Source_file::type_p_name_[] = "ly:source-file?"; +const char * const Source_file::type_p_name_ = "ly:source-file?"; SCM -Source_file::mark_smob () +Source_file::mark_smob () const { return str_port_; } int -Source_file::print_smob (SCM port, scm_print_state *) +Source_file::print_smob (SCM port, scm_print_state *) const { scm_puts ("#