| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * Copyright (C) 2013 Adobe Systems Incorporated. All rights reserved. | 2  * Copyright (C) 2013 Adobe Systems Incorporated. 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  * | 7  * | 
| 8  * 1. Redistributions of source code must retain the above | 8  * 1. Redistributions of source code must retain the above | 
| 9  *    copyright notice, this list of conditions and the following | 9  *    copyright notice, this list of conditions and the following | 
| 10  *    disclaimer. | 10  *    disclaimer. | 
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 43     RasterShapeIntervals(unsigned size, int offset = 0) | 43     RasterShapeIntervals(unsigned size, int offset = 0) | 
| 44         : m_offset(offset) | 44         : m_offset(offset) | 
| 45     { | 45     { | 
| 46         m_intervalLists.resize(size); | 46         m_intervalLists.resize(size); | 
| 47     } | 47     } | 
| 48 | 48 | 
| 49     const IntRect& bounds() const { return m_bounds; } | 49     const IntRect& bounds() const { return m_bounds; } | 
| 50     bool isEmpty() const { return m_bounds.isEmpty(); } | 50     bool isEmpty() const { return m_bounds.isEmpty(); } | 
| 51     void appendInterval(int y, int x1, int x2); | 51     void appendInterval(int y, int x1, int x2); | 
| 52 | 52 | 
| 53     void getIncludedIntervals(int y1, int y2, IntShapeIntervals& result) const; |  | 
| 54     void getExcludedIntervals(int y1, int y2, IntShapeIntervals& result) const; | 53     void getExcludedIntervals(int y1, int y2, IntShapeIntervals& result) const; | 
| 55     bool firstIncludedIntervalY(int minY, const IntSize& minSize, LayoutUnit& re
     sult) const; | 54 | 
| 56     PassOwnPtr<RasterShapeIntervals> computeShapeMarginIntervals(int shapeMargin
     ) const; | 55     PassOwnPtr<RasterShapeIntervals> computeShapeMarginIntervals(int shapeMargin
     ) const; | 
| 57 | 56 | 
| 58     void buildBoundsPath(Path&) const; | 57     void buildBoundsPath(Path&) const; | 
| 59 | 58 | 
| 60 private: | 59 private: | 
| 61     int size() const { return m_intervalLists.size(); } | 60     int size() const { return m_intervalLists.size(); } | 
| 62     int offset() const { return m_offset; } | 61     int offset() const { return m_offset; } | 
| 63     int minY() const { return -m_offset; } | 62     int minY() const { return -m_offset; } | 
| 64     int maxY() const { return -m_offset + m_intervalLists.size(); } | 63     int maxY() const { return -m_offset + m_intervalLists.size(); } | 
| 65 | 64 | 
| (...skipping 26 matching lines...) Expand all  Loading... | 
| 92 class RasterShape FINAL : public Shape { | 91 class RasterShape FINAL : public Shape { | 
| 93     WTF_MAKE_NONCOPYABLE(RasterShape); | 92     WTF_MAKE_NONCOPYABLE(RasterShape); | 
| 94 public: | 93 public: | 
| 95     RasterShape(PassOwnPtr<RasterShapeIntervals> intervals, const IntSize& margi
     nRectSize) | 94     RasterShape(PassOwnPtr<RasterShapeIntervals> intervals, const IntSize& margi
     nRectSize) | 
| 96         : m_intervals(intervals) | 95         : m_intervals(intervals) | 
| 97         , m_marginRectSize(marginRectSize) | 96         , m_marginRectSize(marginRectSize) | 
| 98     { | 97     { | 
| 99     } | 98     } | 
| 100 | 99 | 
| 101     virtual LayoutRect shapeMarginLogicalBoundingBox() const OVERRIDE { return s
     tatic_cast<LayoutRect>(marginIntervals().bounds()); } | 100     virtual LayoutRect shapeMarginLogicalBoundingBox() const OVERRIDE { return s
     tatic_cast<LayoutRect>(marginIntervals().bounds()); } | 
| 102     virtual LayoutRect shapePaddingLogicalBoundingBox() const OVERRIDE { return 
     static_cast<LayoutRect>(paddingIntervals().bounds()); } |  | 
| 103     virtual bool isEmpty() const OVERRIDE { return m_intervals->isEmpty(); } | 101     virtual bool isEmpty() const OVERRIDE { return m_intervals->isEmpty(); } | 
| 104     virtual void getExcludedIntervals(LayoutUnit logicalTop, LayoutUnit logicalH
     eight, SegmentList&) const OVERRIDE; | 102     virtual void getExcludedIntervals(LayoutUnit logicalTop, LayoutUnit logicalH
     eight, SegmentList&) const OVERRIDE; | 
| 105     virtual void getIncludedIntervals(LayoutUnit logicalTop, LayoutUnit logicalH
     eight, SegmentList&) const OVERRIDE; |  | 
| 106     virtual bool firstIncludedIntervalLogicalTop(LayoutUnit minLogicalIntervalTo
     p, const FloatSize& minLogicalIntervalSize, LayoutUnit&) const OVERRIDE; |  | 
| 107 | 103 | 
| 108 private: | 104 private: | 
| 109     const RasterShapeIntervals& marginIntervals() const; | 105     const RasterShapeIntervals& marginIntervals() const; | 
| 110     const RasterShapeIntervals& paddingIntervals() const; |  | 
| 111 | 106 | 
| 112     OwnPtr<RasterShapeIntervals> m_intervals; | 107     OwnPtr<RasterShapeIntervals> m_intervals; | 
| 113     mutable OwnPtr<RasterShapeIntervals> m_marginIntervals; | 108     mutable OwnPtr<RasterShapeIntervals> m_marginIntervals; | 
| 114     IntSize m_marginRectSize; | 109     IntSize m_marginRectSize; | 
| 115 }; | 110 }; | 
| 116 | 111 | 
| 117 } // namespace WebCore | 112 } // namespace WebCore | 
| 118 | 113 | 
| 119 #endif // RasterShape_h | 114 #endif // RasterShape_h | 
| OLD | NEW | 
|---|