2017-10-27 20:33:53 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
2012-05-21 15:12:37 +04:00
|
|
|
/* 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/. */
|
2000-07-14 03:00:59 +04:00
|
|
|
#ifndef nsIReflowCallback_h___
|
|
|
|
#define nsIReflowCallback_h___
|
|
|
|
|
|
|
|
/**
|
2007-03-05 04:39:53 +03:00
|
|
|
* Reflow callback interface.
|
|
|
|
* These are not refcounted. Objects must be removed from the presshell
|
|
|
|
* callback list before they die.
|
2007-12-01 10:22:44 +03:00
|
|
|
* Protocol: objects will either get a ReflowFinished() call when a reflow
|
|
|
|
* has finished or a ReflowCallbackCanceled() call if the shell is destroyed,
|
|
|
|
* whichever happens first. If the object is explicitly removed from the shell
|
2019-05-01 05:27:53 +03:00
|
|
|
* (using PresShell::CancelReflowCallback()) before that occurs then neither
|
2007-12-01 10:22:44 +03:00
|
|
|
* of the callback methods are called.
|
2000-07-14 03:00:59 +04:00
|
|
|
*/
|
2007-03-05 04:39:53 +03:00
|
|
|
class nsIReflowCallback {
|
2000-07-14 03:00:59 +04:00
|
|
|
public:
|
2007-03-05 04:39:53 +03:00
|
|
|
/**
|
2011-10-17 18:59:28 +04:00
|
|
|
* The presshell calls this when reflow has finished. Return true if
|
2017-01-05 10:31:56 +03:00
|
|
|
* you need a FlushType::Layout to happen after this.
|
2007-03-05 04:39:53 +03:00
|
|
|
*/
|
2011-09-29 10:19:26 +04:00
|
|
|
virtual bool ReflowFinished() = 0;
|
2007-12-01 10:22:44 +03:00
|
|
|
/**
|
|
|
|
* The presshell calls this on outstanding callback requests in its
|
|
|
|
* Destroy() method. The shell removes the request after calling
|
|
|
|
* ReflowCallbackCanceled().
|
|
|
|
*/
|
|
|
|
virtual void ReflowCallbackCanceled() = 0;
|
2000-07-14 03:00:59 +04:00
|
|
|
};
|
|
|
|
|
2007-12-01 10:22:44 +03:00
|
|
|
#endif /* nsIReflowCallback_h___ */
|