gecko-dev/layout/base/nsIReflowCallback.h

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

35 строки
1.3 KiB
C
Исходник Обычный вид История

/* -*- 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___
/**
* Reflow callback interface.
* These are not refcounted. Objects must be removed from the presshell
* callback list before they die.
* 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
* (using PresShell::CancelReflowCallback()) before that occurs then neither
* of the callback methods are called.
2000-07-14 03:00:59 +04:00
*/
class nsIReflowCallback {
2000-07-14 03:00:59 +04:00
public:
/**
* The presshell calls this when reflow has finished. Return true if
* you need a FlushType::Layout to happen after this.
*/
virtual bool ReflowFinished() = 0;
/**
* 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
};
#endif /* nsIReflowCallback_h___ */