diff options
| author | Chris Bieneman <beanz@apple.com> | 2014-10-15 21:54:35 +0000 |
|---|---|---|
| committer | Chris Bieneman <beanz@apple.com> | 2014-10-15 21:54:35 +0000 |
| commit | 732e0aa9fb84f1d89e8fa9233f814415cc45a637 (patch) | |
| tree | e00e4701ee328fb676addf55b17ee53bcb4b6681 /llvm/lib/Support/Options.cpp | |
| parent | de4de39c9d5f902c421e562d8b72af7361ace53d (diff) | |
| download | bcm5719-llvm-732e0aa9fb84f1d89e8fa9233f814415cc45a637.tar.gz bcm5719-llvm-732e0aa9fb84f1d89e8fa9233f814415cc45a637.zip | |
Defining a new API for debug options that doesn't rely on static global cl::opts.
Summary:
This is based on the discussions from the LLVMDev thread:
http://lists.cs.uiuc.edu/pipermail/llvmdev/2014-August/075886.html
Reviewers: chandlerc
Reviewed By: chandlerc
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D5389
llvm-svn: 219854
Diffstat (limited to 'llvm/lib/Support/Options.cpp')
| -rw-r--r-- | llvm/lib/Support/Options.cpp | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/llvm/lib/Support/Options.cpp b/llvm/lib/Support/Options.cpp new file mode 100644 index 00000000000..71258450efa --- /dev/null +++ b/llvm/lib/Support/Options.cpp @@ -0,0 +1,33 @@ +//===- llvm/Support/Options.cpp - Debug options support ---------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file implements the helper objects for defining debug options using the +// new API built on cl::opt, but not requiring the use of static globals. +// +//===----------------------------------------------------------------------===// + +#include "llvm/Support/Options.h" +#include "llvm/Support/ManagedStatic.h" + +using namespace llvm; + +OptionRegistry::~OptionRegistry() { + for (auto IT = Options.begin(); IT != Options.end(); ++IT) + delete IT->second; +} + +void OptionRegistry::addOption(void *Key, cl::Option *O) { + assert(Options.find(Key) == Options.end() && + "Argument with this key already registerd"); + Options.insert(std::make_pair(Key, O)); +} + +static ManagedStatic<OptionRegistry> OR; + +OptionRegistry &OptionRegistry::instance() { return *OR; } |

