blob: 36467b459cced91488b3b6d7bc87c2b538bcd4d4 [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/app/android/library_loader_hooks.h"
#include "base/android/reached_code_profiler.h"
#include "base/logging.h"
#include "base/trace_event/trace_event.h"
#include "content/common/content_constants_internal.h"
#include "content/common/url_schemes.h"
#include "services/tracing/public/cpp/trace_startup.h"
namespace content {
bool LibraryLoaded(JNIEnv* env,
jclass clazz,
base::android::LibraryProcessType library_process_type) {
if (library_process_type ==
base::android::LibraryProcessType::PROCESS_BROWSER ||
library_process_type ==
base::android::LibraryProcessType::PROCESS_CHILD) {
base::android::InitReachedCodeProfilerAtStartup(library_process_type);
}
// Android's main browser loop is custom so we set the browser name here as
// early as possible if this is the browser process or main webview process.
if (library_process_type ==
base::android::LibraryProcessType::PROCESS_BROWSER ||
library_process_type ==
base::android::LibraryProcessType::PROCESS_WEBVIEW) {
base::trace_event::TraceLog::GetInstance()->set_process_name("Browser");
}
base::trace_event::TraceLog::GetInstance()->SetProcessSortIndex(
kTraceEventBrowserProcessSortIndex);
// Tracing itself can only be enabled after mojo is initialized, we do so in
// ContentMainRunnerImpl::Initialize.
logging::LoggingSettings settings;
settings.logging_dest =
logging::LOG_TO_SYSTEM_DEBUG_LOG | logging::LOG_TO_STDERR;
logging::InitLogging(settings);
// To view log output with IDs and timestamps use "adb logcat -v threadtime".
logging::SetLogItems(false, // Process ID
false, // Thread ID
false, // Timestamp
false); // Tick count
if (logging::GetMinLogLevel() != 0 || logging::GetVlogVerbosity() != 0 ||
DCHECK_IS_ON()) {
VLOG(0) << "Chromium logging enabled: level = " << logging::GetMinLogLevel()
<< ", default verbosity = " << logging::GetVlogVerbosity();
}
// Content Schemes need to be registered as early as possible after the
// CommandLine has been initialized to allow java and tests to use GURL before
// running ContentMain.
RegisterContentSchemes();
return true;
}
} // namespace content