diff options
author | bauerb@chromium.org <bauerb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-07-30 10:17:07 +0000 |
---|---|---|
committer | bauerb@chromium.org <bauerb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-07-30 10:17:07 +0000 |
commit | 96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced (patch) | |
tree | f33c8f6fa3ae9fbba0178ba0cbf4f291fd3ec11e /tools/gn/scheduler.cc | |
parent | fb68e6c9f20785ccd0024f14b09c200060931953 (diff) | |
download | chromium_src-96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced.zip chromium_src-96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced.tar.gz chromium_src-96ea63d0d101ebbdbb08f79a80f3fa38bfb27ced.tar.bz2 |
Revert 214325 "Revert 214254 "Add initial prototype for the GN m..."
The issue was already fixed :)
> Revert 214254 "Add initial prototype for the GN meta-buildsystem."
>
> It broke the check_licenses step on Android (see http://build.chromium.org/p/chromium.linux/builders/Android%20Builder%20%28dbg%29/builds/39904/steps/check_licenses/logs/stdio):
>
> @@@BUILD_STEP check_licenses@@@
> > /b/build/slave/Android_Builder__dbg_/build/src/android_webview/tools/webview_licenses.py scan
> Got LicenseError "missing README.chromium or licenses.py SPECIAL_CASES entry" while scanning tools/gn/secondary/base/third_party/dynamic_annotations
> Got LicenseError "missing README.chromium or licenses.py SPECIAL_CASES entry" while scanning tools/gn/secondary/third_party/modp_b64
> < /b/build/slave/Android_Builder__dbg_/build/src/android_webview/tools/webview_licenses.py scan
> ERROR: process exited with code 2
> @@@STEP_FAILURE@@@
>
>
> > Add initial prototype for the GN meta-buildsystem.
> >
> > This is currently not hooked into the build. To build, add a reference to the
> > gn.gyp file to build/all.gyp
> >
> > R=darin@chromium.org, scottmg@chromium.org
> >
> > Review URL: https://codereview.chromium.org/21114002
>
> TBR=brettw@chromium.org
>
> Review URL: https://codereview.chromium.org/21084010
TBR=bauerb@chromium.org
Review URL: https://codereview.chromium.org/21204003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@214333 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'tools/gn/scheduler.cc')
-rw-r--r-- | tools/gn/scheduler.cc | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/tools/gn/scheduler.cc b/tools/gn/scheduler.cc new file mode 100644 index 0000000..33c8f1a --- /dev/null +++ b/tools/gn/scheduler.cc @@ -0,0 +1,130 @@ +// Copyright (c) 2013 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 "tools/gn/scheduler.h" + +#include "base/bind.h" +#include "tools/gn/ninja_target_writer.h" +#include "tools/gn/standard_out.h" + +Scheduler* g_scheduler = NULL; + +Scheduler::Scheduler() + : pool_(new base::SequencedWorkerPool(32, "worker_")), + input_file_manager_(new InputFileManager), + verbose_logging_(false), + work_count_(0), + is_failed_(false) { + g_scheduler = this; +} + +Scheduler::~Scheduler() { + g_scheduler = NULL; +} + +bool Scheduler::Run() { + runner_.Run(); + pool_->Shutdown(); + return !is_failed(); +} + +void Scheduler::Log(const std::string& verb, const std::string& msg) { + if (base::MessageLoop::current() == &main_loop_) { + LogOnMainThread(verb, msg); + } else { + // The run loop always joins on the sub threads, so the lifetime of this + // object outlives the invocations of this function, hence "unretained". + main_loop_.PostTask(FROM_HERE, + base::Bind(&Scheduler::LogOnMainThread, + base::Unretained(this), verb, msg)); + } +} + +void Scheduler::FailWithError(const Err& err) { + DCHECK(err.has_error()); + { + base::AutoLock lock(lock_); + + if (is_failed_) + return; // Ignore errors once we see one. + is_failed_ = true; + } + + if (base::MessageLoop::current() == &main_loop_) { + FailWithErrorOnMainThread(err); + } else { + // The run loop always joins on the sub threads, so the lifetime of this + // object outlives the invocations of this function, hence "unretained". + main_loop_.PostTask(FROM_HERE, + base::Bind(&Scheduler::FailWithErrorOnMainThread, + base::Unretained(this), err)); + } +} + +void Scheduler::ScheduleWork(const base::Closure& work) { + IncrementWorkCount(); + pool_->PostWorkerTaskWithShutdownBehavior( + FROM_HERE, base::Bind(&Scheduler::DoWork, + base::Unretained(this), work), + base::SequencedWorkerPool::BLOCK_SHUTDOWN); +} + +void Scheduler::ScheduleTargetFileWrite(const Target* target) { + pool_->PostWorkerTaskWithShutdownBehavior( + FROM_HERE, base::Bind(&Scheduler::DoTargetFileWrite, + base::Unretained(this), target), + base::SequencedWorkerPool::BLOCK_SHUTDOWN); +} + +void Scheduler::AddGenDependency(const SourceFile& source_file) { + base::AutoLock lock(lock_); + gen_dependencies_.push_back(source_file); +} + +std::vector<SourceFile> Scheduler::GetGenDependencies() const { + base::AutoLock lock(lock_); + return gen_dependencies_; +} + +void Scheduler::IncrementWorkCount() { + base::AtomicRefCountInc(&work_count_); +} + +void Scheduler::DecrementWorkCount() { + if (!base::AtomicRefCountDec(&work_count_)) { + if (base::MessageLoop::current() == &main_loop_) { + OnComplete(); + } else { + main_loop_.PostTask(FROM_HERE, + base::Bind(&Scheduler::OnComplete, + base::Unretained(this))); + } + } +} + +void Scheduler::LogOnMainThread(const std::string& verb, + const std::string& msg) { + OutputString(verb, DECORATION_YELLOW); + OutputString(" " + msg + "\n"); +} + +void Scheduler::FailWithErrorOnMainThread(const Err& err) { + err.PrintToStdout(); + runner_.Quit(); +} + +void Scheduler::DoTargetFileWrite(const Target* target) { + NinjaTargetWriter::RunAndWriteFile(target); +} + +void Scheduler::DoWork(const base::Closure& closure) { + closure.Run(); + DecrementWorkCount(); +} + +void Scheduler::OnComplete() { + // Should be called on the main thread. + DCHECK(base::MessageLoop::current() == main_loop()); + runner_.Quit(); +} |