OLD | NEW |
1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <stdarg.h> | 5 #include <stdarg.h> |
6 | 6 |
7 #include "v8.h" | 7 #include "v8.h" |
8 | 8 |
9 #include "bootstrapper.h" | 9 #include "bootstrapper.h" |
10 #include "code-stubs.h" | 10 #include "code-stubs.h" |
(...skipping 1918 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1929 } | 1929 } |
1930 Address setter_entry = v8::ToCData<Address>(ai->setter()); | 1930 Address setter_entry = v8::ToCData<Address>(ai->setter()); |
1931 if (setter_entry != 0) { | 1931 if (setter_entry != 0) { |
1932 PROFILE(isolate_, SetterCallbackEvent(name, setter_entry)); | 1932 PROFILE(isolate_, SetterCallbackEvent(name, setter_entry)); |
1933 } | 1933 } |
1934 } | 1934 } |
1935 } | 1935 } |
1936 | 1936 |
1937 | 1937 |
1938 static void AddIsolateIdIfNeeded(Isolate* isolate, StringStream* stream) { | 1938 static void AddIsolateIdIfNeeded(Isolate* isolate, StringStream* stream) { |
1939 if (isolate->IsDefaultIsolate() || !FLAG_logfile_per_isolate) return; | 1939 if (FLAG_logfile_per_isolate) stream->Add("isolate-%p-", isolate); |
1940 stream->Add("isolate-%p-", isolate); | |
1941 } | 1940 } |
1942 | 1941 |
1943 | 1942 |
1944 static SmartArrayPointer<const char> PrepareLogFileName( | 1943 static SmartArrayPointer<const char> PrepareLogFileName( |
1945 Isolate* isolate, const char* file_name) { | 1944 Isolate* isolate, const char* file_name) { |
1946 if (strchr(file_name, '%') != NULL || !isolate->IsDefaultIsolate()) { | 1945 HeapStringAllocator allocator; |
1947 // If there's a '%' in the log file name we have to expand | 1946 StringStream stream(&allocator); |
1948 // placeholders. | 1947 AddIsolateIdIfNeeded(isolate, &stream); |
1949 HeapStringAllocator allocator; | 1948 for (const char* p = file_name; *p; p++) { |
1950 StringStream stream(&allocator); | 1949 if (*p == '%') { |
1951 AddIsolateIdIfNeeded(isolate, &stream); | 1950 p++; |
1952 for (const char* p = file_name; *p; p++) { | 1951 switch (*p) { |
1953 if (*p == '%') { | 1952 case '\0': |
1954 p++; | 1953 // If there's a % at the end of the string we back up |
1955 switch (*p) { | 1954 // one character so we can escape the loop properly. |
1956 case '\0': | 1955 p--; |
1957 // If there's a % at the end of the string we back up | 1956 break; |
1958 // one character so we can escape the loop properly. | 1957 case 'p': |
1959 p--; | 1958 stream.Add("%d", OS::GetCurrentProcessId()); |
1960 break; | 1959 break; |
1961 case 'p': | 1960 case 't': { |
1962 stream.Add("%d", OS::GetCurrentProcessId()); | 1961 // %t expands to the current time in milliseconds. |
1963 break; | 1962 double time = OS::TimeCurrentMillis(); |
1964 case 't': { | 1963 stream.Add("%.0f", FmtElm(time)); |
1965 // %t expands to the current time in milliseconds. | 1964 break; |
1966 double time = OS::TimeCurrentMillis(); | |
1967 stream.Add("%.0f", FmtElm(time)); | |
1968 break; | |
1969 } | |
1970 case '%': | |
1971 // %% expands (contracts really) to %. | |
1972 stream.Put('%'); | |
1973 break; | |
1974 default: | |
1975 // All other %'s expand to themselves. | |
1976 stream.Put('%'); | |
1977 stream.Put(*p); | |
1978 break; | |
1979 } | 1965 } |
1980 } else { | 1966 case '%': |
1981 stream.Put(*p); | 1967 // %% expands (contracts really) to %. |
| 1968 stream.Put('%'); |
| 1969 break; |
| 1970 default: |
| 1971 // All other %'s expand to themselves. |
| 1972 stream.Put('%'); |
| 1973 stream.Put(*p); |
| 1974 break; |
1982 } | 1975 } |
| 1976 } else { |
| 1977 stream.Put(*p); |
1983 } | 1978 } |
1984 return SmartArrayPointer<const char>(stream.ToCString()); | |
1985 } | 1979 } |
1986 int length = StrLength(file_name); | 1980 return SmartArrayPointer<const char>(stream.ToCString()); |
1987 char* str = NewArray<char>(length + 1); | |
1988 OS::MemCopy(str, file_name, length); | |
1989 str[length] = '\0'; | |
1990 return SmartArrayPointer<const char>(str); | |
1991 } | 1981 } |
1992 | 1982 |
1993 | 1983 |
1994 bool Logger::SetUp(Isolate* isolate) { | 1984 bool Logger::SetUp(Isolate* isolate) { |
1995 // Tests and EnsureInitialize() can call this twice in a row. It's harmless. | 1985 // Tests and EnsureInitialize() can call this twice in a row. It's harmless. |
1996 if (is_initialized_) return true; | 1986 if (is_initialized_) return true; |
1997 is_initialized_ = true; | 1987 is_initialized_ = true; |
1998 | 1988 |
1999 // --ll-prof implies --log-code and --log-snapshot-positions. | 1989 // --ll-prof implies --log-code and --log-snapshot-positions. |
2000 if (FLAG_ll_prof) { | 1990 if (FLAG_ll_prof) { |
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2099 if (jit_logger_) { | 2089 if (jit_logger_) { |
2100 removeCodeEventListener(jit_logger_); | 2090 removeCodeEventListener(jit_logger_); |
2101 delete jit_logger_; | 2091 delete jit_logger_; |
2102 jit_logger_ = NULL; | 2092 jit_logger_ = NULL; |
2103 } | 2093 } |
2104 | 2094 |
2105 return log_->Close(); | 2095 return log_->Close(); |
2106 } | 2096 } |
2107 | 2097 |
2108 } } // namespace v8::internal | 2098 } } // namespace v8::internal |
OLD | NEW |