Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/regexp/regexp-parser.h" | 5 #include "src/regexp/regexp-parser.h" |
| 6 | 6 |
| 7 #include "src/char-predicates-inl.h" | 7 #include "src/char-predicates-inl.h" |
| 8 #include "src/factory.h" | 8 #include "src/factory.h" |
| 9 #include "src/isolate.h" | 9 #include "src/isolate.h" |
| 10 #include "src/objects-inl.h" | 10 #include "src/objects-inl.h" |
| (...skipping 1064 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1075 static_cast<UPropertyNameChoice>(U_LONG_PROPERTY_NAME + i)); | 1075 static_cast<UPropertyNameChoice>(U_LONG_PROPERTY_NAME + i)); |
| 1076 if (long_name == NULL) break; | 1076 if (long_name == NULL) break; |
| 1077 if (strcmp(property_value_name, long_name) == 0) return true; | 1077 if (strcmp(property_value_name, long_name) == 0) return true; |
| 1078 } | 1078 } |
| 1079 return false; | 1079 return false; |
| 1080 } | 1080 } |
| 1081 | 1081 |
| 1082 bool LookupPropertyValueName(UProperty property, | 1082 bool LookupPropertyValueName(UProperty property, |
| 1083 const char* property_value_name, bool negate, | 1083 const char* property_value_name, bool negate, |
| 1084 ZoneList<CharacterRange>* result, Zone* zone) { | 1084 ZoneList<CharacterRange>* result, Zone* zone) { |
| 1085 UProperty property_for_lookup = property; | |
| 1086 if (property_for_lookup == UCHAR_SCRIPT_EXTENSIONS) { | |
| 1087 // For the property Script_Extensions, we have to do the property value | |
| 1088 // name lookup as if the property is Script. | |
|
jungshik at Google
2016/11/17 22:27:49
Filed http://bugs.icu-project.org/trac/ticket/1285
Yang
2016/11/18 06:07:13
Thanks.
| |
| 1089 property_for_lookup = UCHAR_SCRIPT; | |
| 1090 } | |
| 1085 int32_t property_value = | 1091 int32_t property_value = |
| 1086 u_getPropertyValueEnum(property, property_value_name); | 1092 u_getPropertyValueEnum(property_for_lookup, property_value_name); |
| 1087 if (property_value == UCHAR_INVALID_CODE) return false; | 1093 if (property_value == UCHAR_INVALID_CODE) return false; |
| 1088 | 1094 |
| 1089 // We require the property name to match exactly to one of the property value | 1095 // We require the property name to match exactly to one of the property value |
| 1090 // aliases. However, u_getPropertyValueEnum uses loose matching. | 1096 // aliases. However, u_getPropertyValueEnum uses loose matching. |
| 1091 if (!IsExactPropertyValueAlias(property_value_name, property, | 1097 if (!IsExactPropertyValueAlias(property_value_name, property_for_lookup, |
| 1092 property_value)) { | 1098 property_value)) { |
| 1093 return false; | 1099 return false; |
| 1094 } | 1100 } |
| 1095 | 1101 |
| 1096 USet* set = uset_openEmpty(); | 1102 USet* set = uset_openEmpty(); |
|
jungshik at Google
2016/11/17 22:27:49
Not for this CL, but I wonder if there is any reas
Yang
2016/11/18 06:07:13
No reason. It's just the first one I came across.
| |
| 1097 UErrorCode ec = U_ZERO_ERROR; | 1103 UErrorCode ec = U_ZERO_ERROR; |
| 1098 uset_applyIntPropertyValue(set, property, property_value, &ec); | 1104 uset_applyIntPropertyValue(set, property, property_value, &ec); |
| 1099 bool success = ec == U_ZERO_ERROR && !uset_isEmpty(set); | 1105 bool success = ec == U_ZERO_ERROR && !uset_isEmpty(set); |
| 1100 | 1106 |
| 1101 if (success) { | 1107 if (success) { |
| 1102 uset_removeAllStrings(set); | 1108 uset_removeAllStrings(set); |
| 1103 if (negate) uset_complement(set); | 1109 if (negate) uset_complement(set); |
| 1104 int item_count = uset_getItemCount(set); | 1110 int item_count = uset_getItemCount(set); |
| 1105 int item_result = 0; | 1111 int item_result = 0; |
| 1106 for (int i = 0; i < item_count; i++) { | 1112 for (int i = 0; i < item_count; i++) { |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1189 if (property >= UCHAR_BINARY_LIMIT) return false; | 1195 if (property >= UCHAR_BINARY_LIMIT) return false; |
| 1190 if (!IsExactPropertyAlias(name, property)) return false; | 1196 if (!IsExactPropertyAlias(name, property)) return false; |
| 1191 return LookupPropertyValueName(property, negate ? "N" : "Y", false, result, | 1197 return LookupPropertyValueName(property, negate ? "N" : "Y", false, result, |
| 1192 zone()); | 1198 zone()); |
| 1193 } else { | 1199 } else { |
| 1194 // Both property name and value name are specified. Attempt to interpret | 1200 // Both property name and value name are specified. Attempt to interpret |
| 1195 // the property name as enumerated property. | 1201 // the property name as enumerated property. |
| 1196 const char* property_name = first_part.ToConstVector().start(); | 1202 const char* property_name = first_part.ToConstVector().start(); |
| 1197 const char* value_name = second_part.ToConstVector().start(); | 1203 const char* value_name = second_part.ToConstVector().start(); |
| 1198 UProperty property = u_getPropertyEnum(property_name); | 1204 UProperty property = u_getPropertyEnum(property_name); |
| 1199 if (property < UCHAR_INT_START) return false; | |
| 1200 if (property >= UCHAR_INT_LIMIT) return false; | |
| 1201 if (!IsExactPropertyAlias(property_name, property)) return false; | 1205 if (!IsExactPropertyAlias(property_name, property)) return false; |
| 1206 if (property == UCHAR_GENERAL_CATEGORY) { | |
| 1207 // We want to allow aggregate value names such as "Letter". | |
| 1208 property = UCHAR_GENERAL_CATEGORY_MASK; | |
| 1209 } else if (property != UCHAR_SCRIPT && | |
| 1210 property != UCHAR_SCRIPT_EXTENSIONS) { | |
| 1211 return false; | |
| 1212 } | |
| 1202 return LookupPropertyValueName(property, value_name, negate, result, | 1213 return LookupPropertyValueName(property, value_name, negate, result, |
| 1203 zone()); | 1214 zone()); |
| 1204 } | 1215 } |
| 1205 } | 1216 } |
| 1206 | 1217 |
| 1207 #else // V8_I18N_SUPPORT | 1218 #else // V8_I18N_SUPPORT |
| 1208 | 1219 |
| 1209 bool RegExpParser::ParsePropertyClass(ZoneList<CharacterRange>* result, | 1220 bool RegExpParser::ParsePropertyClass(ZoneList<CharacterRange>* result, |
| 1210 bool negate) { | 1221 bool negate) { |
| 1211 return false; | 1222 return false; |
| (...skipping 575 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1787 return false; | 1798 return false; |
| 1788 } | 1799 } |
| 1789 terms_.Add(new (zone()) RegExpQuantifier(min, max, quantifier_type, atom), | 1800 terms_.Add(new (zone()) RegExpQuantifier(min, max, quantifier_type, atom), |
| 1790 zone()); | 1801 zone()); |
| 1791 LAST(ADD_TERM); | 1802 LAST(ADD_TERM); |
| 1792 return true; | 1803 return true; |
| 1793 } | 1804 } |
| 1794 | 1805 |
| 1795 } // namespace internal | 1806 } // namespace internal |
| 1796 } // namespace v8 | 1807 } // namespace v8 |
| OLD | NEW |