summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2020-08-25 21:58:48 +0200
committerCarl Hetherington <cth@carlh.net>2020-08-25 21:58:48 +0200
commit8475d7b7d70d5b98e7737f326653d80a9fd8e9cf (patch)
tree2a3eccbe46591d2bde7ff607890e5de5225d4a9f
parent75f6cc0fa8bcff9b98a31200e313d8895cfaa3f8 (diff)
Move the code to find Liberation into util.cc.
-rw-r--r--src/lib/reel_writer.cc17
-rw-r--r--src/lib/util.cc21
-rw-r--r--src/lib/util.h1
3 files changed, 23 insertions, 16 deletions
diff --git a/src/lib/reel_writer.cc b/src/lib/reel_writer.cc
index 770130798..f5f21f2ea 100644
--- a/src/lib/reel_writer.cc
+++ b/src/lib/reel_writer.cc
@@ -439,24 +439,9 @@ maybe_add_text (
shared_ptr<T> reel_asset;
if (asset) {
- boost::filesystem::path liberation_normal;
- try {
- liberation_normal = shared_path() / "LiberationSans-Regular.ttf";
- if (!boost::filesystem::exists (liberation_normal)) {
- /* Hack for unit tests */
- liberation_normal = shared_path() / "fonts" / "LiberationSans-Regular.ttf";
- }
- } catch (boost::filesystem::filesystem_error& e) {
-
- }
-
- if (!boost::filesystem::exists(liberation_normal)) {
- liberation_normal = "/usr/share/fonts/truetype/liberation/LiberationSans-Regular.ttf";
- }
-
/* Add the font to the subtitle content */
BOOST_FOREACH (shared_ptr<Font> j, fonts) {
- asset->add_font (j->id(), j->file().get_value_or(liberation_normal));
+ asset->add_font (j->id(), j->file().get_value_or(default_font_file()));
}
if (dynamic_pointer_cast<dcp::InteropSubtitleAsset> (asset)) {
diff --git a/src/lib/util.cc b/src/lib/util.cc
index 7ba9242fa..84138f4d9 100644
--- a/src/lib/util.cc
+++ b/src/lib/util.cc
@@ -1253,3 +1253,24 @@ decrypt_kdm_with_helpful_error (dcp::EncryptedKDM kdm)
}
}
+
+boost::filesystem::path
+default_font_file ()
+{
+ boost::filesystem::path liberation_normal;
+ try {
+ liberation_normal = shared_path() / "LiberationSans-Regular.ttf";
+ if (!boost::filesystem::exists (liberation_normal)) {
+ /* Hack for unit tests */
+ liberation_normal = shared_path() / "fonts" / "LiberationSans-Regular.ttf";
+ }
+ } catch (boost::filesystem::filesystem_error& e) {
+
+ }
+
+ if (!boost::filesystem::exists(liberation_normal)) {
+ liberation_normal = "/usr/share/fonts/truetype/liberation/LiberationSans-Regular.ttf";
+ }
+
+ return liberation_normal;
+}
diff --git a/src/lib/util.h b/src/lib/util.h
index 6cfe37beb..b4378040a 100644
--- a/src/lib/util.h
+++ b/src/lib/util.h
@@ -121,6 +121,7 @@ extern void write_swaroop_chain (boost::shared_ptr<const dcp::CertificateChain>
#endif
extern dcp::Size scale_for_display (dcp::Size s, dcp::Size display_container, dcp::Size film_container);
extern dcp::DecryptedKDM decrypt_kdm_with_helpful_error (dcp::EncryptedKDM kdm);
+extern boost::filesystem::path default_font_file ();
template <class T>
std::list<T>