plantuml/src/net/sourceforge/plantuml/project/lang/Verbs.java

171 lines
4.3 KiB
Java

/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2023, Arnaud Roques
*
* Project Info: http://plantuml.com
*
* If you like this project or if you find it useful, you can support us at:
*
* http://plantuml.com/patreon (only 1$ per month!)
* http://plantuml.com/paypal
*
* This file is part of PlantUML.
*
* PlantUML is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* PlantUML distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA.
*
*
* Original Author: Arnaud Roques
*
*
*/
package net.sourceforge.plantuml.project.lang;
import net.sourceforge.plantuml.command.regex.IRegex;
import net.sourceforge.plantuml.command.regex.RegexConcat;
import net.sourceforge.plantuml.command.regex.RegexLeaf;
import net.sourceforge.plantuml.command.regex.RegexOptional;
import net.sourceforge.plantuml.command.regex.RegexOr;
public class Verbs {
public static IRegex are() {
return new RegexLeaf("are");
}
public static IRegex areColored() {
return new RegexLeaf("are[%s]+colou?red");
}
public static IRegex displayOnSameRowAs() {
return new RegexLeaf("displays?[%s]+on[%s]+same[%s]+row[%s]+as");
}
public static IRegex ends() {
return new RegexLeaf("ends");
}
public static IRegex ends2() {
return new RegexLeaf("ends[%s]*(the[%s]*|on[%s]*|at[%s]*)*");
}
public static IRegex happens() {
return new RegexLeaf("happens?[%s]*(at[%s]*|the[%s]*|on[%s]*)*");
}
public static IRegex pauses() {
return new RegexLeaf("pauses?[%s]*(at[%s]*|the[%s]*|on[%s]*|from[%s]*)*");
}
public static IRegex isDeleted() {
return new RegexLeaf("is[%s]+deleted");
}
public static IRegex is() {
return new RegexLeaf("is");
}
public static IRegex isColored() {
return new RegexLeaf("is[%s]+colou?red");
}
public static IRegex isColoredForCompletion() {
return new RegexLeaf("is[%s]+colou?red[%s]+for[%s]+completion");
}
public static IRegex isOff() {
return new RegexConcat(new RegexLeaf("is"), //
RegexLeaf.spaceOneOrMore(), //
new RegexLeaf("off"), //
RegexLeaf.spaceOneOrMore(), //
new RegexOr(//
new RegexLeaf("on"), //
new RegexLeaf("for"), //
new RegexLeaf("the"), //
new RegexLeaf("at") //
));
}
public static IRegex isOn() {
return new RegexConcat(new RegexLeaf("is"), //
RegexLeaf.spaceOneOrMore(), //
new RegexLeaf("on"), //
RegexLeaf.spaceOneOrMore(), //
new RegexOr(//
new RegexLeaf("on"), //
new RegexLeaf("for"), //
new RegexLeaf("the"), //
new RegexLeaf("at") //
) //
);
}
public static IRegex isOrAre() {
return new RegexLeaf("(is|are)");
}
public static IRegex isOrAreNamed() {
return new RegexLeaf("(is|are)[%s]+named");
}
public static IRegex lasts() {
return new RegexLeaf("(lasts|requires)");
}
public static IRegex linksTo() {
return new RegexLeaf("links to");
}
public static IRegex occurs() {
return new RegexLeaf("occurs?");
}
public static IRegex starts3() {
return new RegexLeaf("starts[%s]*(the[%s]*|on[%s]*|at[%s]*)*");
}
public static IRegex starts2() {
return new RegexLeaf("starts");
}
public static IRegex starts() {
return new RegexConcat(new RegexLeaf("start"), //
new RegexOptional(new RegexLeaf("s")), //
RegexLeaf.spaceZeroOrMore(), //
new RegexOptional(new RegexOr(//
new RegexLeaf("on"), //
new RegexLeaf("for"), //
new RegexLeaf("the"), //
new RegexLeaf("at") //
)) //
);
}
public static IRegex just() {
return new RegexLeaf("just");
}
public static IRegex justBefore() {
return new RegexLeaf("just[%s]*before");
}
public static IRegex justAfter() {
return new RegexLeaf("just[%s]*after");
}
}