summaryrefslogtreecommitdiff
path: root/l10ntools/source/localize.cxx
diff options
context:
space:
mode:
authorZolnai Tamás <zolnaitamas2000g@gmail.com>2012-11-26 15:14:11 +0100
committerZolnai Tamás <zolnaitamas2000g@gmail.com>2012-11-26 15:49:56 +0100
commit54f2fad47b002c498b66b899a3cbcdad4bd11197 (patch)
treec79614eb7d7a117659fe94f8780ba8d93332c0de /l10ntools/source/localize.cxx
parent2981921b49c9bc5748a01dec9ee039aace0bc80e (diff)
Varnisch localize.cxx
Use getenv method instead of osl_getEnvironment. Delete rtl and std namespace identifier Use OString every possible place to decrease OString<->OUString conversions. Add some block to minimize scope of local variables and add comments to make clear each block task. Move propex "en_US exist in file name" check to localize to save some extra process time. Change-Id: I9a0455f7524f71e34efe4d32998d2d21601f14e1
Diffstat (limited to 'l10ntools/source/localize.cxx')
-rw-r--r--l10ntools/source/localize.cxx352
1 files changed, 163 insertions, 189 deletions
diff --git a/l10ntools/source/localize.cxx b/l10ntools/source/localize.cxx
index cf211930631d..2a4ec00ec899 100644
--- a/l10ntools/source/localize.cxx
+++ b/l10ntools/source/localize.cxx
@@ -28,12 +28,11 @@
#include "boost/noncopyable.hpp"
#include "osl/file.h"
#include "osl/file.hxx"
-#include "osl/process.h"
#include "osl/thread.h"
#include "rtl/string.h"
#include "rtl/string.hxx"
#include "rtl/textcvt.h"
-#include "rtl/ustrbuf.hxx"
+#include "rtl/strbuf.hxx"
#include "rtl/ustring.h"
#include "rtl/ustring.hxx"
#include "sal/macros.h"
@@ -46,37 +45,26 @@ using namespace std;
namespace {
-rtl::OUString getEnvironment(rtl::OUString const & variable) {
- rtl::OUString value;
- if (osl_getEnvironment(variable.pData, &value.pData) != osl_Process_E_None)
- {
- std::cerr
- << "Error: cannot get environment variable " << variable << '\n';
- throw false; //TODO
- }
- return value;
-}
-
class TempFile: private boost::noncopyable {
public:
TempFile() {
if (osl::FileBase::createTempFile(0, 0, &url_) != osl::FileBase::E_None)
{
- std::cerr << "osl::FileBase::createTempFile() failed\n";
+ cerr << "osl::FileBase::createTempFile() failed\n";
throw false; //TODO
}
}
~TempFile() {
if (osl::File::remove(url_) != osl::FileBase::E_None) {
- std::cerr << "Warning: failure removing temporary " << url_ << '\n';
+ cerr << "Warning: failure removing temporary " << url_ << '\n';
}
}
- rtl::OUString getUrl() const { return url_; }
+ OUString getUrl() const { return url_; }
private:
- rtl::OUString url_;
+ OUString url_;
};
struct AsciiString {
@@ -85,9 +73,9 @@ struct AsciiString {
};
bool matchList(
- rtl::OUString const & url, AsciiString const * list, std::size_t length)
+ OUString const & url, AsciiString const * list, size_t length)
{
- for (std::size_t i = 0; i != length; ++i) {
+ for (size_t i = 0; i != length; ++i) {
if (url.endsWithAsciiL(list[i].string, list[i].length)) {
return true;
}
@@ -95,7 +83,7 @@ bool matchList(
return false;
}
-bool passesNegativeList(rtl::OUString const & url) {
+bool passesNegativeList(OUString const & url) {
static AsciiString const list[] = {
{ RTL_CONSTASCII_STRINGPARAM("/dictionaries.xcu") },
{ RTL_CONSTASCII_STRINGPARAM(
@@ -119,7 +107,7 @@ bool passesNegativeList(rtl::OUString const & url) {
return !matchList(url, list, SAL_N_ELEMENTS(list));
}
-bool passesPositiveList(rtl::OUString const & url) {
+bool passesPositiveList(OUString const & url) {
static AsciiString const list[] = {
{ RTL_CONSTASCII_STRINGPARAM(
"/chart2/source/controller/dialogs/res_DataLabel_tmpl.hrc") },
@@ -159,118 +147,112 @@ bool passesPositiveList(rtl::OUString const & url) {
}
void handleCommand(
- rtl::OUString const & project, rtl::OUString const & projectRoot,
- rtl::OUString const & url, rtl::OUString const & actualDir,
- PoOfstream & rPoOutPut, rtl::OUString const & executable, bool positive)
+ OString const & project, OString const & projectRoot,
+ OUString const & url, OString const & actualPotDir,
+ PoOfstream & rPoOutPut, OString const & executable, bool positive)
{
if (positive ? passesPositiveList(url) : passesNegativeList(url)) {
- rtl::OUString inPath;
- if (osl::FileBase::getSystemPathFromFileURL(url, inPath) !=
- osl::FileBase::E_None)
+
+ //Get input file path
+ OString inPath;
{
- std::cerr
- << "osl::FileBase::getSystemPathFromFileURL(" << url
- << ") failed\n";
- throw false; //TODO
+ OUString inPathTmp;
+ if (osl::FileBase::getSystemPathFromFileURL(url, inPathTmp) !=
+ osl::FileBase::E_None)
+ {
+ cerr
+ << "osl::FileBase::getSystemPathFromFileURL(" << url
+ << ") failed\n";
+ throw false; //TODO
+ }
+ inPath = OUStringToOString( inPathTmp, RTL_TEXTENCODING_UTF8 );
}
+
+ //Get output file path
TempFile temp;
- rtl::OUString outPath;
- if (osl::FileBase::getSystemPathFromFileURL(temp.getUrl(), outPath)
- != osl::FileBase::E_None)
+ OString outPath;
{
- std::cerr
- << "osl::FileBase::getSystemPathFromFileURL(" << temp.getUrl()
- << ") failed\n";
- throw false; //TODO
- }
- rtl::OUStringBuffer buf(
- getEnvironment(
- rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("SOLARVER"))));
- buf.append('/');
- buf.append(
- getEnvironment(
- rtl::OUString(
- RTL_CONSTASCII_USTRINGPARAM("INPATH_FOR_BUILD"))));
- buf.appendAscii(RTL_CONSTASCII_STRINGPARAM("/bin/"));
- buf.append(executable);
- buf.appendAscii(RTL_CONSTASCII_STRINGPARAM(" -p "));
- buf.append(project);
- buf.appendAscii(RTL_CONSTASCII_STRINGPARAM(" -r "));
- buf.append(projectRoot);
- buf.appendAscii(RTL_CONSTASCII_STRINGPARAM(" -i "));
- buf.append(inPath);
- buf.appendAscii(RTL_CONSTASCII_STRINGPARAM(" -o "));
- buf.append(outPath);
- buf.appendAscii(RTL_CONSTASCII_STRINGPARAM(" -l en-US"));
- rtl::OString cmd;
- if (!buf.makeStringAndClear().convertToString(
- &cmd, osl_getThreadTextEncoding(),
- (RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR
- | RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR)))
- {
- std::cerr << "Error: Cannot convert command from UTF-16\n";
- throw false; //TODO
- }
- if (system(cmd.getStr()) != 0) {
- std::cerr << "Error: Failed to execute " << cmd.getStr() << '\n';
- throw false; //TODO
+ OUString outPathTmp;
+ if (osl::FileBase::getSystemPathFromFileURL(temp.getUrl(),outPathTmp)
+ != osl::FileBase::E_None)
+ {
+ cerr
+ << "osl::FileBase::getSystemPathFromFileURL("
+ << temp.getUrl() << ") failed\n";
+ throw false; //TODO
+ }
+ outPath = OUStringToOString( outPathTmp, RTL_TEXTENCODING_UTF8 );
}
- rtl::OString outPath8;
- if (!outPath.convertToString(
- &outPath8, osl_getThreadTextEncoding(),
- (RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR
- | RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR)))
+
+ //Call the executable
{
- std::cerr << "Error: Cannot convert pathname from UTF-16\n";
- throw false; //TODO
+ OStringBuffer buf(OString(getenv("SOLARVER")));
+ buf.append('/');
+ buf.append(OString(getenv("INPATH_FOR_BUILD")));
+ buf.append("/bin/");
+ buf.append(executable);
+ buf.append(" -p ");
+ buf.append(project);
+ buf.append(" -r ");
+ buf.append(projectRoot);
+ buf.append(" -i ");
+ buf.append(inPath);
+ buf.append(" -o ");
+ buf.append(outPath);
+ buf.append(" -l en-US");
+
+ const OString cmd = buf.makeStringAndClear();
+ if (system(cmd.getStr()) != 0) {
+ cerr << "Error: Failed to execute " << cmd.getStr() << '\n';
+ throw false; //TODO
+ }
}
- std::ifstream in(outPath8.getStr());
+
+ ifstream in(outPath.getStr());
if (!in.is_open()) {
- std::cerr << "Error: Cannot open " << outPath8.getStr() << "\n";
+ cerr << "Error: Cannot open " << outPath.getStr() << "\n";
throw false; //TODO
}
- std::string s;
- std::getline(in, s);
+ string s;
+ getline(in, s);
if (!in.eof() && !rPoOutPut.isOpen())
{
- rtl::OUString outDirUrl;
- if (osl::FileBase::getFileURLFromSystemPath(actualDir.
- copy(0,actualDir.lastIndexOf('/')), outDirUrl)
- != osl::FileBase::E_None)
+ //Create directory for po file
{
- std::cerr << "Error: Cannot convert pathname to URL\n";
- throw false; //TODO
+ OUString outDir =
+ OStringToOUString(
+ actualPotDir.copy(0,actualPotDir.lastIndexOf('/')),
+ RTL_TEXTENCODING_UTF8);
+ OUString outDirUrl;
+ if (osl::FileBase::getFileURLFromSystemPath(outDir, outDirUrl)
+ != osl::FileBase::E_None)
+ {
+ cerr << "Error: Cannot convert pathname to URL\n";
+ throw false; //TODO
+ }
+ osl::Directory::createPath(outDirUrl);
}
- osl::Directory::createPath(outDirUrl);
- rtl::OString outFilePath;
- if (!actualDir.concat(".pot").
- convertToString(
- &outFilePath, osl_getThreadTextEncoding(),
- (RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR
- | RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR)))
- {
- std::cerr << "Error: Cannot convert pathname from UTF-16\n";
- throw false; //TODO
- }
- rPoOutPut.open(outFilePath.getStr());
- if (!rPoOutPut.isOpen())
+ //Open po file
{
- std::cerr
- << "Error: Cannot open po file "
- << outFilePath.getStr() << "\n";
- throw false; //TODO
+ OString outFilePath = actualPotDir.concat(".pot");
+ rPoOutPut.open(outFilePath.getStr());
+ if (!rPoOutPut.isOpen())
+ {
+ cerr
+ << "Error: Cannot open po file "
+ << outFilePath.getStr() << "\n";
+ throw false; //TODO
+ }
}
- //Add header to actual po file
+ //Add header to po file
{
const sal_Int32 nProjectInd = inPath.indexOf(project);
const OString relativPath =
- OUStringToOString(
- inPath.copy( nProjectInd,
- inPath.lastIndexOf('/')- nProjectInd),
- RTL_TEXTENCODING_UTF8 );
+ inPath.copy(
+ nProjectInd, inPath.lastIndexOf('/')- nProjectInd);
PoHeader aTmp(relativPath);
rPoOutPut.writeHeader(aTmp);
@@ -292,29 +274,29 @@ void handleCommand(
{
if(aException == PoEntry::INVALIDSDFLINE)
{
- std::cerr
- << executable
+ cerr
+ << executable.getStr()
<< "'s output is invalid:\n"
<< sLine.replaceAll("\t","\\t").getStr()
- << std::endl;
+ << endl;
throw false; //TODO
}
}
- std::getline(in, s);
+ getline(in, s);
};
in.close();
}
}
void handleFile(
- rtl::OUString const & project, rtl::OUString const & projectRoot,
- rtl::OUString const & url, rtl::OUString const & actualDir,
+ OString const & project, OString const & projectRoot,
+ OUString const & url, OString const & actualPotDir,
PoOfstream & rPoOutPut)
{
struct Command {
char const * extension;
sal_Int32 extensionLength;
- char const * executable;
+ OString executable;
bool positive;
};
static Command const commands[] = {
@@ -328,21 +310,23 @@ void handleFile(
{ RTL_CONSTASCII_STRINGPARAM(".properties"), "propex", false },
{ RTL_CONSTASCII_STRINGPARAM(".ui"), "uiex", false },
{ RTL_CONSTASCII_STRINGPARAM(".tree"), "treex", false } };
- for (std::size_t i = 0; i != SAL_N_ELEMENTS(commands); ++i) {
+ for (size_t i = 0; i != SAL_N_ELEMENTS(commands); ++i)
+ {
if (url.endsWithAsciiL(
- commands[i].extension, commands[i].extensionLength))
+ commands[i].extension, commands[i].extensionLength) &&
+ (commands[i].executable != "propex" || url.indexOf("en_US") != -1)
+)
{
handleCommand(
- project, projectRoot, url, actualDir, rPoOutPut,
- rtl::OUString::createFromAscii(commands[i].executable),
- commands[i].positive);
+ project, projectRoot, url, actualPotDir, rPoOutPut,
+ commands[i].executable, commands[i].positive);
break;
}
}
}
-bool includeProject(rtl::OUString const & project) {
- static char const * projects[] = {
+bool includeProject(OString const & project) {
+ static OString projects[] = {
"accessibility",
"avmedia",
"basctl",
@@ -392,34 +376,34 @@ bool includeProject(rtl::OUString const & project) {
"vcl",
"wizards",
"xmlsecurity" };
- for (std::size_t i = 0; i != SAL_N_ELEMENTS(projects); ++i) {
- if (project.equalsAscii(projects[i])) {
+ for (size_t i = 0; i != SAL_N_ELEMENTS(projects); ++i) {
+ if (project == projects[i]) {
return true;
}
}
return false;
}
-bool excludeDirectory(rtl::OUString const & directory) {
+bool excludeDirectory(OString const & directory) {
// Cf. OUTPATH=* in configure.in:
- static AsciiString const excluded[] = {
- { RTL_CONSTASCII_STRINGPARAM("callcatcher") },
- { RTL_CONSTASCII_STRINGPARAM("unxaig") },
- { RTL_CONSTASCII_STRINGPARAM("unxand") },
- { RTL_CONSTASCII_STRINGPARAM("unxdfly") },
- { RTL_CONSTASCII_STRINGPARAM("unxfbsd") },
- { RTL_CONSTASCII_STRINGPARAM("unxios") },
- { RTL_CONSTASCII_STRINGPARAM("unxkfg") },
- { RTL_CONSTASCII_STRINGPARAM("unxlng") },
- { RTL_CONSTASCII_STRINGPARAM("unxmac") },
- { RTL_CONSTASCII_STRINGPARAM("unxnbsd") },
- { RTL_CONSTASCII_STRINGPARAM("unxobsd") },
- { RTL_CONSTASCII_STRINGPARAM("unxsog") },
- { RTL_CONSTASCII_STRINGPARAM("unxsol") },
- { RTL_CONSTASCII_STRINGPARAM("unxubt") },
- { RTL_CONSTASCII_STRINGPARAM("wntmsc") } };
- for (std::size_t i = 0; i != SAL_N_ELEMENTS(excluded); ++i) {
- if (directory.matchAsciiL(excluded[i].string, excluded[i].length)) {
+ static OString const excluded[] = {
+ "callcatcher",
+ "unxaig",
+ "unxand",
+ "unxdfly",
+ "unxfbsd",
+ "unxios",
+ "unxkfg",
+ "unxlng",
+ "unxmac",
+ "unxnbsd",
+ "unxobsd",
+ "unxsog",
+ "unxsol",
+ "unxubt",
+ "wntmsc" };
+ for (size_t i = 0; i != SAL_N_ELEMENTS(excluded); ++i) {
+ if (directory == excluded[i]) {
return true;
}
}
@@ -442,17 +426,16 @@ bool excludeDirectory(rtl::OUString const & directory) {
///
/// @param the relative path back to the project root (empty and ignored if
/// level <= 0)
+/// @param actualPotDir the path of pot directory
void handleDirectory(
- rtl::OUString const & url, int level, rtl::OUString const & project,
- rtl::OUString const & projectRoot, rtl::OUString const & actualDir)
+ OUString const & url, int level, OString const & project,
+ OString const & projectRoot, OString const & actualPotDir)
{
PoOfstream aPoOutPut;
osl::Directory dir(url);
if (dir.open() != osl::FileBase::E_None) {
- std::cerr
- << "Error: Cannot open directory: "
- << rtl::OUStringToOString(url, osl_getThreadTextEncoding()).getStr()
- << '\n';
+ cerr
+ << "Error: Cannot open directory: " << url << '\n';
throw false; //TODO
}
for (;;) {
@@ -462,55 +445,56 @@ void handleDirectory(
break;
}
if (e != osl::FileBase::E_None) {
- std::cerr << "Error: Cannot read directory\n";
+ cerr << "Error: Cannot read directory\n";
throw false; //TODO
}
osl::FileStatus stat(
osl_FileStatus_Mask_Type | osl_FileStatus_Mask_FileName
| osl_FileStatus_Mask_FileURL);
if (item.getFileStatus(stat) != osl::FileBase::E_None) {
- std::cerr << "Error: Cannot get file status\n";
+ cerr << "Error: Cannot get file status\n";
throw false; //TODO
}
+ const OString sFileName =
+ OUStringToOString(stat.getFileName(),RTL_TEXTENCODING_UTF8);
switch (level) {
case -1: // the clone or src directory
if (stat.getFileType() == osl::FileStatus::Directory) {
handleDirectory(
- stat.getFileURL(), 0, rtl::OUString(),
- rtl::OUString(), actualDir);
+ stat.getFileURL(), 0, OString(),
+ OString(), actualPotDir);
}
break;
case 0: // a root directory
if (stat.getFileType() == osl::FileStatus::Directory) {
- if (includeProject(stat.getFileName())) {
+ if (includeProject(sFileName)) {
handleDirectory(
- stat.getFileURL(), 1, stat.getFileName(),
- rtl::OUString(), actualDir.concat("/").
- concat(stat.getFileName()));
- } else if ( stat.getFileName() == "clone" ||
- stat.getFileName() == "src" )
+ stat.getFileURL(), 1, sFileName,
+ OString(), actualPotDir.concat("/").
+ concat(sFileName));
+ } else if ( sFileName == "clone" ||
+ sFileName == "src" )
{
handleDirectory(
- stat.getFileURL(), -1, rtl::OUString(),
- rtl::OUString(), actualDir);
+ stat.getFileURL(), -1, OString(),
+ OString(), actualPotDir);
}
}
break;
default:
if (stat.getFileType() == osl::FileStatus::Directory) {
- if (level == 2 || !excludeDirectory(stat.getFileName())) {
- rtl::OUString pr(projectRoot);
+ if (level == 2 || !excludeDirectory(sFileName)) {
+ OString pr(projectRoot);
if (!pr.isEmpty()) {
- pr += rtl::OUString('/');
+ pr += OString('/');
}
- pr += rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(".."));
+ pr += OString("..");
handleDirectory(stat.getFileURL(), 2, project, pr,
- actualDir.concat("/").
- concat(stat.getFileName()));
+ actualPotDir.concat("/").concat(sFileName));
}
} else {
handleFile(project, projectRoot,
- stat.getFileURL(), actualDir, aPoOutPut);
+ stat.getFileURL(), actualPotDir, aPoOutPut);
}
break;
}
@@ -518,13 +502,14 @@ void handleDirectory(
if (aPoOutPut.isOpen())
aPoOutPut.close();
if (dir.close() != osl::FileBase::E_None) {
- std::cerr << "Error: Cannot close directory\n";
+ cerr << "Error: Cannot close directory\n";
throw false; //TODO
}
}
-void handleProjects(char const * sourceRoot, char const * destRoot) {
- rtl::OUString root16;
+void handleProjects(char * sourceRoot, char const * destRoot)
+{
+ OUString root16;
if (!rtl_convertStringToUString(
&root16.pData, sourceRoot, rtl_str_getLength(sourceRoot),
osl_getThreadTextEncoding(),
@@ -532,40 +517,29 @@ void handleProjects(char const * sourceRoot, char const * destRoot) {
| RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_ERROR
| RTL_TEXTTOUNICODE_FLAGS_INVALID_ERROR)))
{
- std::cerr << "Error: Cannot convert pathname to UTF-16\n";
+ cerr << "Error: Cannot convert pathname to UTF-16\n";
throw false; //TODO
}
- rtl::OUString rootUrl;
+ OUString rootUrl;
if (osl::FileBase::getFileURLFromSystemPath(root16, rootUrl)
!= osl::FileBase::E_None)
{
- std::cerr << "Error: Cannot convert pathname to URL\n";
- throw false; //TODO
- }
- rtl::OUString outPutRoot;
- if (!rtl_convertStringToUString(
- &outPutRoot.pData, destRoot, rtl_str_getLength(destRoot),
- osl_getThreadTextEncoding(),
- (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_ERROR
- | RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_ERROR
- | RTL_TEXTTOUNICODE_FLAGS_INVALID_ERROR)))
- {
- std::cerr << "Error: Cannot convert pathname to UTF-16\n";
+ cerr << "Error: Cannot convert pathname to URL\n";
throw false; //TODO
}
- handleDirectory(rootUrl, 0, rtl::OUString(), rtl::OUString(), outPutRoot);
+ handleDirectory(rootUrl, 0, OString(), OString(), OString(destRoot));
}
}
SAL_IMPLEMENT_MAIN_WITH_ARGS(argc, argv) {
if (argc != 3) {
- std::cerr
+ cerr
<< ("localize (c)2001 by Sun Microsystems\n\n"
"As part of the L10N framework, localize extracts en-US\n"
"strings for translation out of the toplevel modules defined\n"
"in projects array in l10ntools/source/localize.cxx.\n\n"
"Syntax: localize <source-root> <outfile>\n");
- std::exit(EXIT_FAILURE);
+ exit(EXIT_FAILURE);
}
try {
handleProjects(argv[1],argv[2]);