summaryrefslogtreecommitdiff
path: root/libs/surfaces/websockets/manifest.cc
blob: 3279f408b0bf424021be2c750c9d3d3d65406528 (plain)
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
/*
 * Copyright (C) 2020 Luciano Iam <lucianito@gmail.com>
 *
 * This program 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.
 *
 * This program 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 this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 */

#include <iostream>
#include <sstream>

#include <glibmm/fileutils.h>
#include <glibmm/miscutils.h>

#include "pbd/xml++.h"

#include "manifest.h"

static const char* const manifest_filename = "manifest.xml";

SurfaceManifest::SurfaceManifest (std::string path)
	: _path (path)
{
	XMLTree tree;
	std::string xml_path = Glib::build_filename (_path, manifest_filename);

	if (!tree.read (xml_path.c_str())) {
#ifndef NDEBUG
		std::cerr << "SurfaceManifest: could not parse " << xml_path << std::endl;
#endif
		return;
	}

	XMLNodeList nlist = tree.root ()->children ();

	for (XMLNodeConstIterator niter = nlist.begin(); niter != nlist.end(); ++niter) {
		XMLNode*    node = *niter;
		std::string name = node->name ();
		std::string value;
		
		node->get_property ("value", value);

		if (name == "Name") {
			_name = value;
		} else if (name == "Description") {
			_description = value;
		}
	}

	if (_name.empty () || _description.empty ()) {
#ifndef NDEBUG
		std::cerr << "SurfaceManifest: missing properties in " << xml_path << std::endl;
#endif
		return;
	}

	_valid = true;
}

std::string
SurfaceManifest::to_json ()
{
	std::stringstream ss;

	ss << "{"
		<< "\"diskPath\":\"" << _path << "\""
		<< ",\"path\":\"" << Glib::path_get_basename (_path) << "\""
		<< ",\"name\":\"" << _name << "\""
		<< ",\"description\":\"" << _description << "\""
		<< "}";

	return ss.str ();
}

bool
SurfaceManifest::exists_at_path (std::string path)
{
	std::string xml_path = Glib::build_filename (path, manifest_filename);
	return Glib::file_test (xml_path, Glib::FILE_TEST_EXISTS);
}