Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * CSS Media Query | 2 * CSS Media Query |
| 3 * | 3 * |
| 4 * Copyright (C) 2005, 2006 Kimmo Kinnunen <kimmo.t.kinnunen@nokia.com>. | 4 * Copyright (C) 2005, 2006 Kimmo Kinnunen <kimmo.t.kinnunen@nokia.com>. |
| 5 * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). | 5 * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). |
| 6 * | 6 * |
| 7 * Redistribution and use in source and binary forms, with or without | 7 * Redistribution and use in source and binary forms, with or without |
| 8 * modification, are permitted provided that the following conditions | 8 * modification, are permitted provided that the following conditions |
| 9 * are met: | 9 * are met: |
| 10 * 1. Redistributions of source code must retain the above copyright | 10 * 1. Redistributions of source code must retain the above copyright |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 54 if (expressions_.IsEmpty()) { | 54 if (expressions_.IsEmpty()) { |
| 55 result.Append(media_type_); | 55 result.Append(media_type_); |
| 56 return result.ToString(); | 56 return result.ToString(); |
| 57 } | 57 } |
| 58 | 58 |
| 59 if (media_type_ != MediaTypeNames::all || restrictor_ != kNone) { | 59 if (media_type_ != MediaTypeNames::all || restrictor_ != kNone) { |
| 60 result.Append(media_type_); | 60 result.Append(media_type_); |
| 61 result.Append(" and "); | 61 result.Append(" and "); |
| 62 } | 62 } |
| 63 | 63 |
| 64 result.Append(expressions_.at(0)->Serialize()); | 64 result.Append(expressions_.at(0).Serialize()); |
| 65 for (size_t i = 1; i < expressions_.size(); ++i) { | 65 for (size_t i = 1; i < expressions_.size(); ++i) { |
| 66 result.Append(" and "); | 66 result.Append(" and "); |
| 67 result.Append(expressions_.at(i)->Serialize()); | 67 result.Append(expressions_.at(i).Serialize()); |
| 68 } | 68 } |
| 69 return result.ToString(); | 69 return result.ToString(); |
| 70 } | 70 } |
| 71 | 71 |
| 72 static bool ExpressionCompare(const Member<MediaQueryExp>& a, | 72 static bool ExpressionCompare(const MediaQueryExp& a, const MediaQueryExp& b) { |
| 73 const Member<MediaQueryExp>& b) { | 73 return CodePointCompare(a.Serialize(), b.Serialize()) < 0; |
| 74 return CodePointCompare(a->Serialize(), b->Serialize()) < 0; | |
| 75 } | 74 } |
| 76 | 75 |
| 77 MediaQuery* MediaQuery::CreateNotAll() { | 76 std::unique_ptr<MediaQuery> MediaQuery::CreateNotAll() { |
| 78 return new MediaQuery(MediaQuery::kNot, MediaTypeNames::all, | 77 return WTF::WrapUnique(new MediaQuery(MediaQuery::kNot, MediaTypeNames::all, |
| 79 ExpressionHeapVector()); | 78 ExpressionHeapVector())); |
| 80 } | 79 } |
| 81 | 80 |
| 82 MediaQuery* MediaQuery::Create(RestrictorType restrictor, | 81 std::unique_ptr<MediaQuery> MediaQuery::Create( |
| 83 String media_type, | 82 RestrictorType restrictor, |
| 84 ExpressionHeapVector expressions) { | 83 String media_type, |
| 85 return new MediaQuery(restrictor, std::move(media_type), | 84 ExpressionHeapVector expressions) { |
| 86 std::move(expressions)); | 85 return WTF::WrapUnique(new MediaQuery(restrictor, std::move(media_type), |
| 86 std::move(expressions))); | |
| 87 } | 87 } |
| 88 | 88 |
| 89 MediaQuery::MediaQuery(RestrictorType restrictor, | 89 MediaQuery::MediaQuery(RestrictorType restrictor, |
| 90 String media_type, | 90 String media_type, |
| 91 ExpressionHeapVector expressions) | 91 ExpressionHeapVector expressions) |
| 92 : restrictor_(restrictor), | 92 : restrictor_(restrictor), |
| 93 media_type_(AttemptStaticStringCreation(media_type.DeprecatedLower())), | 93 media_type_(AttemptStaticStringCreation(media_type.DeprecatedLower())), |
| 94 expressions_(std::move(expressions)) { | 94 expressions_(std::move(expressions)) { |
| 95 NonCopyingSort(expressions_.begin(), expressions_.end(), ExpressionCompare); | 95 NonCopyingSort(expressions_.begin(), expressions_.end(), ExpressionCompare); |
| 96 | 96 |
| 97 // Remove all duplicated expressions. | 97 // Remove all duplicated expressions. |
| 98 MediaQueryExp* key = 0; | 98 MediaQueryExp key = MediaQueryExp::Invalid(); |
| 99 for (int i = expressions_.size() - 1; i >= 0; --i) { | 99 for (int i = expressions_.size() - 1; i >= 0; --i) { |
| 100 MediaQueryExp* exp = expressions_.at(i).Get(); | 100 MediaQueryExp exp = expressions_.at(i); |
| 101 | 101 CHECK(exp.IsValid()); |
| 102 if (key && *exp == *key) | 102 CHECK(String() == String()); |
|
sof
2017/04/26 09:16:11
accidental addition?
keishi
2017/04/26 09:44:35
Oops. Sorry.
| |
| 103 if (exp == key) | |
| 103 expressions_.erase(i); | 104 expressions_.erase(i); |
| 104 else | 105 else |
| 105 key = exp; | 106 key = exp; |
| 106 } | 107 } |
| 107 } | 108 } |
| 108 | 109 |
| 109 MediaQuery::MediaQuery(const MediaQuery& o) | 110 MediaQuery::MediaQuery(const MediaQuery& o) |
| 110 : restrictor_(o.restrictor_), | 111 : restrictor_(o.restrictor_), |
| 111 media_type_(o.media_type_), | 112 media_type_(o.media_type_), |
| 112 serialization_cache_(o.serialization_cache_) { | 113 serialization_cache_(o.serialization_cache_) { |
| 113 expressions_.ReserveInitialCapacity(o.expressions_.size()); | 114 expressions_.ReserveInitialCapacity(o.expressions_.size()); |
| 114 for (unsigned i = 0; i < o.expressions_.size(); ++i) | 115 for (unsigned i = 0; i < o.expressions_.size(); ++i) |
| 115 expressions_.push_back(o.expressions_[i]->Copy()); | 116 expressions_.push_back(o.expressions_[i]); |
| 116 } | 117 } |
| 117 | 118 |
| 118 MediaQuery::~MediaQuery() {} | 119 MediaQuery::~MediaQuery() {} |
| 119 | 120 |
| 120 // http://dev.w3.org/csswg/cssom/#compare-media-queries | 121 // http://dev.w3.org/csswg/cssom/#compare-media-queries |
| 121 bool MediaQuery::operator==(const MediaQuery& other) const { | 122 bool MediaQuery::operator==(const MediaQuery& other) const { |
| 122 return CssText() == other.CssText(); | 123 return CssText() == other.CssText(); |
| 123 } | 124 } |
| 124 | 125 |
| 125 // http://dev.w3.org/csswg/cssom/#serialize-a-list-of-media-queries | 126 // http://dev.w3.org/csswg/cssom/#serialize-a-list-of-media-queries |
| 126 String MediaQuery::CssText() const { | 127 String MediaQuery::CssText() const { |
| 127 if (serialization_cache_.IsNull()) | 128 if (serialization_cache_.IsNull()) |
| 128 const_cast<MediaQuery*>(this)->serialization_cache_ = Serialize(); | 129 const_cast<MediaQuery*>(this)->serialization_cache_ = Serialize(); |
| 129 | 130 |
| 130 return serialization_cache_; | 131 return serialization_cache_; |
| 131 } | 132 } |
| 132 | 133 |
| 133 DEFINE_TRACE(MediaQuery) { | |
| 134 visitor->Trace(expressions_); | |
| 135 } | |
| 136 | |
| 137 } // namespace blink | 134 } // namespace blink |
| OLD | NEW |