Trigger4Win/libcmdline/Parsing/OptionGroupParser.cs
2015-04-10 00:09:58 +00:00

130 lines
No EOL
5.2 KiB
C#

#region License
// <copyright file="OptionGroupParser.cs" company="Giacomo Stelluti Scala">
// Copyright 2015-2013 Giacomo Stelluti Scala
// </copyright>
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
#endregion
namespace CommandLine.Parsing
{
internal sealed class OptionGroupParser : ArgumentParser
{
private readonly bool _ignoreUnkwnownArguments;
public OptionGroupParser(bool ignoreUnkwnownArguments)
{
_ignoreUnkwnownArguments = ignoreUnkwnownArguments;
}
public override PresentParserState Parse(IArgumentEnumerator argumentEnumerator, OptionMap map, object options)
{
var optionGroup = new OneCharStringEnumerator(argumentEnumerator.Current.Substring(1));
while (optionGroup.MoveNext())
{
var option = map[optionGroup.Current];
if (option == null)
{
return _ignoreUnkwnownArguments ? PresentParserState.MoveOnNextElement : PresentParserState.Failure;
}
option.IsDefined = true;
ArgumentParser.EnsureOptionArrayAttributeIsNotBoundToScalar(option);
if (!option.IsBoolean)
{
if (argumentEnumerator.IsLast && optionGroup.IsLast)
{
return PresentParserState.Failure;
}
bool valueSetting;
if (!optionGroup.IsLast)
{
if (!option.IsArray)
{
valueSetting = option.SetValue(optionGroup.GetRemainingFromNext(), options);
if (!valueSetting)
{
DefineOptionThatViolatesFormat(option);
}
return ArgumentParser.BooleanToParserState(valueSetting);
}
ArgumentParser.EnsureOptionAttributeIsArrayCompatible(option);
var items = ArgumentParser.GetNextInputValues(argumentEnumerator);
items.Insert(0, optionGroup.GetRemainingFromNext());
valueSetting = option.SetValue(items, options);
if (!valueSetting)
{
DefineOptionThatViolatesFormat(option);
}
return ArgumentParser.BooleanToParserState(valueSetting, true);
}
if (!argumentEnumerator.IsLast && !ArgumentParser.IsInputValue(argumentEnumerator.Next))
{
return PresentParserState.Failure;
}
if (!option.IsArray)
{
valueSetting = option.SetValue(argumentEnumerator.Next, options);
if (!valueSetting)
{
DefineOptionThatViolatesFormat(option);
}
return ArgumentParser.BooleanToParserState(valueSetting, true);
}
ArgumentParser.EnsureOptionAttributeIsArrayCompatible(option);
var moreItems = ArgumentParser.GetNextInputValues(argumentEnumerator);
valueSetting = option.SetValue(moreItems, options);
if (!valueSetting)
{
DefineOptionThatViolatesFormat(option);
}
return ArgumentParser.BooleanToParserState(valueSetting);
}
if (!optionGroup.IsLast && map[optionGroup.Next] == null)
{
return PresentParserState.Failure;
}
if (!option.SetValue(true, options))
{
return PresentParserState.Failure;
}
}
return PresentParserState.Success;
}
}
}