mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
b6e35bb4b4
Most of this patch (with the exception of dom/bindings/Codegen.py) was generated by the following bash script: #!/bin/bash function convert() { echo "Converting $1 to $2..." find . ! -wholename "*nsprpub*" \ ! -wholename "*security/nss*" \ ! -wholename "*/.hg*" \ ! -wholename "*/.git*" \ ! -wholename "obj-*" \ -type f \ \( -iname "*.cpp" \ -o -iname "*.h" \ -o -iname "*.cc" \ -o -iname "*.idl" \ -o -iname "*.ipdl" \ -o -iname "*.ipdlh" \ -o -iname "*.mm" \) | \ xargs -n 1 sed -i -e "s/\b$1\b/$2/g" } convert MOZ_DELETE '= delete'
76 lines
2.2 KiB
C++
76 lines
2.2 KiB
C++
/* vim: set shiftwidth=2 tabstop=8 autoindent cindent expandtab: */
|
|
/* 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/. */
|
|
|
|
/* Per-block-formatting-context manager of font size inflation for pan and zoom UI. */
|
|
|
|
#ifndef nsFontInflationData_h_
|
|
#define nsFontInflationData_h_
|
|
|
|
#include "nsContainerFrame.h"
|
|
|
|
struct nsHTMLReflowState;
|
|
|
|
class nsFontInflationData
|
|
{
|
|
public:
|
|
|
|
static nsFontInflationData* FindFontInflationDataFor(const nsIFrame *aFrame);
|
|
|
|
// Returns whether the effective width changed (which requires the
|
|
// caller to mark its descendants dirty
|
|
static bool
|
|
UpdateFontInflationDataWidthFor(const nsHTMLReflowState& aReflowState);
|
|
|
|
static void MarkFontInflationDataTextDirty(nsIFrame *aFrame);
|
|
|
|
bool InflationEnabled() {
|
|
if (mTextDirty) {
|
|
ScanText();
|
|
}
|
|
return mInflationEnabled;
|
|
}
|
|
|
|
nscoord EffectiveWidth() const {
|
|
return mNCAWidth;
|
|
}
|
|
|
|
private:
|
|
|
|
explicit nsFontInflationData(nsIFrame* aBFCFrame);
|
|
|
|
nsFontInflationData(const nsFontInflationData&) = delete;
|
|
void operator=(const nsFontInflationData&) = delete;
|
|
|
|
void UpdateWidth(const nsHTMLReflowState &aReflowState);
|
|
enum SearchDirection { eFromStart, eFromEnd };
|
|
static nsIFrame* FindEdgeInflatableFrameIn(nsIFrame *aFrame,
|
|
SearchDirection aDirection);
|
|
|
|
void MarkTextDirty() { mTextDirty = true; }
|
|
void ScanText();
|
|
// Scan text in the subtree rooted at aFrame. Increment mTextAmount
|
|
// by multiplying the number of characters found by the font size
|
|
// (yielding the width that would be occupied by the characters if
|
|
// they were all em squares). But stop scanning if mTextAmount
|
|
// crosses mTextThreshold.
|
|
void ScanTextIn(nsIFrame *aFrame);
|
|
|
|
static const nsIFrame* FlowRootFor(const nsIFrame *aFrame)
|
|
{
|
|
while (!(aFrame->GetStateBits() & NS_FRAME_FONT_INFLATION_FLOW_ROOT)) {
|
|
aFrame = aFrame->GetParent();
|
|
}
|
|
return aFrame;
|
|
}
|
|
|
|
nsIFrame *mBFCFrame;
|
|
nscoord mNCAWidth;
|
|
nscoord mTextAmount, mTextThreshold;
|
|
bool mInflationEnabled; // for this BFC
|
|
bool mTextDirty;
|
|
};
|
|
|
|
#endif /* !defined(nsFontInflationData_h_) */
|