blob: a4b0699a58d0a06a37fcb463898e8716226485ab (
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
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
|
// SPDX-License-Identifier: GPL-2.0-or-later
/*
* File operations (independent of GUI)
*
* Copyright (C) 2018, 2019 Tavmjong Bah
*
* The contents of this file may be used under the GNU General Public License Version 2 or later.
*
*/
#include "file.h"
#include <iostream>
#include <gtkmm.h>
#include "document.h"
#include "document-undo.h"
#include "extension/system.h" // Extension::open()
#include "extension/extension.h"
#include "extension/db.h"
#include "extension/output.h"
#include "extension/input.h"
#include "object/sp-root.h"
#include "xml/repr.h"
/**
* Create a blank document, remove any template data.
* Input: Empty string or template file name.
*/
SPDocument*
ink_file_new(const std::string &Template)
{
SPDocument *doc = SPDocument::createNewDoc ((Template.empty() ? nullptr : Template.c_str()), true, true );
if (doc) {
// Remove all the template info from xml tree
Inkscape::XML::Node *myRoot = doc->getReprRoot();
Inkscape::XML::Node *nodeToRemove;
nodeToRemove = sp_repr_lookup_name(myRoot, "inkscape:templateinfo");
if (nodeToRemove != nullptr) {
Inkscape::DocumentUndo::ScopedInsensitive no_undo(doc);
sp_repr_unparent(nodeToRemove);
delete nodeToRemove;
}
nodeToRemove = sp_repr_lookup_name(myRoot, "inkscape:_templateinfo"); // backwards-compatibility
if (nodeToRemove != nullptr) {
Inkscape::DocumentUndo::ScopedInsensitive no_undo(doc);
sp_repr_unparent(nodeToRemove);
delete nodeToRemove;
}
} else {
std::cout << "ink_file_new: Did not create new document!" << std::endl;
}
return doc;
}
/**
* Open a document from memory.
*/
SPDocument*
ink_file_open(const Glib::ustring& data)
{
SPDocument *doc = SPDocument::createNewDocFromMem (data.c_str(), data.length(), true);
if (doc == nullptr) {
std::cerr << "ink_file_open: cannot open file in memory (pipe?)" << std::endl;
} else {
// This is the only place original values should be set.
SPRoot *root = doc->getRoot();
root->original.inkscape = root->version.inkscape;
root->original.svg = root->version.svg;
}
return doc;
}
/**
* Open a document.
*/
SPDocument*
ink_file_open(const Glib::RefPtr<Gio::File>& file, bool *cancelled_param)
{
bool cancelled = false;
SPDocument *doc = nullptr;
std::string path = file->get_path();
// TODO: It's useless to catch these exceptions here (and below) unless we do something with them.
// If we can't properly handle them (e.g. by showing a user-visible message) don't catch them!
try {
doc = Inkscape::Extension::open(nullptr, path.c_str());
} catch (Inkscape::Extension::Input::no_extension_found &e) {
doc = nullptr;
} catch (Inkscape::Extension::Input::open_failed &e) {
doc = nullptr;
} catch (Inkscape::Extension::Input::open_cancelled &e) {
cancelled = true;
doc = nullptr;
}
// Try to open explicitly as SVG.
// TODO: Why is this necessary? Shouldn't this be handled by the first call already?
if (doc == nullptr && !cancelled) {
try {
doc = Inkscape::Extension::open(Inkscape::Extension::db.get(SP_MODULE_KEY_INPUT_SVG), path.c_str());
} catch (Inkscape::Extension::Input::no_extension_found &e) {
doc = nullptr;
} catch (Inkscape::Extension::Input::open_failed &e) {
doc = nullptr;
} catch (Inkscape::Extension::Input::open_cancelled &e) {
cancelled = true;
doc = nullptr;
}
}
if (doc != nullptr) {
// This is the only place original values should be set.
SPRoot *root = doc->getRoot();
root->original.inkscape = root->version.inkscape;
root->original.svg = root->version.svg;
} else if (!cancelled) {
std::cerr << "ink_file_open: '" << path << "' cannot be opened!" << std::endl;
}
if (cancelled_param) {
*cancelled_param = cancelled;
}
return doc;
}
/*
Local Variables:
mode:c++
c-file-style:"stroustrup"
c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
indent-tabs-mode:nil
fill-column:99
End:
*/
// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4 :
|