OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2004, 2006, 2007 Apple Inc. All rights reserved. | 2 * Copyright (C) 2004, 2006, 2007 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 174 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
185 | 185 |
186 IntRect r; | 186 IntRect r; |
187 if (o.isText()) { | 187 if (o.isText()) { |
188 // FIXME: Would be better to dump the bounding box x and y rather than t
he first run's x and y, but that would involve updating | 188 // FIXME: Would be better to dump the bounding box x and y rather than t
he first run's x and y, but that would involve updating |
189 // many test results. | 189 // many test results. |
190 const RenderText& text = *toRenderText(&o); | 190 const RenderText& text = *toRenderText(&o); |
191 IntRect linesBox = text.linesBoundingBox(); | 191 IntRect linesBox = text.linesBoundingBox(); |
192 r = IntRect(text.firstRunX(), text.firstRunY(), linesBox.width(), linesB
ox.height()); | 192 r = IntRect(text.firstRunX(), text.firstRunY(), linesBox.width(), linesB
ox.height()); |
193 if (adjustForTableCells && !text.firstTextBox()) | 193 if (adjustForTableCells && !text.firstTextBox()) |
194 adjustForTableCells = false; | 194 adjustForTableCells = false; |
195 } else if (o.isBox()) { | 195 } else if (o.isRenderInline()) { |
196 if (o.isRenderInline()) { | 196 // FIXME: Would be better not to just dump 0, 0 as the x and y here. |
197 // FIXME: Would be better not to just dump 0, 0 as the x and y here. | 197 const RenderInline& inlineFlow = *toRenderInline(&o); |
198 const RenderInline& inlineFlow = *toRenderInline(&o); | 198 r = IntRect(0, 0, inlineFlow.linesBoundingBox().width(), inlineFlow.line
sBoundingBox().height()); |
199 r = IntRect(0, 0, inlineFlow.linesBoundingBox().width(), inlineFlow.
linesBoundingBox().height()); | 199 adjustForTableCells = false; |
200 adjustForTableCells = false; | 200 } else if (o.isTableCell()) { |
201 } else if (o.isTableCell()) { | 201 // FIXME: Deliberately dump the "inner" box of table cells, since that i
s what current results reflect. We'd like |
202 // FIXME: Deliberately dump the "inner" box of table cells, since th
at is what current results reflect. We'd like | 202 // to clean up the results to dump both the outer box and the intrinsic
padding so that both bits of information are |
203 // to clean up the results to dump both the outer box and the intrin
sic padding so that both bits of information are | 203 // captured by the results. |
204 // captured by the results. | 204 const RenderTableCell& cell = static_cast<const RenderTableCell&>(o); |
205 const RenderTableCell& cell = static_cast<const RenderTableCell&>(o)
; | 205 r = IntRect(cell.x(), cell.y() + cell.intrinsicPaddingTop(), cell.width(
), cell.height() - cell.intrinsicPaddingTop() - cell.intrinsicPaddingBottom()); |
206 r = IntRect(cell.x(), cell.y() + cell.intrinsicPaddingTop(), cell.wi
dth(), cell.height() - cell.intrinsicPaddingTop() - cell.intrinsicPaddingBottom(
)); | 206 } else if (o.isBox()) |
207 } else | 207 r = toRenderBox(&o)->frameRect(); |
208 r = toRenderBox(&o)->frameRect(); | |
209 } | |
210 | 208 |
211 // FIXME: Temporary in order to ensure compatibility with existing layout te
st results. | 209 // FIXME: Temporary in order to ensure compatibility with existing layout te
st results. |
212 if (adjustForTableCells) | 210 if (adjustForTableCells) |
213 r.move(0, -static_cast<RenderTableCell*>(o.containingBlock())->intrinsic
PaddingTop()); | 211 r.move(0, -static_cast<RenderTableCell*>(o.containingBlock())->intrinsic
PaddingTop()); |
214 | 212 |
215 ts << " " << r; | 213 ts << " " << r; |
216 | 214 |
217 if (!(o.isText() && !o.isBR())) { | 215 if (!(o.isText() && !o.isBR())) { |
218 if (o.parent() && (o.parent()->style()->color() != o.style()->color())) | 216 if (o.parent() && (o.parent()->style()->color() != o.style()->color())) |
219 ts << " [color=" << o.style()->color().name() << "]"; | 217 ts << " [color=" << o.style()->color().name() << "]"; |
(...skipping 10 matching lines...) Expand all Loading... |
230 | 228 |
231 if (o.parent() && (o.parent()->style()->textStrokeColor() != o.style()->
textStrokeColor()) && | 229 if (o.parent() && (o.parent()->style()->textStrokeColor() != o.style()->
textStrokeColor()) && |
232 o.style()->textStrokeColor().isValid() && o.style()->textStrokeColor
() != o.style()->color() && | 230 o.style()->textStrokeColor().isValid() && o.style()->textStrokeColor
() != o.style()->color() && |
233 o.style()->textStrokeColor().rgb()) | 231 o.style()->textStrokeColor().rgb()) |
234 ts << " [textStrokeColor=" << o.style()->textStrokeColor().name() <<
"]"; | 232 ts << " [textStrokeColor=" << o.style()->textStrokeColor().name() <<
"]"; |
235 | 233 |
236 if (o.parent() && (o.parent()->style()->textStrokeWidth() != o.style()->
textStrokeWidth()) && | 234 if (o.parent() && (o.parent()->style()->textStrokeWidth() != o.style()->
textStrokeWidth()) && |
237 o.style()->textStrokeWidth() > 0) | 235 o.style()->textStrokeWidth() > 0) |
238 ts << " [textStrokeWidth=" << o.style()->textStrokeWidth() << "]"; | 236 ts << " [textStrokeWidth=" << o.style()->textStrokeWidth() << "]"; |
239 | 237 |
240 if (!o.isBox()) | 238 if (!o.isBoxModelObject()) |
241 return ts; | 239 return ts; |
242 | 240 |
243 const RenderBox& box = *toRenderBox(&o); | 241 const RenderBoxModelObject& box = *toRenderBoxModelObject(&o); |
244 if (box.borderTop() || box.borderRight() || box.borderBottom() || box.bo
rderLeft()) { | 242 if (box.borderTop() || box.borderRight() || box.borderBottom() || box.bo
rderLeft()) { |
245 ts << " [border:"; | 243 ts << " [border:"; |
246 | 244 |
247 BorderValue prevBorder; | 245 BorderValue prevBorder; |
248 if (o.style()->borderTop() != prevBorder) { | 246 if (o.style()->borderTop() != prevBorder) { |
249 prevBorder = o.style()->borderTop(); | 247 prevBorder = o.style()->borderTop(); |
250 if (!box.borderTop()) | 248 if (!box.borderTop()) |
251 ts << " none"; | 249 ts << " none"; |
252 else { | 250 else { |
253 ts << " (" << box.borderTop() << "px "; | 251 ts << " (" << box.borderTop() << "px "; |
(...skipping 288 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
542 o->view()->frameView()->layout(); | 540 o->view()->frameView()->layout(); |
543 if (o->hasLayer()) { | 541 if (o->hasLayer()) { |
544 RenderLayer* l = toRenderBox(o)->layer(); | 542 RenderLayer* l = toRenderBox(o)->layer(); |
545 writeLayers(ts, l, l, IntRect(l->xPos(), l->yPos(), l->width(), l->heigh
t())); | 543 writeLayers(ts, l, l, IntRect(l->xPos(), l->yPos(), l->width(), l->heigh
t())); |
546 writeSelection(ts, o); | 544 writeSelection(ts, o); |
547 } | 545 } |
548 return ts.release(); | 546 return ts.release(); |
549 } | 547 } |
550 | 548 |
551 } // namespace WebCore | 549 } // namespace WebCore |
OLD | NEW |