summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--unoidl/source/legacyprovider.cxx7
-rw-r--r--unoidl/source/legacyprovider.hxx (renamed from include/unoidl/legacyprovider.hxx)11
-rwxr-xr-xunoidl/source/sourceprovider.cxx10
-rw-r--r--unoidl/source/sourceprovider.hxx (renamed from include/unoidl/sourceprovider.hxx)10
-rw-r--r--unoidl/source/unoidl.cxx13
-rw-r--r--unoidl/source/unoidlprovider.cxx90
-rw-r--r--unoidl/source/unoidlprovider.hxx (renamed from include/unoidl/unoidlprovider.hxx)22
7 files changed, 63 insertions, 100 deletions
diff --git a/unoidl/source/legacyprovider.cxx b/unoidl/source/legacyprovider.cxx
index b92302d40ab5..3b3821566ff0 100644
--- a/unoidl/source/legacyprovider.cxx
+++ b/unoidl/source/legacyprovider.cxx
@@ -19,10 +19,11 @@
#include "rtl/ref.hxx"
#include "rtl/ustring.hxx"
#include "sal/types.h"
-#include "unoidl/legacyprovider.hxx"
#include "unoidl/unoidl.hxx"
-namespace unoidl {
+#include "legacyprovider.hxx"
+
+namespace unoidl { namespace detail {
namespace {
@@ -823,6 +824,6 @@ rtl::Reference< Entity > LegacyProvider::findEntity(OUString const & name)
LegacyProvider::~LegacyProvider() throw () {}
-}
+} }
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/include/unoidl/legacyprovider.hxx b/unoidl/source/legacyprovider.hxx
index cebdc1f764ea..538b66f02ca6 100644
--- a/include/unoidl/legacyprovider.hxx
+++ b/unoidl/source/legacyprovider.hxx
@@ -14,14 +14,11 @@
#include "registry/registry.hxx"
#include "rtl/ref.hxx"
-#include "sal/types.h"
-#include "unoidl/detail/dllapi.hxx"
#include "unoidl/unoidl.hxx"
+namespace unoidl { namespace detail {
-namespace unoidl {
-
-class LO_DLLPUBLIC_UNOIDL LegacyProvider: public Provider {
+class LegacyProvider: public Provider {
public:
// throws FileFormatException, NoSuchFileException:
LegacyProvider(
@@ -35,13 +32,13 @@ public:
const;
private:
- virtual SAL_DLLPRIVATE ~LegacyProvider() throw ();
+ virtual ~LegacyProvider() throw ();
rtl::Reference< Manager > manager_;
mutable RegistryKey ucr_;
};
-}
+} }
#endif
diff --git a/unoidl/source/sourceprovider.cxx b/unoidl/source/sourceprovider.cxx
index ea7f1103db5e..429f68f41898 100755
--- a/unoidl/source/sourceprovider.cxx
+++ b/unoidl/source/sourceprovider.cxx
@@ -20,14 +20,14 @@
#include "rtl/ref.hxx"
#include "rtl/ustrbuf.hxx"
#include "rtl/ustring.hxx"
-#include "unoidl/sourceprovider.hxx"
#include "unoidl/unoidl.hxx"
#include "sourceprovider-parser-requires.hxx"
#include "sourceprovider-parser.hxx"
#include "sourceprovider-scanner.hxx"
+#include "sourceprovider.hxx"
-namespace unoidl {
+namespace unoidl { namespace detail {
namespace {
@@ -35,7 +35,7 @@ rtl::Reference<Entity> parse(
rtl::Reference<Manager> const & manager, OUString const & name,
OUString const & uri, void const * address, sal_uInt64 size)
{
- detail::SourceProviderScannerData data(manager, address, size);
+ SourceProviderScannerData data(manager, address, size);
yyscan_t yyscanner;
if (yylex_init_extra(&data, &yyscanner) != 0) {
// Checking errno for the specific EINVAL, ENOMEM documented for
@@ -50,7 +50,7 @@ rtl::Reference<Entity> parse(
switch (e) {
case 0:
{
- std::map<OUString, detail::SourceProviderEntity>::const_iterator i(
+ std::map<OUString, SourceProviderEntity>::const_iterator i(
data.entities.find(name));
return i == data.entities.end()
? rtl::Reference<Entity>() : i->second.entity;
@@ -230,6 +230,6 @@ rtl::Reference<Entity> SourceProvider::findEntity(OUString const & name) const {
SourceProvider::~SourceProvider() throw () {}
-}
+} }
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/include/unoidl/sourceprovider.hxx b/unoidl/source/sourceprovider.hxx
index e5967116fcfc..e7ee92f64a0f 100644
--- a/include/unoidl/sourceprovider.hxx
+++ b/unoidl/source/sourceprovider.hxx
@@ -15,13 +15,11 @@
#include <map>
#include "rtl/ref.hxx"
-#include "sal/types.h"
-#include "unoidl/detail/dllapi.hxx"
#include "unoidl/unoidl.hxx"
-namespace unoidl {
+namespace unoidl { namespace detail {
-class LO_DLLPUBLIC_UNOIDL SourceProvider: public Provider {
+class SourceProvider: public Provider {
public:
// throws FileFormatException, NoSuchFileException:
SourceProvider(
@@ -34,14 +32,14 @@ public:
virtual rtl::Reference<Entity> findEntity(OUString const & name) const;
private:
- virtual SAL_DLLPRIVATE ~SourceProvider() throw ();
+ virtual ~SourceProvider() throw ();
rtl::Reference<Manager> manager_;
OUString uri_;
mutable std::map< OUString, rtl::Reference<Entity> > cache_; //TODO: at manager
};
-}
+} }
#endif
diff --git a/unoidl/source/unoidl.cxx b/unoidl/source/unoidl.cxx
index bdc7b98ed0d4..e5c3c434a357 100644
--- a/unoidl/source/unoidl.cxx
+++ b/unoidl/source/unoidl.cxx
@@ -17,10 +17,11 @@
#include "osl/mutex.hxx"
#include "rtl/ref.hxx"
#include "rtl/ustring.hxx"
-#include "unoidl/legacyprovider.hxx"
-#include "unoidl/sourceprovider.hxx"
#include "unoidl/unoidl.hxx"
-#include "unoidl/unoidlprovider.hxx"
+
+#include "legacyprovider.hxx"
+#include "sourceprovider.hxx"
+#include "unoidlprovider.hxx"
namespace unoidl {
@@ -113,17 +114,17 @@ rtl::Reference< Provider > loadProvider(
if (item.getFileStatus(status) == osl::FileBase::E_None
&& status.getFileType() == osl::FileStatus::Directory)
{
- return new SourceProvider(manager, uri);
+ return new detail::SourceProvider(manager, uri);
}
}
try {
- return new UnoidlProvider(uri);
+ return new detail::UnoidlProvider(uri);
} catch (FileFormatException & e) {
SAL_INFO(
"unoidl",
"FileFormatException \"" << e.getDetail() << "\", retrying <" << uri
<< "> as legacy format");
- return new LegacyProvider(manager, uri);
+ return new detail::LegacyProvider(manager, uri);
}
}
diff --git a/unoidl/source/unoidlprovider.cxx b/unoidl/source/unoidlprovider.cxx
index 47b6f9eb0399..b195f4473c0c 100644
--- a/unoidl/source/unoidlprovider.cxx
+++ b/unoidl/source/unoidlprovider.cxx
@@ -24,7 +24,10 @@
#include "sal/types.h"
#include "salhelper/simplereferenceobject.hxx"
#include "unoidl/unoidl.hxx"
-#include "unoidl/unoidlprovider.hxx"
+
+#include "unoidlprovider.hxx"
+
+namespace unoidl { namespace detail {
namespace {
@@ -114,10 +117,6 @@ struct Memory64 {
}
-namespace unoidl {
-
-namespace detail {
-
class MappedFile: public salhelper::SimpleReferenceObject {
public:
explicit MappedFile(OUString const & fileUrl);
@@ -365,15 +364,13 @@ struct MapEntry {
Memory32 data;
};
-}
-
namespace {
enum Compare { COMPARE_LESS, COMPARE_GREATER, COMPARE_EQUAL };
Compare compare(
- rtl::Reference< detail::MappedFile > const & file, OUString const & name,
- sal_Int32 nameOffset, sal_Int32 nameLength, detail::MapEntry const * entry)
+ rtl::Reference< MappedFile > const & file, OUString const & name,
+ sal_Int32 nameOffset, sal_Int32 nameLength, MapEntry const * entry)
{
assert(file.is());
assert(entry != 0);
@@ -411,15 +408,15 @@ Compare compare(
}
sal_uInt32 findInMap(
- rtl::Reference< detail::MappedFile > const & file,
- detail::MapEntry const * mapBegin, sal_uInt32 mapSize,
- OUString const & name, sal_Int32 nameOffset, sal_Int32 nameLength)
+ rtl::Reference< MappedFile > const & file, MapEntry const * mapBegin,
+ sal_uInt32 mapSize, OUString const & name, sal_Int32 nameOffset,
+ sal_Int32 nameLength)
{
if (mapSize == 0) {
return 0;
}
sal_uInt32 n = mapSize / 2;
- detail::MapEntry const * p = mapBegin + n;
+ MapEntry const * p = mapBegin + n;
switch (compare(file, name, nameOffset, nameLength, p)) {
case COMPARE_LESS:
return findInMap(file, mapBegin, n, name, nameOffset, nameLength);
@@ -438,7 +435,7 @@ sal_uInt32 findInMap(
}
std::vector< OUString > readAnnotations(
- bool annotated, rtl::Reference< detail::MappedFile > const & file,
+ bool annotated, rtl::Reference< MappedFile > const & file,
sal_uInt32 offset, sal_uInt32 * newOffset = 0)
{
std::vector< OUString > ans;
@@ -456,7 +453,7 @@ std::vector< OUString > readAnnotations(
}
ConstantValue readConstant(
- rtl::Reference< detail::MappedFile > const & file, sal_uInt32 offset,
+ rtl::Reference< MappedFile > const & file, sal_uInt32 offset,
sal_uInt32 * newOffset = 0, bool * annotated = 0)
{
assert(file.is());
@@ -546,13 +543,13 @@ ConstantValue readConstant(
}
rtl::Reference< Entity > readEntity(
- rtl::Reference< detail::MappedFile > const & file, sal_uInt32 offset);
+ rtl::Reference< MappedFile > const & file, sal_uInt32 offset);
class UnoidlCursor: public MapCursor {
public:
UnoidlCursor(
- rtl::Reference< detail::MappedFile > file,
- detail::MapEntry const * mapBegin, sal_uInt32 mapSize):
+ rtl::Reference< MappedFile > file, MapEntry const * mapBegin,
+ sal_uInt32 mapSize):
file_(file), mapIndex_(mapBegin), mapEnd_(mapBegin + mapSize)
{}
@@ -561,9 +558,9 @@ private:
virtual rtl::Reference< Entity > getNext(OUString * name);
- rtl::Reference< detail::MappedFile > file_;
- detail::MapEntry const * mapIndex_;
- detail::MapEntry const * mapEnd_;
+ rtl::Reference< MappedFile > file_;
+ MapEntry const * mapIndex_;
+ MapEntry const * mapEnd_;
};
rtl::Reference< Entity > UnoidlCursor::getNext(OUString * name) {
@@ -580,11 +577,11 @@ rtl::Reference< Entity > UnoidlCursor::getNext(OUString * name) {
class UnoidlModuleEntity: public ModuleEntity {
public:
UnoidlModuleEntity(
- rtl::Reference< detail::MappedFile > const & file, sal_uInt32 mapOffset,
+ rtl::Reference< MappedFile > const & file, sal_uInt32 mapOffset,
sal_uInt32 mapSize):
file_(file),
mapBegin_(
- reinterpret_cast< detail::MapEntry const * >(
+ reinterpret_cast< MapEntry const * >(
static_cast< char const * >(file_->address) + mapOffset)),
mapSize_(mapSize)
{ assert(file.is()); }
@@ -597,8 +594,8 @@ private:
virtual rtl::Reference< MapCursor > createCursor() const
{ return new UnoidlCursor(file_, mapBegin_, mapSize_); }
- rtl::Reference< detail::MappedFile > file_;
- detail::MapEntry const * mapBegin_;
+ rtl::Reference< MappedFile > file_;
+ MapEntry const * mapBegin_;
sal_uInt32 mapSize_;
};
@@ -611,7 +608,7 @@ std::vector< OUString > UnoidlModuleEntity::getMemberNames() const {
}
rtl::Reference< Entity > readEntity(
- rtl::Reference< detail::MappedFile > const & file, sal_uInt32 offset)
+ rtl::Reference< MappedFile > const & file, sal_uInt32 offset)
{
assert(file.is());
int v = file->read8(offset);
@@ -959,9 +956,8 @@ rtl::Reference< Entity > readEntity(
("UNOIDL format: constant group map offset + size too"
" large"));
}
- detail::MapEntry const * p
- = reinterpret_cast< detail::MapEntry const * >(
- static_cast< char const * >(file->address) + offset + 5);
+ MapEntry const * p = reinterpret_cast< MapEntry const * >(
+ static_cast< char const * >(file->address) + offset + 5);
std::vector< ConstantGroupEntity::Member > mems;
for (sal_uInt32 i = 0; i != n; ++i) {
sal_uInt32 off = p[i].data.getUnsigned32();
@@ -1179,8 +1175,7 @@ rtl::Reference< Entity > readEntity(
}
-UnoidlProvider::UnoidlProvider(OUString const & uri):
- file_(new detail::MappedFile(uri))
+UnoidlProvider::UnoidlProvider(OUString const & uri): file_(new MappedFile(uri))
{
if (file_->size < 8 || std::memcmp(file_->address, "UNOIDL\xFF\0", 8) != 0)
{
@@ -1195,7 +1190,7 @@ UnoidlProvider::UnoidlProvider(OUString const & uri):
throw FileFormatException(
file_->uri, "UNOIDL format: root map offset + size too large");
}
- mapBegin_ = reinterpret_cast< detail::MapEntry const * >(
+ mapBegin_ = reinterpret_cast< MapEntry const * >(
static_cast< char const * >(file_->address) + off);
}
@@ -1205,13 +1200,7 @@ rtl::Reference< MapCursor > UnoidlProvider::createRootCursor() const {
rtl::Reference< Entity > UnoidlProvider::findEntity(OUString const & name) const
{
- bool cnst;
- sal_uInt32 off = find(name, &cnst);
- return off == 0 || cnst ? rtl::Reference< Entity >() : getEntity(off);
-}
-
-sal_uInt32 UnoidlProvider::find(OUString const & name, bool * constant) const {
- detail::MapEntry const * mapBegin = mapBegin_;
+ MapEntry const * mapBegin = mapBegin_;
sal_uInt32 mapSize = mapSize_;
bool cgroup = false;
for (sal_Int32 i = 0;;) {
@@ -1221,16 +1210,13 @@ sal_uInt32 UnoidlProvider::find(OUString const & name, bool * constant) const {
}
sal_Int32 off = findInMap(file_, mapBegin, mapSize, name, i, j - i);
if (off == 0) {
- return 0;
+ return rtl::Reference< Entity >();
}
if (j == name.getLength()) {
- if (constant != 0) {
- *constant = cgroup;
- }
- return off;
+ return cgroup ? rtl::Reference< Entity >() : readEntity(file_, off);
}
if (cgroup) {
- return 0;
+ return rtl::Reference< Entity >();
//TODO: throw an exception instead here, where the segments of a
// constant's name are a prefix of the requested name's
// segments?
@@ -1240,7 +1226,7 @@ sal_uInt32 UnoidlProvider::find(OUString const & name, bool * constant) const {
if ((v & 0x3F) == 7) { // constant group
cgroup = true;
} else {
- return 0;
+ return rtl::Reference< Entity >();
//TODO: throw an exception instead here, where the segments
// of a non-module, non-constant-group entity's name are a
// prefix of the requested name's segments?
@@ -1251,22 +1237,14 @@ sal_uInt32 UnoidlProvider::find(OUString const & name, bool * constant) const {
throw FileFormatException(
file_->uri, "UNOIDL format: map offset + size too large");
}
- mapBegin = reinterpret_cast< detail::MapEntry const * >(
+ mapBegin = reinterpret_cast< MapEntry const * >(
static_cast< char const * >(file_->address) + off + 5);
i = j + 1;
}
}
-rtl::Reference< Entity > UnoidlProvider::getEntity(sal_uInt32 offset) const {
- return readEntity(file_, offset);
-}
-
-ConstantValue UnoidlProvider::getConstant(sal_uInt32 offset) const {
- return readConstant(file_, offset);
-}
-
UnoidlProvider::~UnoidlProvider() throw () {}
-}
+} }
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/include/unoidl/unoidlprovider.hxx b/unoidl/source/unoidlprovider.hxx
index d7d4fbb97f8c..712282a239fd 100644
--- a/include/unoidl/unoidlprovider.hxx
+++ b/unoidl/source/unoidlprovider.hxx
@@ -14,17 +14,14 @@
#include "rtl/ref.hxx"
#include "sal/types.h"
-#include "unoidl/detail/dllapi.hxx"
#include "unoidl/unoidl.hxx"
namespace unoidl { namespace detail {
- class MappedFile;
- struct MapEntry;
-} }
-namespace unoidl {
+class MappedFile;
+struct MapEntry;
-class LO_DLLPUBLIC_UNOIDL UnoidlProvider: public Provider {
+class UnoidlProvider: public Provider {
public:
// throws FileFormatException, NoSuchFileException:
explicit UnoidlProvider(OUString const & uri);
@@ -36,24 +33,15 @@ public:
virtual rtl::Reference< Entity > findEntity(OUString const & name)
const;
- // throws FileFormatException:
- sal_uInt32 find(OUString const & name, bool * constant = 0) const;
-
- // throws FileFormatException:
- rtl::Reference< Entity > getEntity(sal_uInt32 offset) const;
-
- // throws FileFormatException:
- ConstantValue getConstant(sal_uInt32 offset) const;
-
private:
- virtual SAL_DLLPRIVATE ~UnoidlProvider() throw ();
+ virtual ~UnoidlProvider() throw ();
rtl::Reference< detail::MappedFile > file_;
detail::MapEntry const * mapBegin_;
sal_uInt32 mapSize_;
};
-}
+} }
#endif