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
|
/* libpict
* Copyright (C) 2006 Ariya Hidayat (ariya@kde.org)
* Copyright (C) 2007 Fridrich Strba (fridrich.strba@bluewin.ch)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02111-1301 USA
*
* For further information visit http://libpict.sourceforge.net
*/
/* "This product is not manufactured, approved, or supported by
* Corel Corporation or Corel Corporation Limited."
*/
#include "PictImage.h"
#include "PictHeader.h"
#include "PictXParser.h"
#include "Pict1Parser.h"
#include "Pict2Parser.h"
#include "libpict_utils.h"
#include "PictSVGGenerator.h"
#include <libwpg/libwpg.h>
#include <sstream>
/**
Analyzes the content of an input stream to see if it can be parsed
\param input The input stream
\return A value that indicates whether the content from the input
stream is a Macintosh Pict Image that libpict is able to parse
*/
bool libpict::PictImage::isSupported(WPXInputStream* input)
{
input->seek(0, WPX_SEEK_SET);
PictHeader header;
if(!header.load(input))
return false;
return true;
}
/**
Parses the input stream content. It will make callbacks to the functions provided by a
WPGPaintInterface class implementation when needed. This is often commonly called the
'main parsing routine'.
\param input The input stream
\param painter A WPGPainterInterface implementation
\return A value that indicates whether the parsing was successful
*/
bool libpict::PictImage::parse(::WPXInputStream* input, libwpg::WPGPaintInterface* painter)
{
PictXParser *parser = 0;
input->seek(0, WPX_SEEK_SET);
PICT_DEBUG_MSG(("Loading header...\n"));
PictHeader header;
if(!header.load(input))
return false;
// seek to the start of document
input->seek(header.startOfDocument(), WPX_SEEK_SET);
unsigned char tmpVersion = header.getVersion();
bool retval;
switch (tmpVersion) {
case 0x01: // Pict1
PICT_DEBUG_MSG(("Parsing Pict1\n"));
parser = new Pict1Parser(input, painter);
retval = parser->parse();
break;
case 0x02: // Pict2
PICT_DEBUG_MSG(("Parsing Pict2\n"));
parser = new Pict2Parser(input, painter);
retval = parser->parse();
break;
default: // other :-)
PICT_DEBUG_MSG(("Unknown format\n"));
return false;
}
if (parser)
delete parser;
return retval;
}
/**
Parses the input stream content and generates a valid Scalable Vector Graphics
Provided as a convenience function for applications that support SVG internally.
\param input The input stream
\param output The output string whose content is the resulting SVG
\return A value that indicates whether the SVG generation was successful.
*/
bool libpict::PictImage::generateSVG(::WPXInputStream* input, WPXString& output)
{
std::ostringstream tmpOutputStream;
libpict::PictSVGGenerator generator(tmpOutputStream);
bool result = libpict::PictImage::parse(input, &generator);
if (result)
output = WPXString(tmpOutputStream.str().c_str());
else
output = WPXString("");
return result;
}
|