Add xfonts to the font path if necessary.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@5518 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Dekel Tsur 2002-10-25 21:07:05 +00:00
parent 90c5920f8c
commit 27b8ecbe3a
2 changed files with 71 additions and 51 deletions

View File

@ -1,3 +1,8 @@
2002-10-25 Dekel Tsur <dekelts@tau.ac.il>
* xfont_loader.C (getFontinfo): Add xfonts to the font path if
necessary.
2002-10-25 Angus Leeming <leeming@lyx.org> 2002-10-25 Angus Leeming <leeming@lyx.org>
* FormSpellchecker.C (input): fix crash when progress == 0. * FormSpellchecker.C (input): fix crash when progress == 0.

View File

@ -22,6 +22,8 @@
#include "lyxrc.h" // lyxrc.font_* #include "lyxrc.h" // lyxrc.font_*
#include "BufferView.h" #include "BufferView.h"
#include "frontends/LyXView.h" #include "frontends/LyXView.h"
#include "support/systemcall.h"
#include "support/filetools.h"
#include FORMS_H_LOCATION #include FORMS_H_LOCATION
@ -89,6 +91,43 @@ void xfont_loader::unload()
} }
} }
namespace {
string const symbolPattern(LyXFont::FONT_FAMILY family)
{
switch (family) {
case LyXFont::SYMBOL_FAMILY:
return "-*-symbol-*-*-*-*-*-*-*-*-*-*-adobe-fontspecific";
case LyXFont::CMR_FAMILY:
return "-*-cmr10-medium-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::CMSY_FAMILY:
return "-*-cmsy10-*-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::CMM_FAMILY:
return "-*-cmmi10-medium-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::CMEX_FAMILY:
return "-*-cmex10-*-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::MSA_FAMILY:
return "-*-msam10-*-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::MSB_FAMILY:
return "-*-msbm10-*-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::EUFRAK_FAMILY:
return "-*-eufm10-medium-*-*-*-*-*-*-*-*-*-*-*";
case LyXFont::WASY_FAMILY:
return "-*-wasy10-medium-*-*-*-*-*-*-*-*-*-*-*";
default:
return string();
}
}
}
// Get font info // Get font info
/* Takes care of finding which font that can match the given request. Tries /* Takes care of finding which font that can match the given request. Tries
@ -102,55 +141,32 @@ void xfont_loader::getFontinfo(LyXFont::FONT_FAMILY family,
return; return;
// Special fonts // Special fonts
switch (family) string pat = symbolPattern(family);
{ if (!pat.empty()) {
case LyXFont::SYMBOL_FAMILY: static bool first_time = true;
fontinfo[family][series][shape] = fontinfo[family][series][shape] = new FontInfo(pat);
new FontInfo("-*-symbol-*-*-*-*-*-*-*-*-*-*-adobe-fontspecific"); if (family != LyXFont::SYMBOL_FAMILY &&
return; !fontinfo[family][series][shape]->exist() &&
first_time) {
case LyXFont::CMR_FAMILY: first_time = false;
fontinfo[family][series][shape] = string const dir =
new FontInfo("-*-cmr10-medium-*-*-*-*-*-*-*-*-*-*-*"); OnlyPath(LibFileSearch("xfonts", "fonts.dir"));
return; if (!dir.empty()) {
int n;
case LyXFont::CMSY_FAMILY: char ** p = XGetFontPath(fl_get_display(), &n);
fontinfo[family][series][shape] = if (std::find(p, p+n, dir) != p+n)
new FontInfo("-*-cmsy10-*-*-*-*-*-*-*-*-*-*-*-*"); return;
return; lyxerr << "Adding " << dir << " to the font path.\n";
string const command = "xset fp+ " + dir;
case LyXFont::CMM_FAMILY: Systemcall s;
fontinfo[family][series][shape] = if (!s.startscript(Systemcall::Wait, command)) {
new FontInfo("-*-cmmi10-medium-*-*-*-*-*-*-*-*-*-*-*"); delete fontinfo[family][series][shape];
return; fontinfo[family][series][shape] = new FontInfo(pat);
} else
case LyXFont::CMEX_FAMILY: lyxerr << "Unable to add font path.\n";
fontinfo[family][series][shape] = }
new FontInfo("-*-cmex10-*-*-*-*-*-*-*-*-*-*-*-*"); }
return; return;
case LyXFont::MSA_FAMILY:
fontinfo[family][series][shape] =
new FontInfo("-*-msam10-*-*-*-*-*-*-*-*-*-*-*-*");
return;
case LyXFont::MSB_FAMILY:
fontinfo[family][series][shape] =
new FontInfo("-*-msbm10-*-*-*-*-*-*-*-*-*-*-*-*");
return;
case LyXFont::EUFRAK_FAMILY:
fontinfo[family][series][shape] =
new FontInfo("-*-eufm10-medium-*-*-*-*-*-*-*-*-*-*-*");
return;
case LyXFont::WASY_FAMILY:
fontinfo[family][series][shape] =
new FontInfo("-*-wasy10-medium-*-*-*-*-*-*-*-*-*-*-*");
return;
default:
break;
} }
@ -334,6 +350,5 @@ bool xfont_loader::available(LyXFont const & f)
if (!fontinfo[f.family()][f.series()][f.realShape()]) if (!fontinfo[f.family()][f.series()][f.realShape()])
getFontinfo(f.family(), f.series(), f.realShape()); getFontinfo(f.family(), f.series(), f.realShape());
return fontinfo[f.family()][f.series()][f.realShape()] return fontinfo[f.family()][f.series()][f.realShape()]->exist();
->getFontname(f.size()).size();
} }