OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2009 Google Inc. All rights reserved. | 2 * Copyright (C) 2009 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 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
67 uint32_t sqlArgsLength = 0; | 67 uint32_t sqlArgsLength = 0; |
68 v8::Local<v8::Object> sqlArgsObject = info[1]->ToObject(); | 68 v8::Local<v8::Object> sqlArgsObject = info[1]->ToObject(); |
69 TONATIVE_VOID(v8::Local<v8::Value>, length, sqlArgsObject->Get(v8AtomicS
tring(info.GetIsolate(), "length"))); | 69 TONATIVE_VOID(v8::Local<v8::Value>, length, sqlArgsObject->Get(v8AtomicS
tring(info.GetIsolate(), "length"))); |
70 | 70 |
71 if (isUndefinedOrNull(length)) | 71 if (isUndefinedOrNull(length)) |
72 sqlArgsLength = sqlArgsObject->GetPropertyNames()->Length(); | 72 sqlArgsLength = sqlArgsObject->GetPropertyNames()->Length(); |
73 else | 73 else |
74 sqlArgsLength = length->Uint32Value(); | 74 sqlArgsLength = length->Uint32Value(); |
75 | 75 |
76 for (unsigned i = 0; i < sqlArgsLength; ++i) { | 76 for (unsigned i = 0; i < sqlArgsLength; ++i) { |
77 v8::Handle<v8::Integer> key = v8::Integer::New(info.GetIsolate(), i)
; | 77 v8::Local<v8::Integer> key = v8::Integer::New(info.GetIsolate(), i); |
78 TONATIVE_VOID(v8::Local<v8::Value>, value, sqlArgsObject->Get(key)); | 78 TONATIVE_VOID(v8::Local<v8::Value>, value, sqlArgsObject->Get(key)); |
79 | 79 |
80 if (value.IsEmpty() || value->IsNull()) { | 80 if (value.IsEmpty() || value->IsNull()) { |
81 sqlValues.append(SQLValue()); | 81 sqlValues.append(SQLValue()); |
82 } else if (value->IsNumber()) { | 82 } else if (value->IsNumber()) { |
83 TONATIVE_VOID(double, sqlValue, value->NumberValue()); | 83 TONATIVE_VOID(double, sqlValue, value->NumberValue()); |
84 sqlValues.append(SQLValue(sqlValue)); | 84 sqlValues.append(SQLValue(sqlValue)); |
85 } else { | 85 } else { |
86 TOSTRING_VOID(V8StringResource<>, sqlValue, value); | 86 TOSTRING_VOID(V8StringResource<>, sqlValue, value); |
87 sqlValues.append(SQLValue(sqlValue)); | 87 sqlValues.append(SQLValue(sqlValue)); |
88 } | 88 } |
89 } | 89 } |
90 } | 90 } |
91 | 91 |
92 SQLTransaction* transaction = V8SQLTransaction::toImpl(info.Holder()); | 92 SQLTransaction* transaction = V8SQLTransaction::toImpl(info.Holder()); |
93 SQLStatementCallback* callback; | 93 SQLStatementCallback* callback; |
94 if (!isUndefinedOrNull(info[2])) { | 94 if (!isUndefinedOrNull(info[2])) { |
95 if (!info[2]->IsFunction()) { | 95 if (!info[2]->IsFunction()) { |
96 exceptionState.throwDOMException(TypeMismatchError, "The 'callback'
(2nd) argument provided is not a function."); | 96 exceptionState.throwDOMException(TypeMismatchError, "The 'callback'
(2nd) argument provided is not a function."); |
97 exceptionState.throwIfNeeded(); | 97 exceptionState.throwIfNeeded(); |
98 return; | 98 return; |
99 } | 99 } |
100 callback = V8SQLStatementCallback::create(v8::Handle<v8::Function>::Cast
(info[2]), ScriptState::current(info.GetIsolate())); | 100 callback = V8SQLStatementCallback::create(v8::Local<v8::Function>::Cast(
info[2]), ScriptState::current(info.GetIsolate())); |
101 } else { | 101 } else { |
102 callback = nullptr; | 102 callback = nullptr; |
103 } | 103 } |
104 | 104 |
105 SQLStatementErrorCallback* errorCallback; | 105 SQLStatementErrorCallback* errorCallback; |
106 if (!isUndefinedOrNull(info[3])) { | 106 if (!isUndefinedOrNull(info[3])) { |
107 if (!info[3]->IsFunction()) { | 107 if (!info[3]->IsFunction()) { |
108 exceptionState.throwDOMException(TypeMismatchError, "The 'errorCallb
ack' (3rd) argument provided is not a function."); | 108 exceptionState.throwDOMException(TypeMismatchError, "The 'errorCallb
ack' (3rd) argument provided is not a function."); |
109 exceptionState.throwIfNeeded(); | 109 exceptionState.throwIfNeeded(); |
110 return; | 110 return; |
111 } | 111 } |
112 errorCallback = V8SQLStatementErrorCallback::create(v8::Handle<v8::Funct
ion>::Cast(info[3]), ScriptState::current(info.GetIsolate())); | 112 errorCallback = V8SQLStatementErrorCallback::create(v8::Local<v8::Functi
on>::Cast(info[3]), ScriptState::current(info.GetIsolate())); |
113 } else { | 113 } else { |
114 errorCallback = nullptr; | 114 errorCallback = nullptr; |
115 } | 115 } |
116 | 116 |
117 transaction->executeSQL(statement, sqlValues, callback, errorCallback, excep
tionState); | 117 transaction->executeSQL(statement, sqlValues, callback, errorCallback, excep
tionState); |
118 exceptionState.throwIfNeeded(); | 118 exceptionState.throwIfNeeded(); |
119 } | 119 } |
120 | 120 |
121 } // namespace blink | 121 } // namespace blink |
OLD | NEW |