1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
/*
Copyright (C) 2012-2021 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
DCP-o-matic is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
DCP-o-matic is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
*/
#include "cross.h"
#include "dcpomatic_log.h"
#include "warnings.h"
#include <dcp/compose.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
{
char gb[64];
snprintf(gb, 64, "%.1f", _size / 1000000000.0);
string name;
if (_vendor) {
name += *_vendor;
}
if (_model) {
if (name.size() > 0) {
name += " " + *_model;
} else {
name = *_model;
}
}
if (name.size() == 0) {
name = _("Unknown");
}
return dcp::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 dcp::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]")
);
}
|