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
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* EBookImportFilter: Sets up the filter, and calls DocumentCollector
* to do the actual filtering
*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
#include <cppuhelper/supportsservice.hxx>
#include <libe-book/libe-book.h>
#include "EBookImportFilter.hxx"
using com::sun::star::uno::Sequence;
using com::sun::star::uno::XInterface;
using com::sun::star::uno::Exception;
using com::sun::star::uno::RuntimeException;
using com::sun::star::uno::XComponentContext;
using libebook::EBOOKDocument;
bool EBookImportFilter::doImportDocument(librevenge::RVNGInputStream &rInput, OdtGenerator &rGenerator, utl::MediaDescriptor &rDescriptor)
{
rtl::OUString aFilterName;
rDescriptor[utl::MediaDescriptor::PROP_FILTERNAME()] >>= aFilterName;
assert(!aFilterName.isEmpty());
if (aFilterName == "Palm_Text_Document")
{
return EBOOKDocument::RESULT_OK == EBOOKDocument::parse(&rInput, &rGenerator);
}
else
{
EBOOKDocument::Type type = EBOOKDocument::TYPE_UNKNOWN;
if (aFilterName == "BroadBand eBook")
type = EBOOKDocument::TYPE_BBEB;
else if (aFilterName == "FictionBook 2")
type = EBOOKDocument::TYPE_FICTIONBOOK2;
else if (aFilterName == "PalmDoc")
type = EBOOKDocument::TYPE_PALMDOC;
else if (aFilterName == "Plucker eBook")
type = EBOOKDocument::TYPE_PLUCKER;
if (EBOOKDocument::TYPE_UNKNOWN != type)
return EBOOKDocument::RESULT_OK == EBOOKDocument::parse(&rInput, &rGenerator, type);
}
return false;
}
bool EBookImportFilter::doDetectFormat(librevenge::RVNGInputStream &rInput, OUString &rTypeName)
{
rTypeName.clear();
EBOOKDocument::Type type = EBOOKDocument::TYPE_UNKNOWN;
if (EBOOKDocument::CONFIDENCE_EXCELLENT == EBOOKDocument::isSupported(&rInput, &type))
{
switch (type)
{
case EBOOKDocument::TYPE_BBEB :
rTypeName = "writer_BroadBand_eBook";
break;
case EBOOKDocument::TYPE_FICTIONBOOK2 :
rTypeName = "writer_FictionBook_2";
break;
case EBOOKDocument::TYPE_PALMDOC :
rTypeName = "writer_PalmDoc";
break;
case EBOOKDocument::TYPE_PLUCKER :
rTypeName = "writer_Plucker_eBook";
break;
case EBOOKDocument::TYPE_PEANUTPRESS :
case EBOOKDocument::TYPE_TEALDOC :
case EBOOKDocument::TYPE_ZTXT :
rTypeName = "Palm_Text_Document";
break;
default :
SAL_WARN_IF(type != EBOOKDocument::TYPE_UNKNOWN, "writerperfect", "EBookImportFilter::doDetectFormat: document type " << type << " detected, but ignored");
}
}
return !rTypeName.isEmpty();
}
// XServiceInfo
OUString SAL_CALL EBookImportFilter::getImplementationName()
throw (RuntimeException, std::exception)
{
return OUString("org.libreoffice.comp.Writer.EBookImportFilter");
}
sal_Bool SAL_CALL EBookImportFilter::supportsService(const OUString &rServiceName)
throw (RuntimeException, std::exception)
{
return cppu::supportsService(this, rServiceName);
}
Sequence< OUString > SAL_CALL EBookImportFilter::getSupportedServiceNames()
throw (RuntimeException, std::exception)
{
Sequence < OUString > aRet(2);
OUString *pArray = aRet.getArray();
pArray[0] = "com.sun.star.document.ImportFilter";
pArray[1] = "com.sun.star.document.ExtendedTypeDetection";
return aRet;
}
extern "C"
SAL_DLLPUBLIC_EXPORT css::uno::XInterface *SAL_CALL
org_libreoffice_comp_Writer_EBookImportFilter_get_implementation(
css::uno::XComponentContext *const context,
const css::uno::Sequence<css::uno::Any> &)
{
return cppu::acquire(new EBookImportFilter(context));
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|