From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- layout/base/LayoutConstants.h | 109 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 109 insertions(+) create mode 100644 layout/base/LayoutConstants.h (limited to 'layout/base/LayoutConstants.h') diff --git a/layout/base/LayoutConstants.h b/layout/base/LayoutConstants.h new file mode 100644 index 0000000000..ac9a8b029d --- /dev/null +++ b/layout/base/LayoutConstants.h @@ -0,0 +1,109 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* 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/. */ + +/* constants used throughout the Layout module */ + +#ifndef LayoutConstants_h___ +#define LayoutConstants_h___ + +#include "mozilla/EnumSet.h" +#include "nsSize.h" // for NS_MAXSIZE +#include "Units.h" + +/** + * Constant used to indicate an unconstrained size. + * + * NOTE: The constants defined in this file are semantically used as symbolic + * values, so user should not depend on the underlying numeric values. If + * new specific use cases arise, define a new constant here. + */ +#define NS_UNCONSTRAINEDSIZE NS_MAXSIZE + +// NS_AUTOOFFSET is assumed to have the same value as NS_UNCONSTRAINEDSIZE. +#define NS_AUTOOFFSET NS_UNCONSTRAINEDSIZE + +// +1 is to avoid clamped huge margin values being processed as auto margins +#define NS_AUTOMARGIN (NS_UNCONSTRAINEDSIZE + 1) + +#define NS_INTRINSIC_ISIZE_UNKNOWN nscoord_MIN + +namespace mozilla { + +/** + * Bit-flags to pass to various functions that compute sizes like + * nsIFrame::ComputeSize(). + */ +enum class ComputeSizeFlag : uint8_t { + /** + * Set if the frame is in a context where non-replaced blocks should + * shrink-wrap (e.g., it's floating, absolutely positioned, or + * inline-block). + */ + ShrinkWrap, + + /** + * Set if this is a grid measuring reflow, to prevent stretching. + */ + IsGridMeasuringReflow, + + /** + * Indicates that we should clamp the margin-box min-size to the given CB + * size. This is used for implementing the grid area clamping here: + * https://drafts.csswg.org/css-grid/#min-size-auto + */ + IClampMarginBoxMinSize, // clamp in our inline axis + BClampMarginBoxMinSize, // clamp in our block axis + + /** + * The frame is stretching (per CSS Box Alignment) and doesn't have an + * Automatic Minimum Size in the indicated axis. + * (may be used for both flex/grid items, but currently only used for Grid) + * https://drafts.csswg.org/css-grid/#min-size-auto + * https://drafts.csswg.org/css-align-3/#valdef-justify-self-stretch + */ + IApplyAutoMinSize, // only has an effect when eShrinkWrap is false +}; +using ComputeSizeFlags = mozilla::EnumSet; + +/** + * The fallback size of width is 300px and the aspect-ratio is 2:1, based on + * CSS2 section 10.3.2 and CSS Sizing Level 3 section 5.1: + * https://drafts.csswg.org/css2/visudet.html#inline-replaced-width + * https://drafts.csswg.org/css-sizing-3/#intrinsic-sizes + */ +inline constexpr CSSIntCoord kFallbackIntrinsicWidthInPixels(300); +inline constexpr CSSIntCoord kFallbackIntrinsicHeightInPixels(150); +inline constexpr CSSIntSize kFallbackIntrinsicSizeInPixels( + kFallbackIntrinsicWidthInPixels, kFallbackIntrinsicHeightInPixels); + +inline constexpr nscoord kFallbackIntrinsicWidth = + kFallbackIntrinsicWidthInPixels * AppUnitsPerCSSPixel(); +inline constexpr nscoord kFallbackIntrinsicHeight = + kFallbackIntrinsicHeightInPixels * AppUnitsPerCSSPixel(); +inline constexpr nsSize kFallbackIntrinsicSize(kFallbackIntrinsicWidth, + kFallbackIntrinsicHeight); + +/** + * This is used in some nsLayoutUtils functions. + * Declared here so that fewer files need to include nsLayoutUtils.h. + */ +enum class IntrinsicISizeType { MinISize, PrefISize }; + +enum class ContentRelevancyReason { + // If the content of this Frame is on screen or nearly on screen. + Visible, + + // If this Frame's element has focus in its subtree. + FocusInSubtree, + + // If this Frame's content is part of a selection. + Selected, +}; +using ContentRelevancy = EnumSet; + +} // namespace mozilla + +#endif // LayoutConstants_h___ -- cgit v1.2.3