OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 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 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
64 { \ | 64 { \ |
65 v8::TryCatch block; \ | 65 v8::TryCatch block; \ |
66 var = (value); \ | 66 var = (value); \ |
67 if (UNLIKELY(block.HasCaught())) { \ | 67 if (UNLIKELY(block.HasCaught())) { \ |
68 block.ReThrow(); \ | 68 block.ReThrow(); \ |
69 return retVal; \ | 69 return retVal; \ |
70 } \ | 70 } \ |
71 } | 71 } |
72 | 72 |
73 #define TONATIVE_VOID_EXCEPTIONSTATE_INTERNAL(var, value, exceptionState) \ | 73 #define TONATIVE_VOID_EXCEPTIONSTATE_INTERNAL(var, value, exceptionState) \ |
74 var = (value); \ | 74 var = (value); \ |
75 if (UNLIKELY(block.HasCaught())) \ | 75 if (UNLIKELY(block.HasCaught() || exceptionState.throwIfNeeded())) \ |
76 exceptionState.rethrowV8Exception(block.Exception()); \ | 76 return; \ |
77 if (UNLIKELY(exceptionState.throwIfNeeded())) \ | |
78 return; | |
79 | 77 |
80 #define TONATIVE_VOID_EXCEPTIONSTATE(type, var, value, exceptionState) \ | 78 #define TONATIVE_VOID_EXCEPTIONSTATE(type, var, value, exceptionState) \ |
81 type var; \ | 79 type var; \ |
82 { \ | 80 { \ |
83 v8::TryCatch block; \ | 81 v8::TryCatch block; \ |
| 82 V8RethrowTryCatchScope rethrow(block); \ |
84 TONATIVE_VOID_EXCEPTIONSTATE_INTERNAL(var, value, exceptionState); \ | 83 TONATIVE_VOID_EXCEPTIONSTATE_INTERNAL(var, value, exceptionState); \ |
85 } | 84 } |
86 | 85 |
87 #define TONATIVE_DEFAULT_EXCEPTIONSTATE(type, var, value, exceptionState, retVal
) \ | 86 #define TONATIVE_DEFAULT_EXCEPTIONSTATE(type, var, value, exceptionState, retVal
) \ |
88 type var; \ | 87 type var;
\ |
89 { \ | 88 {
\ |
90 v8::TryCatch block; \ | 89 v8::TryCatch block;
\ |
91 var = (value); \ | 90 V8RethrowTryCatchScope rethrow(block);
\ |
92 if (UNLIKELY(block.HasCaught())) \ | 91 var = (value);
\ |
93 exceptionState.rethrowV8Exception(block.Exception()); \ | 92 if (UNLIKELY(block.HasCaught() || exceptionState.throwIfNeeded()))
\ |
94 if (UNLIKELY(exceptionState.throwIfNeeded())) \ | 93 return retVal;
\ |
95 return retVal; \ | |
96 } | 94 } |
97 | 95 |
98 // type is an instance of class template V8StringResource<>, | 96 // type is an instance of class template V8StringResource<>, |
99 // but Mode argument varies; using type (not Mode) for consistency | 97 // but Mode argument varies; using type (not Mode) for consistency |
100 // with other macros and ease of code generation | 98 // with other macros and ease of code generation |
101 #define TOSTRING_VOID(type, var, value) \ | 99 #define TOSTRING_VOID(type, var, value) \ |
102 type var(value); \ | 100 type var(value); \ |
103 if (UNLIKELY(!var.prepare())) \ | 101 if (UNLIKELY(!var.prepare())) \ |
104 return; | 102 return; |
105 | 103 |
106 #define TOSTRING_VOID_INTERNAL(var, value) \ | 104 #define TOSTRING_VOID_INTERNAL(var, value) \ |
107 var = (value); \ | 105 var = (value); \ |
108 if (UNLIKELY(!var.prepare())) \ | 106 if (UNLIKELY(!var.prepare())) \ |
109 return; | 107 return; |
110 | 108 |
111 #define TOSTRING_DEFAULT(type, var, value, retVal) \ | 109 #define TOSTRING_DEFAULT(type, var, value, retVal) \ |
112 type var(value); \ | 110 type var(value); \ |
113 if (UNLIKELY(!var.prepare())) \ | 111 if (UNLIKELY(!var.prepare())) \ |
114 return retVal; | 112 return retVal; |
115 | 113 |
116 } // namespace WebCore | 114 } // namespace WebCore |
117 | 115 |
118 #endif // V8BindingMacros_h | 116 #endif // V8BindingMacros_h |
OLD | NEW |