diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:51:28 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:51:28 +0000 |
commit | 940b4d1848e8c70ab7642901a68594e8016caffc (patch) | |
tree | eb72f344ee6c3d9b80a7ecc079ea79e9fba8676d /shell/inc/metainforeader.hxx | |
parent | Initial commit. (diff) | |
download | libreoffice-940b4d1848e8c70ab7642901a68594e8016caffc.tar.xz libreoffice-940b4d1848e8c70ab7642901a68594e8016caffc.zip |
Adding upstream version 1:7.0.4.upstream/1%7.0.4upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'shell/inc/metainforeader.hxx')
-rw-r--r-- | shell/inc/metainforeader.hxx | 144 |
1 files changed, 144 insertions, 0 deletions
diff --git a/shell/inc/metainforeader.hxx b/shell/inc/metainforeader.hxx new file mode 100644 index 000000000..7ff0a734f --- /dev/null +++ b/shell/inc/metainforeader.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_SHELL_INC_INTERNAL_METAINFOREADER_HXX +#define INCLUDED_SHELL_INC_INTERNAL_METAINFOREADER_HXX + +#include "basereader.hxx" +#include "types.hxx" +#include <stack> +#include "filepath.hxx" + +class ITag; +class CKeywordsTag; +class CSimpleTag; +class CDummyTag; + +class CMetaInfoReader : public CBaseReader +{ +public: + virtual ~CMetaInfoReader() override; + + CMetaInfoReader( const Filepath_t& DocumentName ); + + CMetaInfoReader( StreamInterface* stream ); + + /** check if the Tag is in the target meta.xml file. + + @param TagName + the name of the tag that will be retrieved. + */ + bool hasTag(const std::wstring& TagName) const; + + + /** Get a specific tag content, compound tags will be returned as comma separated list. + + @param TagName + the name of the tag that will be retrieved. + */ + std::wstring getTagData(const std::wstring& TagName); + + /** check if the a tag has the specific attribute. + + @param TagName + the name of the tag. + @param AttributeName + the name of the attribute. + */ + bool hasTagAttribute(const std::wstring& TagName, const std::wstring& AttributeName); + + /** Get a specific attribute content. + + @param TagName + the name of the tag. + @param AttributeName + the name of the attribute. + */ + std::wstring getTagAttribute(const std::wstring& TagName, const std::wstring& AttributeName); + + /** Get the default language of the whole document. + */ + LocaleSet_t getDefaultLocale( ); + +protected: // protected because its only an implementation relevant class + + /** start_element occurs when a tag is start. + + @param raw_name + raw name of the tag. + @param local_name + local name of the tag. + @param attributes + attribute structure. + */ + virtual void start_element( + const string_t& raw_name, + const string_t& local_name, + const xml_tag_attribute_container_t& attributes) override; + + /** end_element occurs when a tag is closed + + @param raw_name + raw name of the tag. + @param local_name + local name of the tag. + */ + virtual void end_element( + const string_t& raw_name, const string_t& local_name) override; + + /** characters occurs when receiving characters + + @param character + content of the information received. + */ + virtual void characters(const string_t& character) override; + +protected: + /** choose an appropriate tag reader to handle the tag. + + @param tag_name + the name of the tag. + @param XmlAttributes + attribute structure of the tag to save in. + */ + ITag* chooseTagReader( + const std::wstring& tag_name, const XmlTagAttributes_t& XmlAttributes ); + + /** save the received content into structure. + + @param tag_name + the name of the tag. + */ + void saveTagContent( const std::wstring& tag_name ); + +private: + XmlTags_t m_AllMetaInfo; + +private: + std::stack<ITag*> m_TagBuilderStack; + +private: + CKeywordsTag* m_pKeywords_Builder; + CDummyTag* m_pDummy_Builder; + CSimpleTag* m_pSimple_Builder; +}; + +#endif + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |