/* -*- 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/. */ #ifndef INCLUDED_TEST_SCREENSHOT_TEST_HXX #define INCLUDED_TEST_SCREENSHOT_TEST_HXX #include #include #include #include #include #include #include class VclAbstractDialog; typedef std::map< OString, sal_uInt32 > mapType; class OOO_DLLPUBLIC_TEST ScreenshotTest : public test::BootstrapFixture, public unotest::MacrosTest { private: /// the target directory for screenshots OUString m_aScreenshotDirectory; /// The current UI language OUString maCurrentLanguage; /// the set of known dialogs and their ID for usage in createDialogByID mapType maKnownDialogs; private: /// helpers void implSaveScreenshot(const Bitmap& rScreenshot, const OString& rScreenshotId); void saveScreenshot(VclAbstractDialog const & rDialog); void saveScreenshot(Dialog& rDialog); /// helper method to populate maKnownDialogs, called in setUp(). Needs to be /// written and has to add entries to maKnownDialogs virtual void registerKnownDialogsByID(mapType& rKnownDialogs) = 0; /// dialog creation for known dialogs by ID. Has to be implemented for /// each registered known dialog virtual VclPtr createDialogByID(sal_uInt32 nID) = 0; public: ScreenshotTest(); virtual ~ScreenshotTest() override; virtual void setUp() override; /// Dialog creation for known dialogs by Name (path and UIXMLDescription, *.ui file). /// This uses maKnownDialogs to check if known, and if so, calls createDialogByID /// with the ID from the map VclPtr createDialogByName(const OString& rName); /// version for AbstractDialogs, the ones created in AbstractDialogFactories void dumpDialogToPath(VclAbstractDialog& rDialog); /// version for pure vcl-based dialogs void dumpDialogToPath(Dialog& rDialog); /// fallback version for dialogs for which only the UXMLDescription is known. /// This should be used with care - no active layouting will be done, only the /// VclBuilder will be activated for layouting. Result can thus vary drastically /// compared to the active dialog (can be compared with dialog previewer) void dumpDialogToPath(const OString& rUIXMLDescription); /// helper to process all known dialogs void processAllKnownDialogs(); /// helper to process an input file containing the UXMLDescriptions /// of the dialogs to dump. It will internally try to detect and open /// as known dialog first. If not successful, it will then use the /// fallback version to dump the dialog. /// The syntax of the input file is as follows: /// - empty lines are allowed /// - lines starting with '#' are treated as comment /// - all other lines should contain a *.ui filename in the same /// notation as in the dialog constructors(see code) void processDialogBatchFile(const OUString& rFile); /// const access to known dialogs const mapType& getKnownDialogs() const { return maKnownDialogs; } }; #endif // INCLUDED_TEST_SCREENSHOT_TEST_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ ='distro/collabora/cp-4.1'>distro/collabora/cp-4.1 LibreOffice 核心代码仓库文档基金会
summaryrefslogtreecommitdiff
AgeCommit message (Expand)Author
2024-03-06Use less boost_headers in low level librariesGabor Kelemen