]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/kpath.cc
* lily/kpath.cc:
[lilypond.git] / lily / kpath.cc
index 473b955120bb389433cadf6686c6dab163b7ae28..0a5cfc9cc317c24f58593e42c0ff51d3edd9ed46 100644 (file)
@@ -3,13 +3,29 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 2000--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+  (c) 2000--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
-#include <stdio.h>
-#include <string.h>
+#include "kpath.hh"
+
+#include <cstdio>
+#include <cstring>
+
+/*
 
-#include "config.h"
+The problem, as far as I can tell, is that MacOS X has its getopt
+prototype in <unistd.h>, whinole I think other operating systems have it
+in other places. <unistd.h> is included by kpathsea.h, so you end up
+renaming both conflicting prototypes to YAKLUDGE.
+
+I found a somewhat more elegant patch for this: Just #include
+<unistd.h> before defining YAKLUDGE.
+
+*/
+
+#include <unistd.h>    
+
+#include "config.hh"
 
 #define popen REALLYUGLYKLUDGE
 #define pclose ANOTHERREALLYUGLYKLUDGE
@@ -23,92 +39,115 @@ extern "C" {
 #endif
 
 #include "file-path.hh"
-#include "string.hh"
 #include "main.hh"
-#include "kpath.hh"
+#include "source-file.hh"
 #include "warn.hh"
+#include "kpath-private.hh"
 
 String
-ly_find_afm (char const * name)
+kpathsea_find_afm (char const *name)
 {
 #if (KPATHSEA && HAVE_KPSE_FIND_FILE)
-  char * name_ptr =  kpse_find_file (name, kpse_afm_format, true);
 
-  if(!name_ptr)
-    {
-  /*
-    don't mutter about afms, since we try to find them first, and lots of
-    TFMs don't have AFMs. 
-   */
-      //      warning (_f("kpathsea couldn't find AFM file `%s'", name));
-    }
-  else
-    return name_ptr;
-  
+  if (char *afm = kpse_find_file (name, kpse_afm_format, false))
+    return afm;
+#if 0 /* Do not mutter about afms, since we try to find them first, and
+        lots of TFMs don't have AFMs. */
+  warning (_f ("kpathsea can't find %s file: `%s'", "AFM", name));
+#endif
 #endif
   return "";
 }
 
 String
-ly_find_tfm (char const * name)
+kpathsea_find_tfm (char const *name)
 {
-  String p = global_path.find (String (name) + ".tfm");
-
-  if (p.length_i ())
-    return p;
-  
+  String file_name = 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)
+  if (file_name.is_empty ())
     {
-      warning (_f("Kpathsea couldn't find TFM file `%s'", name));
+      /* 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. */
+      if (char *tfm = kpse_find_file (name, kpse_tfm_format, false))
+       return tfm;
+      warning (_f ("kpathsea can't find %s file: `%s'", "TFM", name));
     }
-  else
-    return name_ptr;
-  
 #endif
-  return "";
+  return file_name;
 }
 
+#if KPATHSEA
+/* FIXME: this should be part of kpathsea */
 
-void
-ly_init_kpath (char *av0)
+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. )
+  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
 
-    PRO:
-    - TFM and AFM checksums always match in Lily.
+String
+kpathsea_gulp_file_to_string (String name)
+{
+  String file_name = global_path.find (name);
 
-    - less hassle, no kpathsea spaghetti
+#if (KPATHSEA && HAVE_KPSE_FIND_FILE)
+  if (file_name.is_empty ())
+    {
+      char *p = kpse_find_file (name.to_str0 (), kpathsea_find_format (name),
+       true);
+      if (p)
+       file_name = p;
+      else
+       warning (_f ("kpathsea can't find file: `%s'", name));
+    }
+#endif
 
-    CON:
+  if (file_name.is_empty ())
+    error (_f ("can't find file: `%s'", name));
 
-    - feta PK files are often recreated, locally
-    Solution: cache PK files locally?
+  if (be_verbose_global)
+    progress_indication ("[" + file_name);
 
-    - need env. vars to make sure that TeX finds the TFMs
+  int filesize;
+  char *str = gulp_file (file_name, &filesize);
+  String string (str);
+  delete[] str;
+  
+  if (be_verbose_global)
+    progress_indication ("]");
 
-    - Outdated PK (TFM?) font files are not automatically removed,
-    since VERSION is not part of the standard location.
+  return string;
+}
 
 
-    ALTERNATIVE
 
-    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
@@ -117,5 +156,3 @@ ly_init_kpath (char *av0)
   kpse_maketex_option ("tfm", TRUE);
 #endif
 }
-
-