blob: f3e6ddd65f4ba27d5e5768549be4b37b2c3239cd [file] [log] [blame]
Damien Martin-Guillerezf88f4d82015-09-25 13:56:55 +00001// Copyright 2014 The Bazel Authors. All rights reserved.
Han-Wen Nienhuysd08b27f2015-02-25 16:45:20 +01002//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14package com.google.devtools.common.options;
15
16/**
17 * A converter is a little helper object that can take a String and
18 * turn it into an instance of type T (the type parameter to the converter).
19 */
20public interface Converter<T> {
21
22 /**
Googler21b759d2019-04-03 10:57:09 -070023 * Convert a string into type T. Please note that we assume that converting the same string (if
24 * successful) will produce objects which are equal ({@link Object#equals)}).
Han-Wen Nienhuysd08b27f2015-02-25 16:45:20 +010025 */
26 T convert(String input) throws OptionsParsingException;
27
28 /**
29 * The type description appears in usage messages. E.g.: "a string",
30 * "a path", etc.
31 */
32 String getTypeDescription();
33
34}