/** * This file is part of the DOM implementation for KDE. * * Copyright (C) 2000 Lars Knoll (knoll@kde.org) * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. * */ #include "render_br.h" #include "dom_position.h" #include "render_block.h" #include "render_line.h" using namespace khtml; using DOM::Position; RenderBR::RenderBR(DOM::NodeImpl* node) : RenderText(node, new DOM::DOMStringImpl(QChar('\n'))), m_lineHeight(-1) { } RenderBR::~RenderBR() { } InlineBox* RenderBR::createInlineBox(bool makePlaceholder, bool isRootLineBox, bool isOnlyRun) { // We only treat a box as text for a
if we are on a line by ourself or in strict mode // (Note the use of strict mode. In "almost strict" mode, we don't treat the box for
as text.) InlineTextBox* box = static_cast(RenderText::createInlineBox(makePlaceholder, isRootLineBox, isOnlyRun)); box->setIsText(isOnlyRun || document()->inStrictMode()); return box; } short RenderBR::baselinePosition( bool firstLine, bool isRootLineBox) const { if (firstTextBox() && !firstTextBox()->isText()) return 0; return RenderText::baselinePosition(firstLine, isRootLineBox); } short RenderBR::lineHeight(bool firstLine, bool isRootLineBox) const { if (firstTextBox() && !firstTextBox()->isText()) return 0; if (firstLine) { RenderStyle* s = style(firstLine); Length lh = s->lineHeight(); if (lh.value < 0) { if (s == style()) { if (m_lineHeight == -1) m_lineHeight = RenderObject::lineHeight(false); return m_lineHeight; } return s->fontMetrics().lineSpacing(); } if (lh.isPercent()) return lh.minWidth(s->font().pixelSize()); return lh.value; } if (m_lineHeight == -1) m_lineHeight = RenderObject::lineHeight(false); return m_lineHeight; } void RenderBR::setStyle(RenderStyle* _style) { RenderText::setStyle(_style); m_lineHeight = -1; } long RenderBR::caretMinOffset() const { return 0; } long RenderBR::caretMaxOffset() const { return 1; } unsigned long RenderBR::caretMaxRenderedOffset() const { return 1; } VisiblePosition RenderBR::positionForCoordinates(int _x, int _y) { return VisiblePosition(element(), 0, DOWNSTREAM); } QRect RenderBR::caretRect(int offset, EAffinity affinity, int *extraWidthToEndOfLine) { // EDIT FIXME: This does not work yet. Some other changes are need before // an accurate position can be determined. int absx, absy; absolutePosition(absx,absy); if (extraWidthToEndOfLine) *extraWidthToEndOfLine = containingBlockWidth() - xPos(); // FIXME: an older version of this code wasn't setting width at // all, using the default of 1... return QRect(xPos() + absx, yPos() + absy, 1, lineHeight(false)); } InlineBox *RenderBR::inlineBox(long offset, EAffinity affinity) { return firstTextBox(); }