OLD | NEW |
1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 951 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
962 } | 962 } |
963 | 963 |
964 thread_context.Dispose(); | 964 thread_context.Dispose(); |
965 ptr = next_line; | 965 ptr = next_line; |
966 } | 966 } |
967 } | 967 } |
968 #endif // V8_SHARED | 968 #endif // V8_SHARED |
969 | 969 |
970 | 970 |
971 SourceGroup::~SourceGroup() { | 971 SourceGroup::~SourceGroup() { |
| 972 #ifndef V8_SHARED |
972 delete next_semaphore_; | 973 delete next_semaphore_; |
973 next_semaphore_ = NULL; | 974 next_semaphore_ = NULL; |
974 delete done_semaphore_; | 975 delete done_semaphore_; |
975 done_semaphore_ = NULL; | 976 done_semaphore_ = NULL; |
976 delete thread_; | 977 delete thread_; |
977 thread_ = NULL; | 978 thread_ = NULL; |
| 979 #endif // V8_SHARED |
978 } | 980 } |
979 | 981 |
980 | 982 |
981 void SourceGroup::ExitShell(int exit_code) { | 983 void SourceGroup::ExitShell(int exit_code) { |
982 // Use _exit instead of exit to avoid races between isolate | 984 // Use _exit instead of exit to avoid races between isolate |
983 // threads and static destructors. | 985 // threads and static destructors. |
984 fflush(stdout); | 986 fflush(stdout); |
985 fflush(stderr); | 987 fflush(stderr); |
986 _exit(exit_code); | 988 _exit(exit_code); |
987 } | 989 } |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1071 thread_->Start(); | 1073 thread_->Start(); |
1072 } | 1074 } |
1073 next_semaphore_->Signal(); | 1075 next_semaphore_->Signal(); |
1074 } | 1076 } |
1075 | 1077 |
1076 | 1078 |
1077 void SourceGroup::WaitForThread() { | 1079 void SourceGroup::WaitForThread() { |
1078 if (thread_ == NULL) return; | 1080 if (thread_ == NULL) return; |
1079 if (Shell::options.last_run) { | 1081 if (Shell::options.last_run) { |
1080 thread_->Join(); | 1082 thread_->Join(); |
1081 thread_ = NULL; | |
1082 } else { | 1083 } else { |
1083 done_semaphore_->Wait(); | 1084 done_semaphore_->Wait(); |
1084 } | 1085 } |
1085 } | 1086 } |
1086 #endif // V8_SHARED | 1087 #endif // V8_SHARED |
1087 | 1088 |
1088 | 1089 |
1089 bool Shell::SetOptions(int argc, char* argv[]) { | 1090 bool Shell::SetOptions(int argc, char* argv[]) { |
1090 for (int i = 0; i < argc; i++) { | 1091 for (int i = 0; i < argc; i++) { |
1091 if (strcmp(argv[i], "--stress-opt") == 0) { | 1092 if (strcmp(argv[i], "--stress-opt") == 0) { |
(...skipping 232 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1324 } | 1325 } |
1325 | 1326 |
1326 } // namespace v8 | 1327 } // namespace v8 |
1327 | 1328 |
1328 | 1329 |
1329 #ifndef GOOGLE3 | 1330 #ifndef GOOGLE3 |
1330 int main(int argc, char* argv[]) { | 1331 int main(int argc, char* argv[]) { |
1331 return v8::Shell::Main(argc, argv); | 1332 return v8::Shell::Main(argc, argv); |
1332 } | 1333 } |
1333 #endif | 1334 #endif |
OLD | NEW |