office-gobmx/autodoc/source/exes/adc_uni/adc_cl.cxx
Michael Meeks 535e83550e re-base on ALv2 code. Includes:
Avoid some uses of non portable #!/bin/bash in shell scripts.
    Patch contributed by Pedro Giffuni
    http://svn.apache.org/viewvc?view=revision&revision=1235297
    remove redundant namespace, patch contributed Mathias Bauer
    http://svn.apache.org/viewvc?view=revision&revision=1162610
    removal of OS/2 port changes, and preferring our similiar
    tools/inc/tools/solar.h DLLPOSTFIX cleanup.
    i118595 - Removal of the use of getopt() from rscdep.
    Patch contributed by Andre Fische
    http://svn.apache.org/viewvc?view=revision&revision=1202270
2012-07-11 18:12:35 +01:00

383 lines
10 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 <precomp.h>
#include <adc_cl.hxx>
// NOT FULLY DEFINED SERVICES
#include <algorithm>
#include <cosv/x.hxx>
#include <cosv/file.hxx>
#include <cosv/tpl/tpltools.hxx>
#include <ary/ary.hxx>
#include <tools/tkpchars.hxx>
#include <adc_msg.hxx>
#include "adc_cmds.hxx"
#include "adc_cmd_parse.hxx"
#include "cmd_sincedata.hxx"
namespace autodoc
{
CommandLine * CommandLine::pTheInstance_ = 0;
const char * const C_sUserGuide =
"\n\n\n"
" General Use of Autodoc\n"
" ----------------------\n"
"\n"
" Example for IDL:\n"
"\n"
" -html <OutputDirectory> -name \"UDK 3.x anything\" -lg idl\n"
" -t <SourceDir1> <SourceDir2>\n"
"\n"
" Instead of or in addition to -t may be\n"
" used -d (no subdirectories) or -f (just one file). There can\n"
" be multiple arguments after each of these options (-t -d -f).\n"
"\n"
"\n"
" Replacing @since Tag Content\n"
" ----------------------------\n"
"\n"
" You can give a transformation file to replace\n"
" entries in @since tags by different entries.\n"
" This file is given by the option\n"
" -sincefile <TransformationFilePath>\n"
" This option has to appear between the -html and the -lg option.\n"
" Example:\n"
" -html <OutputDirectory> -sincefile replacesince.txt\n"
" -name \"UDK 3.x anything\" -lg idl -t <SourceDir>\n"
"\n"
"\n";
CommandLine::CommandLine()
: nDebugStyle(0),
pSinceTransformator(new command::SinceTagTransformationData),
aCommands(),
bInitOk(false),
pCommand_CreateHtml(0),
pReposy( & ary::Repository::Create_() ),
bIdl(false)
{
csv_assert(pTheInstance_ == 0);
pTheInstance_ = this;
}
CommandLine::~CommandLine()
{
csv::erase_container_of_heap_ptrs(aCommands);
pTheInstance_ = 0;
}
int
CommandLine::Run() const
{
Cout() << "\nAutodoc version 2.2.5"
<< "\n---------------------"
<< "\n" << Endl();
bool
ok = true;
for ( CommandList::const_iterator it = aCommands.begin();
ok AND it != aCommands.end();
++it )
{
ok = (*it)->Run();
}
if (pCommand_CreateHtml != 0)
{
StreamStr aDiagnosticMessagesFile(700);
aDiagnosticMessagesFile
<< pCommand_CreateHtml->OutputDir()
<< csv::ploc::Delimiter()
<< "Autodoc_DiagnosticMessages.txt";
TheMessages().WriteFile(aDiagnosticMessagesFile.c_str());
}
return ok ? 0 : 1;
}
CommandLine &
CommandLine::Get_()
{
csv_assert(pTheInstance_ != 0);
return *pTheInstance_;
}
bool
CommandLine::DoesTransform_SinceTag() const
{
return pSinceTransformator->DoesTransform();
}
//bool
//CommandLine::Strip_SinceTagText( String & io_sSinceTagValue ) const
//{
// return pSinceTransformator->StripSinceTagText(io_sSinceTagValue);
//}
const String &
CommandLine::DisplayOf_SinceTagValue( const String & i_sVersionNumber ) const
{
return pSinceTransformator->DisplayOf(i_sVersionNumber);
}
void
CommandLine::do_Init( int argc,
char * argv[] )
{
try
{
bInitOk = false;
StringVector aParameters;
char * * itpEnd = &argv[0] + argc;
for ( char * * itp = &argv[1]; itp != itpEnd; ++itp )
{
if ( strncmp(*itp, "-I:", 3) != 0 )
aParameters.push_back(String(*itp));
else
load_IncludedCommands(aParameters, (*itp)+3);
}
StringVector::const_iterator itEnd = aParameters.end();
for ( StringVector::const_iterator it = aParameters.begin();
it != itEnd;
)
{
if ( *it == command::C_opt_Verbose )
do_clVerbose(it,itEnd);
else if ( *it == command::C_opt_LangAll
OR *it == command::C_opt_Name
OR *it == command::C_opt_DevmanFile )
do_clParse(it,itEnd);
else if (*it == command::C_opt_CreateHtml)
do_clCreateHtml(it,itEnd);
else if (*it == command::C_opt_SinceFile)
do_clSinceFile(it,itEnd);
else if (*it == command::C_opt_ExternNamespace)
{
sExternNamespace = *(++it);
++it;
if ( strncmp(sExternNamespace.c_str(), "::", 2) != 0)
{
throw command::X_CommandLine(
"-extnsp needs an absolute qualified namespace, starting with \"::\"."
);
}
}
else if (*it == command::C_opt_ExternRoot)
{
++it;
StreamLock sl(1000);
if ( csv::compare(*it, 0, "http://", 7) != 0 )
{
sl() << "http://" << *it;
}
if ( *(sl().end()-1) != '/')
sl() << '/';
sExternRoot = sl().c_str();
++it;
}
// else if (*it == command::C_opt_CreateXml)
// do_clCreateXml(it,itEnd);
// else if (command::C_opt_Load)
// do_clLoad(it,itEnd);
// else if (*it == command::C_opt_Save)
// do_clSave(it,itEnd);
else if (*it == "-h" OR *it == "-?" OR *it == "?")
// Leads to displaying help, because bInitOk stays on false.
return;
else if ( *it == command::C_opt_Parse )
// Only for backwards compatibility.
// Just ignore "-parse".
++it;
else
{
StreamLock sl(200);
throw command::X_CommandLine(
sl() << "Unknown commandline option \""
<< *it
<< "\"."
<< c_str );
}
} // end for
sort_Commands();
bInitOk = true;
} // end try
catch ( command::X_CommandLine & xxx )
{
xxx.Report( Cerr() );
}
catch ( csv::Exception & xxx )
{
xxx.GetInfo( Cerr() );
}
}
void
CommandLine::do_PrintUse() const
{
Cout() << C_sUserGuide << Endl();
}
bool
CommandLine::inq_CheckParameters() const
{
if (NOT bInitOk OR aCommands.empty())
return false;
return true;
}
void
CommandLine::load_IncludedCommands( StringVector & out,
const char * i_filePath )
{
CharacterSource
aIncludedCommands;
csv::File
aFile(i_filePath, csv::CFM_READ);
if (NOT aFile.open())
{
Cerr() << "Command include file \""
<< i_filePath
<< "\" not found."
<< Endl();
throw command::X_CommandLine("Invalid file in option -I:<command-file>.");
}
aIncludedCommands.LoadText(aFile);
aFile.close();
bool bInToken = false;
StreamLock aTransmit(200);
for ( ; NOT aIncludedCommands.IsFinished(); aIncludedCommands.MoveOn() )
{
if (bInToken)
{
if (aIncludedCommands.CurChar() <= 32)
{
const char *
pToken = aIncludedCommands.CutToken();
bInToken = false;
if ( strncmp(pToken, "-I:", 3) != 0 )
{
aTransmit().seekp(0);
aTransmit() << pToken;
aTransmit().replace_all('\\', *csv::ploc::Delimiter());
aTransmit().replace_all('/', *csv::ploc::Delimiter());
out.push_back(String(aTransmit().c_str()));
}
else
load_IncludedCommands(out, pToken+3);
}
}
else
{
if (aIncludedCommands.CurChar() > 32)
{
aIncludedCommands.CutToken();
bInToken = true;
}
} // endif (bInToken) else
} // end while()
}
namespace
{
inline int
v_nr(StringVector::const_iterator it)
{
return int( *(*it).c_str() ) - int('0');
}
} // anonymous namespace
void
CommandLine::do_clVerbose( opt_iter & it,
opt_iter itEnd )
{
++it;
if ( it == itEnd ? true : v_nr(it) < 0 OR v_nr(it) > 7 )
throw command::X_CommandLine( "Missing or invalid number in -v option." );
nDebugStyle = v_nr(it);
++it;
}
void
CommandLine::do_clParse( opt_iter & it,
opt_iter itEnd )
{
command::Command *
pCmd_Parse = new command::Parse;
pCmd_Parse->Init(it, itEnd);
aCommands.push_back(pCmd_Parse);
}
void
CommandLine::do_clCreateHtml( opt_iter & it,
opt_iter itEnd )
{
pCommand_CreateHtml = new command::CreateHtml;
pCommand_CreateHtml->Init(it, itEnd);
aCommands.push_back(pCommand_CreateHtml);
}
void
CommandLine::do_clSinceFile( opt_iter & it,
opt_iter itEnd )
{
pSinceTransformator->Init(it, itEnd);
}
namespace
{
struct Less_RunningRank
{
bool operator()(
const command::Command * const &
i1,
const command::Command * const &
i2 ) const
{ return i1->RunningRank() < i2->RunningRank(); }
};
} // anonymous namespace
void
CommandLine::sort_Commands()
{
std::sort( aCommands.begin(),
aCommands.end(),
Less_RunningRank() );
}
} // namespace autodoc
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */