summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2016-02-04 15:06:30 +0100
committerStephan Bergmann <sbergman@redhat.com>2016-02-04 15:56:57 +0100
commit2f90103948742f1e588d90d4bcb05f943192eb4f (patch)
tree45aac080131ff826830f07ba54fd73827675f1c9
parent048f5e6847a4d1f9ed139b6ab7edaaddd80e42b3 (diff)
Add --ignore-unpublished to unoidl-check
...to make it a better replacement for SDK's regcompare Change-Id: I7b5eee3d449b8dc7c03601083d06a6d13e4607be
-rw-r--r--unoidl/source/unoidl-check.cxx52
1 files changed, 35 insertions, 17 deletions
diff --git a/unoidl/source/unoidl-check.cxx b/unoidl/source/unoidl-check.cxx
index e0993bae60fd..b54aeaeb697f 100644
--- a/unoidl/source/unoidl-check.cxx
+++ b/unoidl/source/unoidl-check.cxx
@@ -73,9 +73,10 @@ namespace {
void badUsage() {
std::cerr
<< "Usage:" << std::endl << std::endl
- << (" unoidl-check [<extra registries A>] <registry A> -- [<extra"
- " registries B>]")
- << std::endl << " <registry B>" << std::endl << std::endl
+ << (" unoidl-check [--ignore-unpublished] [<extra registries A>]"
+ " <registry A> --")
+ << std::endl << " [<extra registries B>] <registry B>" << std::endl
+ << std::endl
<< ("where each <registry> is either a new- or legacy-format .rdb file,"
" a single .idl")
<< std::endl
@@ -87,15 +88,24 @@ void badUsage() {
std::exit(EXIT_FAILURE);
}
-OUString getArgumentUri(sal_uInt32 argument, bool * delimiter) {
+bool getArgument(
+ sal_uInt32 argument, bool * ignoreUnpublished, bool * delimiter,
+ OUString * uri)
+{
+ assert(ignoreUnpublished != nullptr);
+ assert(uri != nullptr);
OUString arg;
rtl_getAppCommandArg(argument, &arg.pData);
+ if (argument == 0 && arg == "--ignore-unpublished") {
+ *ignoreUnpublished = true;
+ return false;
+ }
if (arg == "--") {
if (delimiter == nullptr) {
badUsage();
}
*delimiter = true;
- return OUString();
+ return false;
}
OUString url;
osl::FileBase::RC e1 = osl::FileBase::getFileURLFromSystemPath(arg, url);
@@ -113,15 +123,14 @@ OUString getArgumentUri(sal_uInt32 argument, bool * delimiter) {
<< std::endl;
std::exit(EXIT_FAILURE);
}
- OUString abs;
- e1 = osl::FileBase::getAbsoluteFileURL(cwd, url, abs);
+ e1 = osl::FileBase::getAbsoluteFileURL(cwd, url, *uri);
if (e1 != osl::FileBase::E_None) {
std::cerr
<< "Cannot make \"" << url
<< "\" into an absolute file URL, error code " << +e1 << std::endl;
std::exit(EXIT_FAILURE);
}
- return abs;
+ return true;
}
OUString showDirection(
@@ -151,7 +160,7 @@ private:
void checkMap(
rtl::Reference<unoidl::Provider> const & providerB, OUString const & prefix,
- rtl::Reference<unoidl::MapCursor> const & cursor)
+ rtl::Reference<unoidl::MapCursor> const & cursor, bool ignoreUnpublished)
{
assert(providerB.is());
assert(cursor.is());
@@ -166,8 +175,14 @@ void checkMap(
checkMap(
providerB, name + ".",
(static_cast<unoidl::ModuleEntity *>(entA.get())
- ->createCursor()));
+ ->createCursor()),
+ ignoreUnpublished);
} else {
+ bool pubA = dynamic_cast<unoidl::PublishableEntity &>(*entA.get())
+ .isPublished();
+ if (!pubA && ignoreUnpublished) {
+ continue;
+ }
rtl::Reference<unoidl::Entity> entB(providerB->findEntity(name));
if (!entB.is()) {
std::cerr
@@ -181,8 +196,7 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- if ((dynamic_cast<unoidl::PublishableEntity &>(*entA.get())
- .isPublished())
+ if (pubA
&& (!dynamic_cast<unoidl::PublishableEntity &>(*entB.get())
.isPublished()))
{
@@ -1170,12 +1184,14 @@ SAL_IMPLEMENT_MAIN() {
mgr[1] = new unoidl::Manager;
rtl::Reference<unoidl::Provider> prov[2];
int side = 0;
+ bool ignoreUnpublished = false;
for (sal_uInt32 i = 0; i != args; ++i) {
bool delimiter = false;
- OUString uri(getArgumentUri(i, side == 0 ? &delimiter : nullptr));
- if (delimiter) {
- side = 1;
- } else {
+ OUString uri;
+ if (getArgument(
+ i, &ignoreUnpublished, side == 0 ? &delimiter : nullptr,
+ &uri))
+ {
try {
prov[side] = mgr[side]->addProvider(uri);
} catch (unoidl::NoSuchFileException &) {
@@ -1183,12 +1199,14 @@ SAL_IMPLEMENT_MAIN() {
<< "Input <" << uri << "> does not exist" << std::endl;
std::exit(EXIT_FAILURE);
}
+ } else if (delimiter) {
+ side = 1;
}
}
if (side == 0 || !(prov[0].is() && prov[1].is())) {
badUsage();
}
- checkMap(prov[1], "", prov[0]->createRootCursor());
+ checkMap(prov[1], "", prov[0]->createRootCursor(), ignoreUnpublished);
checkIds(prov[0], "", prov[1]->createRootCursor());
return EXIT_SUCCESS;
} catch (unoidl::FileFormatException & e1) {