crashtesting: assert on reimport of docx export of ooo102874-2.doc
[LibreOffice.git] / slideshow / source / inc / vieweventhandler.hxx
bloba375e047f56024cac29dad3a87b0b59ff9507614
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_SLIDESHOW_SOURCE_INC_VIEWEVENTHANDLER_HXX
21 #define INCLUDED_SLIDESHOW_SOURCE_INC_VIEWEVENTHANDLER_HXX
23 #include <memory>
25 #include "unoview.hxx"
26 #include "disposable.hxx"
29 /* Definition of ViewEventHandler interface */
31 namespace slideshow::internal
34 /** Interface for handling view events.
36 Classes implementing this interface can be added to an
37 EventMultiplexer object, and are called from there to
38 handle view events.
40 class ViewEventHandler : public virtual SharedPtrAble
42 public:
43 /** Notify new view.
45 @param rView
46 The newly added view
48 virtual void viewAdded( const UnoViewSharedPtr& rView ) = 0;
50 /** Notify removed view.
52 @param rView
53 The removed view
55 virtual void viewRemoved( const UnoViewSharedPtr& rView ) = 0;
57 /** Notify changed view.
59 Reasons for a viewChanged notification can be
60 different view size, transformation, or other device
61 properties (color resolution or profile, etc.)
63 @param rView
64 The changed view
66 virtual void viewChanged( const UnoViewSharedPtr& rView ) = 0;
68 /** Notify that all views changed.
70 Reasons for a viewChanged notification can be
71 different view size, transformation, or other device
72 properties (color resolution or profile, etc.)
74 Note that this method avoids hidden inefficiencies
75 (O(n^2) behaviour when viewChanged() needs to perform
76 linear searches)
78 virtual void viewsChanged() = 0;
81 typedef ::std::weak_ptr< ViewEventHandler > ViewEventHandlerWeakPtr;
85 #endif // INCLUDED_SLIDESHOW_SOURCE_INC_VIEWEVENTHANDLER_HXX
87 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */