summaryrefslogtreecommitdiffstats
path: root/l10ntools/inc/cfgmerge.hxx
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
commit267c6f2ac71f92999e969232431ba04678e7437e (patch)
tree358c9467650e1d0a1d7227a21dac2e3d08b622b2 /l10ntools/inc/cfgmerge.hxx
parentInitial commit. (diff)
downloadlibreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz
libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'l10ntools/inc/cfgmerge.hxx')
-rw-r--r--l10ntools/inc/cfgmerge.hxx182
1 files changed, 182 insertions, 0 deletions
diff --git a/l10ntools/inc/cfgmerge.hxx b/l10ntools/inc/cfgmerge.hxx
new file mode 100644
index 0000000000..a2f59e1e6e
--- /dev/null
+++ b/l10ntools/inc/cfgmerge.hxx
@@ -0,0 +1,182 @@
+/* -*- 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 .
+ */
+
+#ifndef INCLUDED_L10NTOOLS_INC_CFGMERGE_HXX
+#define INCLUDED_L10NTOOLS_INC_CFGMERGE_HXX
+
+#include <sal/config.h>
+
+#include <fstream>
+#include <unordered_map>
+#include <memory>
+#include <utility>
+#include <vector>
+#include "po.hxx"
+#include "export.hxx"
+
+typedef std::unordered_map<OString, OString> OStringHashMap;
+
+
+
+
+class CfgStackData
+{
+friend class CfgParser;
+friend class CfgExport;
+friend class CfgMerge;
+private:
+ OString sTagType;
+ OString sIdentifier;
+
+ OString sResTyp;
+
+ OString sTextTag;
+ OString sEndTextTag;
+
+ OStringHashMap sText;
+public:
+ CfgStackData(OString _sTag, OString _sId)
+ : sTagType(std::move( _sTag )), sIdentifier(std::move( _sId ))
+ {}
+
+ const OString &GetTagType() const { return sTagType; }
+ const OString &GetIdentifier() const { return sIdentifier; }
+
+};
+
+
+
+
+class CfgStack
+{
+private:
+ std::vector< CfgStackData* > maList;
+
+public:
+ CfgStack() {}
+ ~CfgStack();
+
+ CfgStackData *Push(const OString &rTag, const OString &rId);
+ void Pop()
+ {
+ if (!maList.empty())
+ {
+ delete maList.back();
+ maList.pop_back();
+ }
+ }
+
+ CfgStackData *GetStackData();
+
+ OString GetAccessPath( size_t nPos );
+
+ size_t size() const { return maList.size(); }
+};
+
+/// Parser for *.xcu files
+class CfgParser
+{
+protected:
+ OString sCurrentResTyp;
+ OString sCurrentIsoLang;
+ OString sCurrentText;
+
+ OString sLastWhitespace;
+
+ CfgStack aStack;
+ CfgStackData *pStackData;
+
+ bool bLocalize;
+
+ virtual void WorkOnText(
+ OString &rText,
+ const OString &rLangIndex )=0;
+
+ virtual void WorkOnResourceEnd()=0;
+
+ virtual void Output(const OString & rOutput)=0;
+
+private:
+ void ExecuteAnalyzedToken( int nToken, char *pToken );
+ void AddText(
+ OString &rText,
+ const OString &rIsoLang,
+ const OString &rResTyp );
+
+ static bool IsTokenClosed(std::string_view rToken);
+
+public:
+ CfgParser();
+ virtual ~CfgParser();
+
+ void Execute( int nToken, char * pToken );
+};
+
+/// Export strings from *.xcu files
+class CfgExport : public CfgParser
+{
+private:
+ OString sPath;
+ PoOfstream pOutputStream;
+
+protected:
+ virtual void WorkOnText(
+ OString &rText,
+ const OString &rIsoLang
+ ) override;
+
+ void WorkOnResourceEnd() override;
+ void Output(const OString& rOutput) override;
+public:
+ CfgExport(
+ const OString &rOutputFile,
+ OString sFilePath
+ );
+ virtual ~CfgExport() override;
+};
+
+/// Merge strings to *.xcu files
+class CfgMerge : public CfgParser
+{
+private:
+ std::unique_ptr<MergeDataFile> pMergeDataFile;
+ std::vector<OString> aLanguages;
+ std::unique_ptr<ResData> pResData;
+
+ OString sFilename;
+ bool bEnglish;
+
+ std::ofstream pOutputStream;
+
+protected:
+ virtual void WorkOnText(OString &rText, const OString &rLangIndex) override;
+
+ void WorkOnResourceEnd() override;
+
+ void Output(const OString& rOutput) override;
+public:
+ CfgMerge(
+ const OString &rMergeSource, const OString &rOutputFile,
+ OString sFilename, const OString &rLanguage );
+ virtual ~CfgMerge() override;
+};
+
+#endif
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */