summaryrefslogtreecommitdiffstats
path: root/l10ntools/inc/export.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'l10ntools/inc/export.hxx')
-rw-r--r--l10ntools/inc/export.hxx144
1 files changed, 144 insertions, 0 deletions
diff --git a/l10ntools/inc/export.hxx b/l10ntools/inc/export.hxx
new file mode 100644
index 000000000..3f46c552f
--- /dev/null
+++ b/l10ntools/inc/export.hxx
@@ -0,0 +1,144 @@
+/* -*- 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_EXPORT_HXX
+#define INCLUDED_L10NTOOLS_INC_EXPORT_HXX
+
+#include <sal/config.h>
+
+#include <rtl/string.hxx>
+
+#include <set>
+#include <unordered_map>
+#include <memory>
+#include <vector>
+#include <string_view>
+
+#ifdef _WIN32
+#include <direct.h>
+#endif
+
+#define NO_TRANSLATE_ISO "x-no-translate"
+
+class MergeEntrys;
+
+typedef std::unordered_map<OString, OString>
+ OStringHashMap;
+
+typedef std::unordered_map<OString, bool>
+ OStringBoolHashMap;
+
+#define SOURCE_LANGUAGE "en-US"
+#define X_COMMENT "x-comment"
+
+
+
+
+/// Purpose: holds mandatory data to export a single res
+class ResData
+{
+public:
+ ResData( const OString &rGId );
+ ResData( const OString &rGId , const OString &rFilename );
+
+ OString sResTyp;
+ OString sId;
+ OString sGId;
+ OString sFilename;
+
+ OStringHashMap sText;
+};
+
+
+
+
+class ParserQueue;
+
+
+
+/// Purpose: holds information of data to merge
+class MergeEntrys
+{
+friend class MergeDataFile;
+private:
+ OStringHashMap sText;
+ OStringBoolHashMap bTextFirst;
+ OStringHashMap sQuickHelpText;
+ OStringBoolHashMap bQuickHelpTextFirst;
+ OStringHashMap sTitle;
+ OStringBoolHashMap bTitleFirst;
+
+public:
+ MergeEntrys(){};
+ void InsertEntry(const OString &rId, const OString &rText,
+ const OString &rQuickHelpText, const OString &rTitle)
+ {
+
+ sText[ rId ] = rText;
+ bTextFirst[ rId ] = true;
+ sQuickHelpText[ rId ] = rQuickHelpText;
+ bQuickHelpTextFirst[ rId ] = true;
+ sTitle[ rId ] = rTitle;
+ bTitleFirst[ rId ] = true;
+ }
+ bool GetText( OString &rReturn, const OString &nLangIndex, bool bDel = false );
+
+ /**
+ Generate QTZ string with ResData
+ For executable which works one language and without PO files.
+ */
+ static OString GetQTZText(const ResData& rResData, std::string_view rOrigText);
+
+};
+
+
+
+/// Purpose: holds information of data to merge, read from PO file
+class MergeDataFile
+{
+ private:
+ std::unordered_map<OString, std::unique_ptr<MergeEntrys>> aMap;
+ std::set<OString> aLanguageSet;
+
+ MergeEntrys *GetMergeData( ResData *pResData , bool bCaseSensitive = false );
+ void InsertEntry(std::string_view rTYP, std::string_view rGID,
+ std::string_view rLID, const OString &nLang,
+ const OString &rTEXT, const OString &rQHTEXT,
+ const OString &rTITLE, std::string_view sFilename,
+ bool bFirstLang, bool bCaseSensitive);
+ public:
+ explicit MergeDataFile(
+ const OString &rFileName, std::string_view rFile,
+ bool bCaseSensitive, bool bWithQtz = true );
+ ~MergeDataFile();
+
+
+ std::vector<OString> GetLanguages() const;
+
+ MergeEntrys *GetMergeEntrys( ResData *pResData );
+ MergeEntrys *GetMergeEntrysCaseSensitive( ResData *pResData );
+
+ static OString CreateKey(std::string_view rTYP, std::string_view rGID,
+ std::string_view rLID, std::string_view rFilename, bool bCaseSensitive);
+};
+
+
+#endif // INCLUDED_L10NTOOLS_INC_EXPORT_HXX
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */