Refactoring llvm command line parsing and option registration.
authorChris Bieneman <beanz@apple.com>
Wed, 28 Jan 2015 19:00:25 +0000 (19:00 +0000)
committerChris Bieneman <beanz@apple.com>
Wed, 28 Jan 2015 19:00:25 +0000 (19:00 +0000)
commit61b9b31ef1ee75278de36f0d016bf732d6cf5e26
treec2ceb774c1f3303fd658547f1d5c589ac23c5d83
parent57e74771327cd30caf8040fbd09e6ca973ee4f00
Refactoring llvm command line parsing and option registration.

Summary:
The primary goal of this patch is to remove the need for MarkOptionsChanged(). That goal is accomplished by having addOption and removeOption properly sort the options.

This patch puts the new add and remove functionality on a CommandLineParser class that is a placeholder. Some of the functionality in this class will need to be merged into the OptionRegistry, and other bits can hopefully be in a better abstraction.

This patch also removes the RegisteredOptionList global, and the need for cl::Option objects to be linked list nodes.

The changes in CommandLineTest.cpp are required because these changes shift when we validate that options are not duplicated. Before this change duplicate options were only found during certain cl API calls (like cl::ParseCommandLine). With this change duplicate options are found during option construction.

Reviewers: dexonsmith, chandlerc, pete

Reviewed By: pete

Subscribers: pete, majnemer, llvm-commits

Differential Revision: http://reviews.llvm.org/D7132

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@227345 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/Support/CommandLine.h
lib/Support/CommandLine.cpp
unittests/Support/CommandLineTest.cpp