/*
- Copyright (C) 2012-2020 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2012-2021 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
*/
+
#include "cross.h"
#include "compose.hpp"
+#include "dcpomatic_log.h"
+#include "warnings.h"
+#include <dcp/raw_convert.h>
+DCPOMATIC_DISABLE_WARNINGS
+#include <libxml++/libxml++.h>
+DCPOMATIC_ENABLE_WARNINGS
+#include <iostream>
#include "i18n.h"
+
using std::string;
+
+Drive::Drive (string xml)
+{
+ cxml::Document doc;
+ doc.read_string (xml);
+ _device = doc.string_child("Device");
+ for (auto i: doc.node_children("MountPoint")) {
+ _mount_points.push_back (i->content());
+ }
+ _size = doc.number_child<uint64_t>("Size");
+ _vendor = doc.optional_string_child("Vendor");
+ _model = doc.optional_string_child("Model");
+}
+
+
+string
+Drive::as_xml () const
+{
+ xmlpp::Document doc;
+ auto root = doc.create_root_node ("Drive");
+ root->add_child("Device")->add_child_text(_device);
+ for (auto i: _mount_points) {
+ root->add_child("MountPoint")->add_child_text(i.string());
+ }
+ root->add_child("Size")->add_child_text(dcp::raw_convert<string>(_size));
+ if (_vendor) {
+ root->add_child("Vendor")->add_child_text(*_vendor);
+ }
+ if (_model) {
+ root->add_child("Model")->add_child_text(*_model);
+ }
+
+ return doc.write_to_string("UTF-8");
+}
+
+
string
Drive::description () const
{
name = _("Unknown");
}
- return String::compose(_("%1 (%2 GB) [%3]"), name, gb, _internal_name);
+ return String::compose(_("%1 (%2 GB) [%3]"), name, gb, _device);
}
+
+string
+Drive::log_summary () const
+{
+ string mp;
+ for (auto i: _mount_points) {
+ mp += i.string() + ",";
+ }
+ if (mp.empty()) {
+ mp = "[none]";
+ } else {
+ mp = mp.substr (0, mp.length() - 1);
+ }
+
+ return String::compose(
+ "Device %1 mounted on %2 size %3 vendor %4 model %5",
+ _device, mp, _size, _vendor.get_value_or("[none]"), _model.get_value_or("[none]")
+ );
+}