Make cppumaker work on top of unoidl/ instead of registry/, as a first step to
change all the various codemakers.
* API CHANGE: cppumaker no longer supports the -B switch, as that is meaningless
with the new format. When reading from an old-format .rdb file, /UCR is
hard-coded as the prefix now.
* TODO: The new format does not yet support deprecation annotations, so the
generated .hdl/.hpp files lack any SAL_DEPRECATED_INTERNALs for now.
* codemaker/typemanager.hxx is extended with access to unoidl/ functionality, so
the various codemakers can use registry/ and unoidl/ in parallel for now.
The access to registry/ functionality will be removed. (Added small throwaway
helper functions u2b/b2u to easily map between OString and OUString at the
remaining seams for now.)
* Includes a selective revert of ba044b1e96
"remove needless forward rtl::OUString declarations" in those parts of
codemaker, unodevtools, unoidl that were covered by this local
work-in-progress patch; I would otherwise have hard a hard time re-applying
it.
* The generated .hdl/.hpp files are mostly unchanged, except for a few minor
things:
** Any SAL_DEPRECATED_INTERNALs are missing (see above).
** In comprehensive getCppuType definitions, some members were erroneously
classified as TypeCalss_UNKNOWN.
** In comprehensive getCppuType definitions, some unnecessary calls like
::cppu::UnoType< ::sal_Int32 >::get();
can be removed.
** For typedef sequence<X>, the .hdl file need not include X.hdl, but only needs
to forward-declare it.
** Unnecessary includes for optional bases of interfaces can be removed.
** Some numbering of local variable names (sMethodName1, ...) has changed.
Change-Id: Icad98f248ac15177337f1b4ab709a755a8af6238
342 lines
11 KiB
C++
342 lines
11 KiB
C++
/* -*- 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 "cppuoptions.hxx"
|
|
#include "osl/thread.h"
|
|
#include "osl/process.h"
|
|
|
|
using ::rtl::OUString;
|
|
using ::rtl::OUStringToOString;
|
|
using ::rtl::OString;
|
|
|
|
#ifdef SAL_UNX
|
|
#define SEPARATOR '/'
|
|
#else
|
|
#define SEPARATOR '\\'
|
|
#endif
|
|
|
|
sal_Bool CppuOptions::initOptions(int ac, char* av[], sal_Bool bCmdFile)
|
|
throw( IllegalArgument )
|
|
{
|
|
sal_Bool ret = sal_True;
|
|
sal_uInt16 i=0;
|
|
|
|
if (!bCmdFile)
|
|
{
|
|
bCmdFile = sal_True;
|
|
|
|
OString name(av[0]);
|
|
sal_Int32 index = name.lastIndexOf(SEPARATOR);
|
|
m_program = name.copy((index > 0 ? index+1 : 0));
|
|
|
|
if (ac < 2)
|
|
{
|
|
fprintf(stderr, "%s", prepareHelp().getStr());
|
|
ret = sal_False;
|
|
}
|
|
|
|
i = 1;
|
|
}
|
|
else
|
|
{
|
|
i = 0;
|
|
}
|
|
|
|
char *s=NULL;
|
|
for( ; i < ac; i++)
|
|
{
|
|
if (av[i][0] == '-')
|
|
{
|
|
switch (av[i][1])
|
|
{
|
|
case 'O':
|
|
if (av[i][2] == '\0')
|
|
{
|
|
if (i < ac - 1 && av[i+1][0] != '-')
|
|
{
|
|
i++;
|
|
s = av[i];
|
|
}
|
|
else
|
|
{
|
|
OString tmp("'-O', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i+1]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
s = av[i] + 2;
|
|
}
|
|
|
|
m_options["-O"] = OString(s);
|
|
break;
|
|
case 'T':
|
|
if (av[i][2] == '\0')
|
|
{
|
|
if (i < ac - 1 && av[i+1][0] != '-')
|
|
{
|
|
i++;
|
|
s = av[i];
|
|
}
|
|
else
|
|
{
|
|
OString tmp("'-T', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i+1]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
s = av[i] + 2;
|
|
}
|
|
|
|
if (m_options.count("-T") > 0)
|
|
{
|
|
OString tmp(m_options["-T"]);
|
|
tmp = tmp + ";" + s;
|
|
m_options["-T"] = tmp;
|
|
}
|
|
else
|
|
{
|
|
m_options["-T"] = OString(s);
|
|
}
|
|
break;
|
|
case 'L':
|
|
if (av[i][2] != '\0')
|
|
{
|
|
OString tmp("'-L', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
|
|
if (isValid("-C") || isValid("-CS"))
|
|
{
|
|
OString tmp("'-L' could not be combined with '-C' or '-CS' option");
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
m_options["-L"] = OString("");
|
|
break;
|
|
case 'C':
|
|
if (av[i][2] == 'S')
|
|
{
|
|
if (av[i][3] != '\0')
|
|
{
|
|
OString tmp("'-CS', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
|
|
if (isValid("-L") || isValid("-C"))
|
|
{
|
|
OString tmp("'-CS' could not be combined with '-L' or '-C' option");
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
m_options["-CS"] = OString("");
|
|
break;
|
|
}
|
|
else if (av[i][2] != '\0')
|
|
{
|
|
OString tmp("'-C', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
|
|
if (isValid("-L") || isValid("-CS"))
|
|
{
|
|
OString tmp("'-C' could not be combined with '-L' or '-CS' option");
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
m_options["-C"] = OString("");
|
|
break;
|
|
case 'G':
|
|
if (av[i][2] == 'c')
|
|
{
|
|
if (av[i][3] != '\0')
|
|
{
|
|
OString tmp("'-Gc', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
|
|
m_options["-Gc"] = OString("");
|
|
break;
|
|
}
|
|
else if (av[i][2] != '\0')
|
|
{
|
|
OString tmp("'-G', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
|
|
m_options["-G"] = OString("");
|
|
break;
|
|
case 'X': // support for eXtra type rdbs
|
|
{
|
|
if (av[i][2] == '\0')
|
|
{
|
|
if (i < ac - 1 && av[i+1][0] != '-')
|
|
{
|
|
i++;
|
|
s = av[i];
|
|
}
|
|
else
|
|
{
|
|
OString tmp("'-X', please check");
|
|
if (i <= ac - 1)
|
|
{
|
|
tmp += " your input '" + OString(av[i+1]) + "'";
|
|
}
|
|
|
|
throw IllegalArgument(tmp);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
s = av[i] + 2;
|
|
}
|
|
|
|
m_extra_input_files.push_back( s );
|
|
break;
|
|
}
|
|
|
|
default:
|
|
throw IllegalArgument("the option is unknown" + OString(av[i]));
|
|
}
|
|
} else
|
|
{
|
|
if (av[i][0] == '@')
|
|
{
|
|
FILE* cmdFile = fopen(av[i]+1, "r");
|
|
if( cmdFile == NULL )
|
|
{
|
|
fprintf(stderr, "%s", prepareHelp().getStr());
|
|
ret = sal_False;
|
|
}
|
|
else
|
|
{
|
|
int rargc=0;
|
|
char* rargv[512];
|
|
char buffer[512];
|
|
|
|
while ( fscanf(cmdFile, "%s", buffer) != EOF )
|
|
{
|
|
rargv[rargc]= strdup(buffer);
|
|
rargc++;
|
|
}
|
|
fclose(cmdFile);
|
|
|
|
ret = initOptions(rargc, rargv, bCmdFile);
|
|
|
|
for (long j=0; j < rargc; j++)
|
|
{
|
|
free(rargv[j]);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (bCmdFile)
|
|
{
|
|
m_inputFiles.push_back(av[i]);
|
|
}
|
|
else
|
|
{
|
|
OUString system_filepath;
|
|
if (osl_getCommandArg( i-1, &system_filepath.pData )
|
|
!= osl_Process_E_None)
|
|
{
|
|
OSL_ASSERT(false);
|
|
}
|
|
m_inputFiles.push_back(OUStringToOString(system_filepath, osl_getThreadTextEncoding()));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
OString CppuOptions::prepareHelp()
|
|
{
|
|
OString help("\nusing: ");
|
|
help += m_program + " [-options] file_1 ... file_n\nOptions:\n";
|
|
help += " -O<path> = path describes the root directory for the generated output.\n";
|
|
help += " The output directory tree is generated under this directory.\n";
|
|
help += " -T<name> = name specifies a type or a list of types. The output for this\n";
|
|
help += " [t1;...] type is generated. If no '-T' option is specified,\n";
|
|
help += " then output for all types is generated.\n";
|
|
help += " Example: 'com.sun.star.uno.XInterface' is a valid type.\n";
|
|
help += " -L = UNO type functions are generated lightweight, that means only\n";
|
|
help += " the name and typeclass are given and everything else is retrieved\n";
|
|
help += " from the type library dynamically. The default is that UNO type\n";
|
|
help += " functions provides enough type information for boostrapping C++.\n";
|
|
help += " '-L' should be the default for external components.\n";
|
|
help += " -C = UNO type functions are generated comprehensive that means all\n";
|
|
help += " necessary information is available for bridging the type in UNO.\n";
|
|
help += " -G = generate only target files which does not exists.\n";
|
|
help += " -Gc = generate only target files which content will be changed.\n";
|
|
help += " -X<file> = extra types which will not be taken into account for generation.\n\n";
|
|
help += prepareVersion();
|
|
|
|
return help;
|
|
}
|
|
|
|
OString CppuOptions::prepareVersion()
|
|
{
|
|
OString version(m_program);
|
|
version += " Version 2.0\n\n";
|
|
return version;
|
|
}
|
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|