summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2021-12-23 23:33:56 +0100
committerCarl Hetherington <cth@carlh.net>2022-05-02 00:22:43 +0200
commita2f8e8839f276bc83d5926983ab2d38e0a36f927 (patch)
tree24a3485fbd6a6db99d72328be3f053a7ad121645
parent809bcfd85fad2ef7d4131c054be4cccd5bcc9d05 (diff)
Extract simple_digest().
-rw-r--r--src/lib/content.cc6
-rw-r--r--src/lib/util.cc7
-rw-r--r--src/lib/util.h1
3 files changed, 9 insertions, 5 deletions
diff --git a/src/lib/content.cc b/src/lib/content.cc
index 3c3942aa1..ed0e9af6d 100644
--- a/src/lib/content.cc
+++ b/src/lib/content.cc
@@ -169,15 +169,11 @@ Content::as_xml (xmlpp::Node* node, bool with_paths) const
string
Content::calculate_digest () const
{
- boost::mutex::scoped_lock lm (_mutex);
- auto p = _paths;
- lm.unlock ();
-
/* Some content files are very big, so we use a poor man's
digest here: a digest of the first and last 1e6 bytes with the
size of the first file tacked on the end as a string.
*/
- return digest_head_tail(p, 1000000) + raw_convert<string>(boost::filesystem::file_size(p.front()));
+ return simple_digest (paths());
}
diff --git a/src/lib/util.cc b/src/lib/util.cc
index 7106cc782..6e2a1ad64 100644
--- a/src/lib/util.cc
+++ b/src/lib/util.cc
@@ -530,6 +530,13 @@ digest_head_tail (vector<boost::filesystem::path> files, boost::uintmax_t size)
}
+string
+simple_digest (vector<boost::filesystem::path> paths)
+{
+ return digest_head_tail(paths, 1000000) + raw_convert<string>(boost::filesystem::file_size(paths.front()));
+}
+
+
/** Trip an assert if the caller is not in the UI thread */
void
ensure_ui_thread ()
diff --git a/src/lib/util.h b/src/lib/util.h
index e335434d8..706056cda 100644
--- a/src/lib/util.h
+++ b/src/lib/util.h
@@ -91,6 +91,7 @@ extern void dcpomatic_setup ();
extern void dcpomatic_setup_path_encoding ();
extern void dcpomatic_setup_gettext_i18n (std::string);
extern std::string digest_head_tail (std::vector<boost::filesystem::path>, boost::uintmax_t size);
+extern std::string simple_digest (std::vector<boost::filesystem::path> paths);
extern void ensure_ui_thread ();
extern std::string audio_channel_name (int);
extern std::string short_audio_channel_name (int);