#include "all-font-metrics.hh"
#include "main.hh"
+#include "protected-scm.hh"
+
+All_font_metrics *all_fonts_global = 0;
+Protected_scm all_fonts_global_scm;
LY_DEFINE (ly_reset_all_fonts, "ly:reset-all-fonts", 0, 0, 0,
(),
"Forget all about previously loaded fonts.")
{
- delete all_fonts_global;
all_fonts_global = new All_font_metrics (global_path.to_string ());
+ all_fonts_global_scm = all_fonts_global->unprotect ();
return SCM_UNSPECIFIED;
}
All_font_metrics::All_font_metrics (const string &path)
{
+#if HAVE_PANGO_FT2
+ pango_dict_ = new Scheme_hash_table;
+#endif
+
otf_dict_ = new Scheme_hash_table;
+ smobify_self ();
+ otf_dict_->unprotect ();
#if HAVE_PANGO_FT2
+ pango_dict_->unprotect ();
PangoFontMap *pfm = pango_ft2_font_map_new ();
pango_ft2_fontmap_ = PANGO_FT2_FONT_MAP (pfm);
pango_dpi_ = PANGO_RESOLUTION;
pango_ft2_font_map_set_resolution (pango_ft2_fontmap_,
pango_dpi_, pango_dpi_);
-
- pango_dict_ = new Scheme_hash_table;
#endif
search_path_.parse_path (path);
All_font_metrics::~All_font_metrics ()
{
- otf_dict_->unprotect ();
-
#if HAVE_PANGO_FT2
- pango_dict_->unprotect ();
g_object_unref (pango_ft2_fontmap_);
#endif
}
-All_font_metrics::All_font_metrics (All_font_metrics const &)
+SCM
+All_font_metrics::mark_smob ()
{
+#if HAVE_PANGO_FT2
+ if (pango_dict_)
+ scm_gc_mark (pango_dict_->self_scm ());
+#endif
+ if (otf_dict_)
+ return otf_dict_->self_scm ();
+ return SCM_UNDEFINED;
}
#if HAVE_PANGO_FT2
return f;
}
-
-All_font_metrics *all_fonts_global;
Interface to all fonts (both system fonts and fonts loaded
via Pango).
*/
-class All_font_metrics
+class All_font_metrics : public Smob<All_font_metrics>
{
Scheme_hash_table *otf_dict_;
File_path search_path_;
All_font_metrics (All_font_metrics const &);
public:
+ SCM mark_smob ();
Index_to_charcode_map const *get_index_to_charcode_map (const string &filename,
int face_index,