depot/third_party/copybara/java/com/google/copybara/LabelFinder.java

103 lines
2.7 KiB
Java
Raw Normal View History

/*
* Copyright (C) 2016 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.google.copybara;
import static com.google.common.base.Preconditions.checkState;
import com.google.re2j.Matcher;
import com.google.re2j.Pattern;
/**
* A simple line finder/parser for labels like:
* <ul>
* <li>foo = bar</li>
* <li>baz : foo</li>
* </ul>
*
* <p>In general this class should only be used in {@code Origin}s to create a labels map.
* During transformations/destination, it can be used to check if a line is a line but
* never to find labels. Use {@link TransformWork#getLabel(String)} instead, since it looks
* in more places for labels.
*
* TODO(malcon): Rename to MaybeLabel
*/
public class LabelFinder {
private static final String VALID_LABEL_EXPR = "([\\w-]+)";
public static final Pattern VALID_LABEL = Pattern.compile(VALID_LABEL_EXPR);
private static final Pattern URL = Pattern.compile(VALID_LABEL + "://.*");
private static final Pattern LABEL_PATTERN = Pattern.compile(
"^" + VALID_LABEL_EXPR + "( *[:=] ?)(.*)");
private final Matcher matcher;
private final String line;
public LabelFinder(String line) {
matcher = LABEL_PATTERN.matcher(line);
this.line = line;
}
public boolean isLabel() {
// It is a line if it looks like a line but it doesn't look like a url (foo://bar)
return matcher.matches() && !URL.matcher(line).matches();
}
public boolean isLabel(String labelName) {
return isLabel() && getName().equals(labelName);
}
/**
* Returns the name of the label.
*
* <p>Use isLabel() method before calling this method.
*/
public String getName() {
checkIsLabel();
return matcher.group(1);
}
/**
* Returns the separator of the label.
*
* <p>Use isLabel() method before calling this method.
*/
public String getSeparator() {
checkIsLabel();
return matcher.group(2);
}
/**
* Returns the value of the label.
*
* <p>Use isLabel() method before calling this method.
*/
public String getValue() {
checkIsLabel();
return matcher.group(3);
}
private void checkIsLabel() {
checkState(isLabel(), "Not a label: '" + line + "'. Please call isLabel() first");
}
public String getLine() {
return line;
}
}