2 * Copyright (C) 2002 Lars Knoll (knoll@kde.org)
3 * (C) 2002 Dirk Mueller (mueller@kde.org)
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
15 * You should have received a copy of the GNU Library General Public License
16 * along with this library; see the file COPYING.LIB. If not, write to
17 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18 * Boston, MA 02110-1301, USA.
21 #ifndef TableLayoutAlgorithm_h
22 #define TableLayoutAlgorithm_h
24 #include "wtf/FastAllocBase.h"
25 #include "wtf/Noncopyable.h"
32 class TableLayoutAlgorithm
{
33 WTF_MAKE_NONCOPYABLE(TableLayoutAlgorithm
); WTF_MAKE_FAST_ALLOCATED(TableLayoutAlgorithm
);
35 explicit TableLayoutAlgorithm(LayoutTable
* table
)
40 virtual ~TableLayoutAlgorithm() { }
42 virtual void computeIntrinsicLogicalWidths(LayoutUnit
& minWidth
, LayoutUnit
& maxWidth
) = 0;
43 virtual void applyPreferredLogicalWidthQuirks(LayoutUnit
& minWidth
, LayoutUnit
& maxWidth
) const = 0;
44 virtual void layout() = 0;
45 virtual void willChangeTableLayout() = 0;
48 // FIXME: Once we enable SATURATED_LAYOUT_ARITHMETHIC, this should just be LayoutUnit::nearlyMax().
49 // Until then though, using nearlyMax causes overflow in some tests, so we just pick a large number.
50 const static int tableMaxWidth
= 1000000;
57 #endif // TableLayoutAlgorithm_h