OLD | NEW |
1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 1118 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1129 } | 1129 } |
1130 EXCEPTION_PREAMBLE(); | 1130 EXCEPTION_PREAMBLE(); |
1131 i::ScriptDataImpl* pre_data_impl = static_cast<i::ScriptDataImpl*>(pre_data); | 1131 i::ScriptDataImpl* pre_data_impl = static_cast<i::ScriptDataImpl*>(pre_data); |
1132 // We assert that the pre-data is sane, even though we can actually | 1132 // We assert that the pre-data is sane, even though we can actually |
1133 // handle it if it turns out not to be in release mode. | 1133 // handle it if it turns out not to be in release mode. |
1134 ASSERT(pre_data_impl == NULL || pre_data_impl->SanityCheck()); | 1134 ASSERT(pre_data_impl == NULL || pre_data_impl->SanityCheck()); |
1135 // If the pre-data isn't sane we simply ignore it | 1135 // If the pre-data isn't sane we simply ignore it |
1136 if (pre_data_impl != NULL && !pre_data_impl->SanityCheck()) { | 1136 if (pre_data_impl != NULL && !pre_data_impl->SanityCheck()) { |
1137 pre_data_impl = NULL; | 1137 pre_data_impl = NULL; |
1138 } | 1138 } |
1139 i::Handle<i::JSFunction> boilerplate = | 1139 i::Handle<i::SharedFunctionInfo> result = |
1140 i::Compiler::Compile(str, | 1140 i::Compiler::Compile(str, |
1141 name_obj, | 1141 name_obj, |
1142 line_offset, | 1142 line_offset, |
1143 column_offset, | 1143 column_offset, |
1144 NULL, | 1144 NULL, |
1145 pre_data_impl, | 1145 pre_data_impl, |
1146 Utils::OpenHandle(*script_data), | 1146 Utils::OpenHandle(*script_data), |
1147 i::NOT_NATIVES_CODE); | 1147 i::NOT_NATIVES_CODE); |
1148 has_pending_exception = boilerplate.is_null(); | 1148 has_pending_exception = result.is_null(); |
1149 EXCEPTION_BAILOUT_CHECK(Local<Script>()); | 1149 EXCEPTION_BAILOUT_CHECK(Local<Script>()); |
1150 return Local<Script>(ToApi<Script>(boilerplate)); | 1150 return Local<Script>(ToApi<Script>(result)); |
1151 } | 1151 } |
1152 | 1152 |
1153 | 1153 |
1154 Local<Script> Script::New(v8::Handle<String> source, | 1154 Local<Script> Script::New(v8::Handle<String> source, |
1155 v8::Handle<Value> file_name) { | 1155 v8::Handle<Value> file_name) { |
1156 ScriptOrigin origin(file_name); | 1156 ScriptOrigin origin(file_name); |
1157 return New(source, &origin); | 1157 return New(source, &origin); |
1158 } | 1158 } |
1159 | 1159 |
1160 | 1160 |
1161 Local<Script> Script::Compile(v8::Handle<String> source, | 1161 Local<Script> Script::Compile(v8::Handle<String> source, |
1162 v8::ScriptOrigin* origin, | 1162 v8::ScriptOrigin* origin, |
1163 v8::ScriptData* pre_data, | 1163 v8::ScriptData* pre_data, |
1164 v8::Handle<String> script_data) { | 1164 v8::Handle<String> script_data) { |
1165 ON_BAILOUT("v8::Script::Compile()", return Local<Script>()); | 1165 ON_BAILOUT("v8::Script::Compile()", return Local<Script>()); |
1166 LOG_API("Script::Compile"); | 1166 LOG_API("Script::Compile"); |
1167 ENTER_V8; | 1167 ENTER_V8; |
1168 Local<Script> generic = New(source, origin, pre_data, script_data); | 1168 Local<Script> generic = New(source, origin, pre_data, script_data); |
1169 if (generic.IsEmpty()) | 1169 if (generic.IsEmpty()) |
1170 return generic; | 1170 return generic; |
1171 i::Handle<i::JSFunction> boilerplate = Utils::OpenHandle(*generic); | 1171 i::Handle<i::Object> obj = Utils::OpenHandle(*generic); |
| 1172 i::Handle<i::SharedFunctionInfo> function = |
| 1173 i::Handle<i::SharedFunctionInfo>(i::SharedFunctionInfo::cast(*obj)); |
1172 i::Handle<i::JSFunction> result = | 1174 i::Handle<i::JSFunction> result = |
1173 i::Factory::NewFunctionFromBoilerplate(boilerplate, | 1175 i::Factory::NewFunctionFromSharedFunctionInfo(function, |
1174 i::Top::global_context()); | 1176 i::Top::global_context()); |
1175 return Local<Script>(ToApi<Script>(result)); | 1177 return Local<Script>(ToApi<Script>(result)); |
1176 } | 1178 } |
1177 | 1179 |
1178 | 1180 |
1179 Local<Script> Script::Compile(v8::Handle<String> source, | 1181 Local<Script> Script::Compile(v8::Handle<String> source, |
1180 v8::Handle<Value> file_name, | 1182 v8::Handle<Value> file_name, |
1181 v8::Handle<String> script_data) { | 1183 v8::Handle<String> script_data) { |
1182 ScriptOrigin origin(file_name); | 1184 ScriptOrigin origin(file_name); |
1183 return Compile(source, &origin, 0, script_data); | 1185 return Compile(source, &origin, 0, script_data); |
1184 } | 1186 } |
1185 | 1187 |
1186 | 1188 |
1187 Local<Value> Script::Run() { | 1189 Local<Value> Script::Run() { |
1188 ON_BAILOUT("v8::Script::Run()", return Local<Value>()); | 1190 ON_BAILOUT("v8::Script::Run()", return Local<Value>()); |
1189 LOG_API("Script::Run"); | 1191 LOG_API("Script::Run"); |
1190 ENTER_V8; | 1192 ENTER_V8; |
1191 i::Object* raw_result = NULL; | 1193 i::Object* raw_result = NULL; |
1192 { | 1194 { |
1193 HandleScope scope; | 1195 HandleScope scope; |
1194 i::Handle<i::JSFunction> fun = Utils::OpenHandle(this); | 1196 i::Handle<i::Object> obj = Utils::OpenHandle(this); |
1195 if (fun->IsBoilerplate()) { | 1197 i::Handle<i::JSFunction> fun; |
1196 fun = i::Factory::NewFunctionFromBoilerplate(fun, | 1198 if (obj->IsSharedFunctionInfo()) { |
1197 i::Top::global_context()); | 1199 i::Handle<i::SharedFunctionInfo> |
| 1200 function_info(i::SharedFunctionInfo::cast(*obj)); |
| 1201 fun = i::Factory::NewFunctionFromSharedFunctionInfo( |
| 1202 function_info, i::Top::global_context()); |
| 1203 } else { |
| 1204 fun = i::Handle<i::JSFunction>(i::JSFunction::cast(*obj)); |
1198 } | 1205 } |
1199 EXCEPTION_PREAMBLE(); | 1206 EXCEPTION_PREAMBLE(); |
1200 i::Handle<i::Object> receiver(i::Top::context()->global_proxy()); | 1207 i::Handle<i::Object> receiver(i::Top::context()->global_proxy()); |
1201 i::Handle<i::Object> result = | 1208 i::Handle<i::Object> result = |
1202 i::Execution::Call(fun, receiver, 0, NULL, &has_pending_exception); | 1209 i::Execution::Call(fun, receiver, 0, NULL, &has_pending_exception); |
1203 EXCEPTION_BAILOUT_CHECK(Local<Value>()); | 1210 EXCEPTION_BAILOUT_CHECK(Local<Value>()); |
1204 raw_result = *result; | 1211 raw_result = *result; |
1205 } | 1212 } |
1206 i::Handle<i::Object> result(raw_result); | 1213 i::Handle<i::Object> result(raw_result); |
1207 return Utils::ToLocal(result); | 1214 return Utils::ToLocal(result); |
1208 } | 1215 } |
1209 | 1216 |
1210 | 1217 |
| 1218 static i::Handle<i::SharedFunctionInfo> OpenScript(Script* script) { |
| 1219 i::Handle<i::Object> obj = Utils::OpenHandle(script); |
| 1220 i::Handle<i::SharedFunctionInfo> result; |
| 1221 if (obj->IsSharedFunctionInfo()) { |
| 1222 result = |
| 1223 i::Handle<i::SharedFunctionInfo>(i::SharedFunctionInfo::cast(*obj)); |
| 1224 } else { |
| 1225 result = |
| 1226 i::Handle<i::SharedFunctionInfo>(i::JSFunction::cast(*obj)->shared()); |
| 1227 } |
| 1228 return result; |
| 1229 } |
| 1230 |
| 1231 |
1211 Local<Value> Script::Id() { | 1232 Local<Value> Script::Id() { |
1212 ON_BAILOUT("v8::Script::Id()", return Local<Value>()); | 1233 ON_BAILOUT("v8::Script::Id()", return Local<Value>()); |
1213 LOG_API("Script::Id"); | 1234 LOG_API("Script::Id"); |
1214 i::Object* raw_id = NULL; | 1235 i::Object* raw_id = NULL; |
1215 { | 1236 { |
1216 HandleScope scope; | 1237 HandleScope scope; |
1217 i::Handle<i::JSFunction> fun = Utils::OpenHandle(this); | 1238 i::Handle<i::SharedFunctionInfo> function_info = OpenScript(this); |
1218 i::Handle<i::Script> script(i::Script::cast(fun->shared()->script())); | 1239 i::Handle<i::Script> script(i::Script::cast(function_info->script())); |
1219 i::Handle<i::Object> id(script->id()); | 1240 i::Handle<i::Object> id(script->id()); |
1220 raw_id = *id; | 1241 raw_id = *id; |
1221 } | 1242 } |
1222 i::Handle<i::Object> id(raw_id); | 1243 i::Handle<i::Object> id(raw_id); |
1223 return Utils::ToLocal(id); | 1244 return Utils::ToLocal(id); |
1224 } | 1245 } |
1225 | 1246 |
1226 | 1247 |
1227 void Script::SetData(v8::Handle<String> data) { | 1248 void Script::SetData(v8::Handle<String> data) { |
1228 ON_BAILOUT("v8::Script::SetData()", return); | 1249 ON_BAILOUT("v8::Script::SetData()", return); |
1229 LOG_API("Script::SetData"); | 1250 LOG_API("Script::SetData"); |
1230 { | 1251 { |
1231 HandleScope scope; | 1252 HandleScope scope; |
1232 i::Handle<i::JSFunction> fun = Utils::OpenHandle(this); | 1253 i::Handle<i::SharedFunctionInfo> function_info = OpenScript(this); |
1233 i::Handle<i::Object> raw_data = Utils::OpenHandle(*data); | 1254 i::Handle<i::Object> raw_data = Utils::OpenHandle(*data); |
1234 i::Handle<i::Script> script(i::Script::cast(fun->shared()->script())); | 1255 i::Handle<i::Script> script(i::Script::cast(function_info->script())); |
1235 script->set_data(*raw_data); | 1256 script->set_data(*raw_data); |
1236 } | 1257 } |
1237 } | 1258 } |
1238 | 1259 |
1239 | 1260 |
1240 // --- E x c e p t i o n s --- | 1261 // --- E x c e p t i o n s --- |
1241 | 1262 |
1242 | 1263 |
1243 v8::TryCatch::TryCatch() | 1264 v8::TryCatch::TryCatch() |
1244 : next_(i::Top::try_catch_handler_address()), | 1265 : next_(i::Top::try_catch_handler_address()), |
(...skipping 2761 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4006 | 4027 |
4007 | 4028 |
4008 char* HandleScopeImplementer::Iterate(ObjectVisitor* v, char* storage) { | 4029 char* HandleScopeImplementer::Iterate(ObjectVisitor* v, char* storage) { |
4009 HandleScopeImplementer* thread_local = | 4030 HandleScopeImplementer* thread_local = |
4010 reinterpret_cast<HandleScopeImplementer*>(storage); | 4031 reinterpret_cast<HandleScopeImplementer*>(storage); |
4011 thread_local->IterateThis(v); | 4032 thread_local->IterateThis(v); |
4012 return storage + ArchiveSpacePerThread(); | 4033 return storage + ArchiveSpacePerThread(); |
4013 } | 4034 } |
4014 | 4035 |
4015 } } // namespace v8::internal | 4036 } } // namespace v8::internal |
OLD | NEW |