Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2014 Google Inc. All rights reserved. | 2 * Copyright (C) 2014 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 14 matching lines...) Expand all Loading... | |
| 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 29 */ | 29 */ |
| 30 | 30 |
| 31 #include "config.h" | 31 #include "config.h" |
| 32 #include "core/svg/SVGAngleTearOff.h" | 32 #include "core/svg/SVGAngleTearOff.h" |
| 33 | 33 |
| 34 #include "bindings/v8/ExceptionState.h" | 34 #include "bindings/v8/ExceptionState.h" |
| 35 #include "bindings/v8/ExceptionStatePlaceholder.h" | |
| 35 #include "core/dom/ExceptionCode.h" | 36 #include "core/dom/ExceptionCode.h" |
| 36 | 37 |
| 37 namespace WebCore { | 38 namespace WebCore { |
| 38 | 39 |
| 39 SVGAngleTearOff::SVGAngleTearOff(PassRefPtr<SVGAngle> targetProperty, SVGElement * contextElement, PropertyIsAnimValType propertyIsAnimVal, const QualifiedName& attributeName) | 40 SVGAngleTearOff::SVGAngleTearOff(PassRefPtr<SVGAngle> targetProperty, SVGElement * contextElement, PropertyIsAnimValType propertyIsAnimVal, const QualifiedName& attributeName) |
| 40 : SVGPropertyTearOff<SVGAngle>(targetProperty, contextElement, propertyIsAni mVal, attributeName) | 41 : SVGPropertyTearOff<SVGAngle>(targetProperty, contextElement, propertyIsAni mVal, attributeName) |
| 41 { | 42 { |
| 42 ScriptWrappable::init(this); | 43 ScriptWrappable::init(this); |
| 43 } | 44 } |
| 44 | 45 |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 101 commitChange(); | 102 commitChange(); |
| 102 } | 103 } |
| 103 | 104 |
| 104 void SVGAngleTearOff::setValueAsString(const String& value, ExceptionState& exce ptionState) | 105 void SVGAngleTearOff::setValueAsString(const String& value, ExceptionState& exce ptionState) |
| 105 { | 106 { |
| 106 if (isImmutable()) { | 107 if (isImmutable()) { |
| 107 exceptionState.throwDOMException(NoModificationAllowedError, "The attrib ute is read-only."); | 108 exceptionState.throwDOMException(NoModificationAllowedError, "The attrib ute is read-only."); |
| 108 return; | 109 return; |
| 109 } | 110 } |
| 110 | 111 |
| 112 String old = target()->valueAsString(); | |
|
fs
2014/06/11 07:29:07
Nit: s/old/oldValue/ (or something)
Erik Dahlström (inactive)
2014/06/11 08:04:25
Done.
| |
| 113 | |
| 111 target()->setValueAsString(value, exceptionState); | 114 target()->setValueAsString(value, exceptionState); |
| 115 | |
| 116 if (!exceptionState.hadException() && !hasExposedAngleUnit()) { | |
| 117 target()->setValueAsString(old, IGNORE_EXCEPTION); // rollback to old va lue | |
|
fs
2014/06/11 07:29:07
Nit: ASSERT_NO_EXCEPTION might be even better?
Erik Dahlström (inactive)
2014/06/11 08:04:25
Done.
| |
| 118 exceptionState.throwDOMException(SyntaxError, "The value provided ('" + value + "') is invalid."); | |
| 119 return; | |
| 120 } | |
| 121 | |
| 112 commitChange(); | 122 commitChange(); |
| 113 } | 123 } |
| 114 | 124 |
| 115 } | 125 } |
| OLD | NEW |