Kaydet (Commit) 32afbf1a authored tarafından Stephan Bergmann's avatar Stephan Bergmann

Remove obsolete rdbedit tool

Change-Id: Ibc0885e4c073c09a673f08297bfc5de42f2b3c28
üst f74c5f27
...@@ -55,7 +55,6 @@ $(eval $(call gb_Helper_register_executables,NONE, \ ...@@ -55,7 +55,6 @@ $(eval $(call gb_Helper_register_executables,NONE, \
osl_process_child \ osl_process_child \
pdf2xml \ pdf2xml \
pdfunzip \ pdfunzip \
rdbedit \
propex \ propex \
regsvrex \ regsvrex \
renewpo \ renewpo \
......
# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
#
# 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/.
#
$(eval $(call gb_Executable_Executable,rdbedit))
$(eval $(call gb_Executable_use_libraries,rdbedit,\
sal \
reg \
))
$(eval $(call gb_Executable_use_static_libraries,rdbedit,\
registry_helper \
))
$(eval $(call gb_Executable_add_exception_objects,rdbedit,\
registry/tools/rdbedit \
))
# vim:set shiftwidth=4 softtabstop=4 expandtab:
...@@ -38,7 +38,6 @@ $(eval $(call gb_Module_add_targets,registry,\ ...@@ -38,7 +38,6 @@ $(eval $(call gb_Module_add_targets,registry,\
Executable_regmerge \ Executable_regmerge \
Executable_regview \ Executable_regview \
Executable_regcompare \ Executable_regcompare \
Executable_rdbedit \
)) ))
endif endif
......
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* 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/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include <stdio.h>
#include <string.h>
#include "registry/registry.hxx"
#include "registry/reflread.hxx"
#include <rtl/ustring.hxx>
#include <rtl/alloc.h>
#include <osl/process.h>
#include <osl/diagnose.h>
#include <osl/thread.h>
#include <osl/file.hxx>
#ifdef SAL_UNX
#define SEPARATOR '/'
#else
#define SEPARATOR '\\'
#endif
using namespace ::rtl;
using namespace ::osl;
sal_Bool isFileUrl(const OString& fileName)
{
if (fileName.indexOf("file://") == 0 )
return sal_True;
return sal_False;
}
OUString convertToFileUrl(const OString& fileName)
{
if ( isFileUrl(fileName) )
{
return OStringToOUString(fileName, osl_getThreadTextEncoding());
}
OUString uUrlFileName;
OUString uFileName(fileName.getStr(), fileName.getLength(), osl_getThreadTextEncoding());
if ( fileName.indexOf('.') == 0 || fileName.indexOf(SEPARATOR) < 0 )
{
OUString uWorkingDir;
if (osl_getProcessWorkingDir(&uWorkingDir.pData) != osl_Process_E_None)
{
OSL_ASSERT(false);
}
if (FileBase::getAbsoluteFileURL(uWorkingDir, uFileName, uUrlFileName)
!= FileBase::E_None)
{
OSL_ASSERT(false);
}
} else
{
if (FileBase::getFileURLFromSystemPath(uFileName, uUrlFileName)
!= FileBase::E_None)
{
OSL_ASSERT(false);
}
}
return uUrlFileName;
}
#define U2S( s ) \
OUStringToOString(s, RTL_TEXTENCODING_UTF8).getStr()
#define S2U( s ) \
OStringToOUString(s, RTL_TEXTENCODING_UTF8)
struct LessString
{
sal_Bool operator()(const OUString& str1, const OUString& str2) const
{
return (str1 < str2);
}
};
enum Command {
DELETEKEY
};
class Options
{
public:
Options()
: m_bVerbose(false)
{}
~Options()
{}
bool initOptions(int ac, char* av[]);
OString prepareHelp();
OString prepareVersion();
const OString& getProgramName() const
{ return m_program; }
const OString& getTypeReg() const
{ return m_typeRegName; }
const OString& getKeyName() const
{ return m_keyName; }
Command getCommand() const
{ return m_command; }
bool verbose() const
{ return m_bVerbose; }
protected:
OString m_program;
OString m_typeRegName;
OString m_keyName;
Command m_command;
bool m_bVerbose;
};
bool Options::initOptions(int ac, char* av[])
{
bool bRet = true;
sal_uInt16 i=1;
if (ac < 2)
{
fprintf(stderr, "%s", prepareHelp().getStr());
bRet = sal_False;
}
m_program = av[0];
sal_Int32 index = -1;
if ((index=m_program.lastIndexOf(SEPARATOR)) > 0)
m_program = av[0]+index+1;
char *s=NULL;
for (; i < ac; i++)
{
if (av[i][0] == '-')
{
switch (av[i][1])
{
case 'r':
case 'R':
if (av[i][2] == '\0')
{
if (i < ac - 1 && av[i+1][0] != '-')
{
i++;
s = av[i];
} else
{
fprintf(stderr, "%s: invalid option '%s'\n", m_program.getStr(), av[i]);
bRet = sal_False;
break;
}
} else
{
s = av[i] + 2;
}
m_typeRegName = OString(s);
break;
case 'd':
case 'D':
if (av[i][2] == '\0')
{
if (i < ac - 1 && av[i+1][0] != '-')
{
i++;
s = av[i];
} else
{
fprintf(stderr, "%s: invalid option '%s'\n", m_program.getStr(), av[i]);
bRet = sal_False;
break;
}
} else
{
s = av[i] + 2;
}
m_keyName = OString(s);
break;
case 'v':
case 'V':
if (av[i][2] != '\0')
{
fprintf(stderr, "%s: invalid option '%s'\n", m_program.getStr(), av[i]);
bRet = sal_False;
}
m_bVerbose = true;
break;
case 'h':
case '?':
if (av[i][2] != '\0')
{
fprintf(stderr, "%s: invalid option '%s'\n", m_program.getStr(), av[i]);
bRet = false;
} else
{
fprintf(stdout, "%s", prepareHelp().getStr());
exit(0);
}
break;
default:
fprintf(stderr, "%s: unknown option '%s'\n", m_program.getStr(), av[i]);
bRet = false;
break;
}
} else
{
fprintf(stderr, "%s: unknown option '%s'\n", m_program.getStr(), av[i]);
bRet = false;
}
}
return bRet;
}
OString Options::prepareHelp()
{
OString help("\nusing: ");
help += m_program + " -r<filename> <command>\n";
help += " -r<filename> = filename specifies the name of the type registry.\n";
help += "Commands:\n";
help += " -d <keyname> = delete the specified key from the registry. Keyname\n";
help += " specifies the name of the key that get deleted.\n";
help += " -v = verbose output.\n";
help += " -h|-? = print this help message and exit.\n";
help += prepareVersion();
return help;
}
OString Options::prepareVersion()
{
OString version(m_program);
version += " Version 1.0\n\n";
return version;
}
static Options options;
#if (defined UNX) || (defined __MINGW32__)
int main( int argc, char * argv[] )
#else
int _cdecl main( int argc, char * argv[] )
#endif
{
if ( !options.initOptions(argc, argv) )
{
exit(1);
}
OUString typeRegName( convertToFileUrl(options.getTypeReg()) );
Registry typeReg;
if ( typeReg.open(typeRegName, REG_READWRITE) )
{
fprintf(stderr, "%s: open registry \"%s\" failed\n",
options.getProgramName().getStr(), options.getTypeReg().getStr());
exit(2);
}
RegistryKey typeRoot;
if ( typeReg.openRootKey(typeRoot) )
{
fprintf(stderr, "%s: open root key of registry \"%s\" failed\n",
options.getProgramName().getStr(), options.getTypeReg().getStr());
exit(3);
}
if ( options.getCommand() == DELETEKEY )
{
if ( typeRoot.deleteKey(S2U(options.getKeyName())) )
{
fprintf(stderr, "%s: delete key \"%s\" of registry \"%s\" failed\n",
options.getProgramName().getStr(), options.getKeyName().getStr(), options.getTypeReg().getStr());
exit(4);
} else {
if (options.verbose())
fprintf(stderr, "%s: delete key \"%s\" of registry \"%s\"\n",
options.getProgramName().getStr(), options.getKeyName().getStr(), options.getTypeReg().getStr());
}
}
typeRoot.releaseKey();
if ( typeReg.close() )
{
fprintf(stderr, "%s: closing registry \"%s\" failed\n",
options.getProgramName().getStr(), options.getTypeReg().getStr());
exit(5);
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment