OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2011 Google Inc. All rights reserved. | 2 * Copyright (C) 2011 Google 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 are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 20 matching lines...) Expand all Loading... |
31 #ifndef CalculationValue_h | 31 #ifndef CalculationValue_h |
32 #define CalculationValue_h | 32 #define CalculationValue_h |
33 | 33 |
34 #include "platform/Length.h" | 34 #include "platform/Length.h" |
35 #include "platform/LengthFunctions.h" | 35 #include "platform/LengthFunctions.h" |
36 #include "wtf/OwnPtr.h" | 36 #include "wtf/OwnPtr.h" |
37 #include "wtf/PassOwnPtr.h" | 37 #include "wtf/PassOwnPtr.h" |
38 #include "wtf/RefCounted.h" | 38 #include "wtf/RefCounted.h" |
39 #include "wtf/Vector.h" | 39 #include "wtf/Vector.h" |
40 | 40 |
41 namespace WebCore { | 41 namespace blink { |
42 | 42 |
43 class PLATFORM_EXPORT CalculationValue : public RefCounted<CalculationValue> { | 43 class PLATFORM_EXPORT CalculationValue : public RefCounted<CalculationValue> { |
44 public: | 44 public: |
45 static PassRefPtr<CalculationValue> create(PixelsAndPercent value, ValueRang
e range) | 45 static PassRefPtr<CalculationValue> create(PixelsAndPercent value, ValueRang
e range) |
46 { | 46 { |
47 return adoptRef(new CalculationValue(value, range)); | 47 return adoptRef(new CalculationValue(value, range)); |
48 } | 48 } |
49 | 49 |
50 float evaluate(float maxValue) const { return pixels() + percent() / 100 * m
axValue; } | 50 float evaluate(float maxValue) const { return pixels() + percent() / 100 * m
axValue; } |
51 bool operator==(const CalculationValue& o) const { return pixels() == o.pixe
ls() && percent() == o.percent(); } | 51 bool operator==(const CalculationValue& o) const { return pixels() == o.pixe
ls() && percent() == o.percent(); } |
52 bool isNonNegative() const { return m_isNonNegative; } | 52 bool isNonNegative() const { return m_isNonNegative; } |
53 float pixels() const { return m_value.pixels; } | 53 float pixels() const { return m_value.pixels; } |
54 float percent() const { return m_value.percent; } | 54 float percent() const { return m_value.percent; } |
55 PixelsAndPercent pixelsAndPercent() const { return m_value; } | 55 PixelsAndPercent pixelsAndPercent() const { return m_value; } |
56 | 56 |
57 private: | 57 private: |
58 CalculationValue(PixelsAndPercent value, ValueRange range) | 58 CalculationValue(PixelsAndPercent value, ValueRange range) |
59 : m_value(value) | 59 : m_value(value) |
60 , m_isNonNegative(range == ValueRangeNonNegative) | 60 , m_isNonNegative(range == ValueRangeNonNegative) |
61 { | 61 { |
62 } | 62 } |
63 | 63 |
64 PixelsAndPercent m_value; | 64 PixelsAndPercent m_value; |
65 bool m_isNonNegative; | 65 bool m_isNonNegative; |
66 }; | 66 }; |
67 | 67 |
68 } // namespace WebCore | 68 } // namespace blink |
69 | 69 |
70 #endif // CalculationValue_h | 70 #endif // CalculationValue_h |
OLD | NEW |