#include "string.hh"
#include "main.hh"
#include "kpath.hh"
+#include "source-file.hh"
#include "warn.hh"
String
kpathsea_find_afm (char const * name)
{
#if (KPATHSEA && HAVE_KPSE_FIND_FILE)
- char * name_ptr = kpse_find_file (name, kpse_afm_format, true);
+ char * name_ptr = kpse_find_file (name, kpse_afm_format, false);
if (!name_ptr)
{
}
String
-kpathsea_find_tfm (char const * name)
+kpathsea_find_tfm (char const *name)
{
- String p = global_path.find (String (name) + ".tfm");
-
- if (p.length ())
- return p;
-
+ String filename = global_path.find (String (name) + ".tfm");
#if (KPATHSEA && HAVE_KPSE_FIND_FILE)
- char * name_ptr = kpse_find_file (name, kpse_tfm_format, true);
- if (!name_ptr)
- warning (_f ("kpathsea can not find TFM file: `%s'", name));
- else
- return name_ptr;
-
+ if (filename.is_empty ())
+ {
+ /* If invoked for a TeX font, we could do TRUE (must exist).
+ We could also do:
+ p = kpse_find_file (name, kpse_mf_format, false);
+ if (p)
+ p = kpse_find_file (name, kpse_mf_format, true);
+
+ but we assume that if there is a .PFA, there is also a .TFM,
+ and it's no use generating TFMs on the fly, because PFAs cannot
+ be generated on the fly. */
+ char *p = kpse_find_file (name, kpse_tfm_format, false);
+ if (!p)
+ warning (_f ("kpathsea can not find TFM file: `%s'", name));
+ else
+ filename = p;
+ }
#endif
- return "";
+ return filename;
}
+#if KPATHSEA
+/* FIXME: this should be part of kpathsea */
-void
-initialize_kpathsea (char *av0)
+static kpse_file_format_type
+kpathsea_find_format (String name)
{
-#if KPATHSEA && HAVE_KPATHSEA_KPATHSEA_H
- /*
- We take two pronged approach to tfms:
-
- * the lilypond tfms (feta*.tfm) are found through our own routines.
-
- * the TeX tfms are found through vanilla kpathsea.
-
- (* other TFMs are not found, i.e. don't use them. )
-
- PRO:
-
- - TFM and AFM checksums always match in Lily.
+ for (int i = 0; i < kpse_last_format; i++)
+ {
+ if (!kpse_format_info[i].type)
+ kpse_init_format ((kpse_file_format_type) i);
+
+ char const **suffixes[] = { kpse_format_info[i].suffix,
+ kpse_format_info[i].alt_suffix };
+ for (int j = 0; j < 2; j++)
+ for (char const **p = suffixes[j]; p && *p; p++)
+ {
+ String suffix = *p;
+ if (name.right_string (suffix.length ()) == suffix)
+ return (kpse_file_format_type) i;
+ }
+ }
+ return kpse_last_format;
+}
+#endif
- - less hassle, no kpathsea spaghetti
+String
+kpathsea_gulp_file_to_string (String name)
+{
+ String filename = global_path.find (name);
- CON:
+#if (KPATHSEA && HAVE_KPSE_FIND_FILE)
+ if (filename.is_empty ())
+ {
+ char *p = kpse_find_file (name.to_str0 (), kpathsea_find_format (name),
+ true);
+ if (p)
+ filename = p;
+ else
+ warning (_f ("kpathsea can not find file: `%s'", name));
+ }
+#endif
- - feta PK files are often recreated, locally
- Solution: cache PK files locally?
+ if (filename.is_empty ())
+ error (_f ("can't find file: `%s'", name));
- - need env. vars to make sure that TeX finds the TFMs
+ if (verbose_global_b)
+ progress_indication ("[" + filename);
- - Outdated PK (TFM?) font files are not automatically removed,
- since VERSION is not part of the standard location.
+ int filesize;
+ char *str = gulp_file (filename, &filesize);
+ String string (str);
+ delete[] str;
+
+ if (verbose_global_b)
+ progress_indication ("]");
+ return string;
+}
- ALTERNATIVE
+LY_DEFINE (ly_kpathsea_gulp_file, "ly:kpathsea-gulp-file",
+ 1, 0, 0, (SCM name),
+ "Read the file @var{name}, and return its contents in a string. "
+ "The file is looked up using the search path and kpathsea.")
+{
+ SCM_ASSERT_TYPE (is_string (name), name, SCM_ARG1, __FUNCTION__, "string");
+ return scm_makfrom0str
+ (kpathsea_gulp_file_to_string (ly_scm2string (name)).to_str0 ());
+}
- we have tried to come up with schemes that leave this kind of work
- to kpathsea with objective of fixing the CONs, but miserably
- failed. TeX installations and kpathsea itself form a buggy,
- inconsistent, and unorderly mess.
-
- */
+void
+initialize_kpathsea (char *av0)
+{
+#if KPATHSEA && HAVE_KPATHSEA_KPATHSEA_H
/*
initialize kpathsea
kpse_maketex_option ("tfm", TRUE);
#endif
}
-
-