haikuwebkit/Source/WebCore/layout/integration/LayoutIntegrationRun.h

122 lines
4.6 KiB
C++

/*
* Copyright (C) 2019 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#if ENABLE(LAYOUT_FORMATTING_CONTEXT)
#include "InlineRect.h"
#include "LayoutBox.h"
#include "RenderStyle.h"
#include "TextFlags.h"
namespace WebCore {
class CachedImage;
namespace LayoutIntegration {
struct Run {
WTF_MAKE_STRUCT_FAST_ALLOCATED;
struct TextContent {
WTF_MAKE_STRUCT_FAST_ALLOCATED;
public:
TextContent(size_t position, size_t length, const String&, String adjustedContentToRender, bool hasHyphen);
size_t start() const { return m_start; }
size_t end() const { return start() + length(); }
size_t length() const { return m_length; }
StringView originalContent() const { return StringView(m_originalContent).substring(m_start, m_length); }
StringView renderedContent() const { return m_adjustedContentToRender.isNull() ? originalContent() : m_adjustedContentToRender; }
bool hasHyphen() const { return m_hasHyphen; }
private:
size_t m_start { 0 };
size_t m_length { 0 };
bool m_hasHyphen { false };
String m_originalContent;
String m_adjustedContentToRender;
};
struct Expansion;
Run(size_t lineIndex, const Layout::Box&, const FloatRect&, const FloatRect& inkOverflow, Expansion, std::optional<TextContent> = std::nullopt);
const FloatRect& rect() const { return m_rect; }
const FloatRect& inkOverflow() const { return m_inkOverflow; }
std::optional<TextContent>& textContent() { return m_textContent; }
const std::optional<TextContent>& textContent() const { return m_textContent; }
// FIXME: This information should be preserved at Run construction time.
bool isLineBreak() const { return layoutBox().isLineBreakBox() || (textContent() && textContent()->originalContent() == "\n" && style().preserveNewline()); }
struct Expansion {
ExpansionBehavior behavior { DefaultExpansion };
InlineLayoutUnit horizontalExpansion { 0 };
};
Expansion expansion() const { return m_expansion; }
CachedImage* image() const { return m_cachedImage; }
bool hasUnderlyingLayout() const { return !!m_layoutBox; }
const Layout::Box& layoutBox() const { return *m_layoutBox; }
const RenderStyle& style() const { return m_layoutBox->style(); }
size_t lineIndex() const { return m_lineIndex; }
private:
// FIXME: Find out the Display::Run <-> paint style setup.
const size_t m_lineIndex;
WeakPtr<const Layout::Box> m_layoutBox;
CachedImage* m_cachedImage { nullptr };
FloatRect m_rect;
FloatRect m_inkOverflow;
Expansion m_expansion;
std::optional<TextContent> m_textContent;
};
inline Run::Run(size_t lineIndex, const Layout::Box& layoutBox, const FloatRect& rect, const FloatRect& inkOverflow, Expansion expansion, std::optional<TextContent> textContent)
: m_lineIndex(lineIndex)
, m_layoutBox(makeWeakPtr(layoutBox))
, m_rect(rect)
, m_inkOverflow(inkOverflow)
, m_expansion(expansion)
, m_textContent(textContent)
{
}
inline Run::TextContent::TextContent(size_t start, size_t length, const String& originalContent, String adjustedContentToRender, bool hasHyphen)
: m_start(start)
, m_length(length)
, m_hasHyphen(hasHyphen)
, m_originalContent(originalContent)
, m_adjustedContentToRender(adjustedContentToRender)
{
}
}
}
#endif