+#endif
+
+String
+kpathsea_find_file (String name, String ext)
+{
+ name += "." + ext;
+ String path = global_path.find (name);
+ if (path.length () > 0)
+ return path;
+
+ SCM kpath = ly_lily_module_constant ("ly:kpathsea-find-file");
+ if (ly_is_procedure (kpath))
+ {
+ SCM kp_result = scm_call_1 (kpath, scm_makfrom0str (name.to_str0 ()));
+ if (scm_is_string (kp_result))
+ return ly_scm2string (kp_result);
+ }
+
+ return "";
+}
+
+/*
+ TODO: our AFM handling is broken: the units in an AFM file are
+ relative to the design size (1000 units = 1 designsize). Hence we
+ should include design size when generating an AFM metric.
+
+ ugr: copied from find_tfm.
+*/
+Adobe_font_metric *
+All_font_metrics::find_afm (String name)
+{
+ SCM sname = ly_symbol2scm (name.to_str0 ());
+ SCM name_string = scm_makfrom0str (name.to_str0 ());
+ SCM val;
+ if (!afm_dict_->try_retrieve (sname, &val))
+ {
+ String file_name;
+
+ if (file_name.is_empty ())
+ file_name = search_path_.find (name + ".afm");
+
+ if (file_name.is_empty ())