mirror of
https://github.com/octoleo/plantuml.git
synced 2025-01-03 07:12:29 +00:00
feat: improve gantt language
This commit is contained in:
parent
bcb3b92dbc
commit
f0b3e6900c
@ -86,7 +86,7 @@ import net.sourceforge.plantuml.project.core.TaskInstant;
|
|||||||
import net.sourceforge.plantuml.project.core.TaskSeparator;
|
import net.sourceforge.plantuml.project.core.TaskSeparator;
|
||||||
import net.sourceforge.plantuml.project.draw.FingerPrint;
|
import net.sourceforge.plantuml.project.draw.FingerPrint;
|
||||||
import net.sourceforge.plantuml.project.draw.ResourceDraw;
|
import net.sourceforge.plantuml.project.draw.ResourceDraw;
|
||||||
import net.sourceforge.plantuml.project.draw.ResourceDrawVersion2;
|
import net.sourceforge.plantuml.project.draw.ResourceDrawBasic;
|
||||||
import net.sourceforge.plantuml.project.draw.TaskDraw;
|
import net.sourceforge.plantuml.project.draw.TaskDraw;
|
||||||
import net.sourceforge.plantuml.project.draw.TaskDrawDiamond;
|
import net.sourceforge.plantuml.project.draw.TaskDrawDiamond;
|
||||||
import net.sourceforge.plantuml.project.draw.TaskDrawGroup;
|
import net.sourceforge.plantuml.project.draw.TaskDrawGroup;
|
||||||
@ -153,6 +153,9 @@ public class GanttDiagram extends TitledDiagram implements ToTaskDraw, WithSprit
|
|||||||
|
|
||||||
private int defaultCompletion = 100;
|
private int defaultCompletion = 100;
|
||||||
|
|
||||||
|
private Task it;
|
||||||
|
private Resource they;
|
||||||
|
|
||||||
public CommandExecutionResult changeLanguage(String lang) {
|
public CommandExecutionResult changeLanguage(String lang) {
|
||||||
this.locale = new Locale(lang);
|
this.locale = new Locale(lang);
|
||||||
return CommandExecutionResult.ok();
|
return CommandExecutionResult.ok();
|
||||||
@ -487,7 +490,8 @@ public class GanttDiagram extends TitledDiagram implements ToTaskDraw, WithSprit
|
|||||||
|
|
||||||
private ResourceDraw buildResourceDraw(GanttDiagram gantt, Resource res, TimeScale timeScale, double y, Day min,
|
private ResourceDraw buildResourceDraw(GanttDiagram gantt, Resource res, TimeScale timeScale, double y, Day min,
|
||||||
Day max) {
|
Day max) {
|
||||||
return new ResourceDrawVersion2(gantt, res, timeScale, y, min, max);
|
return new ResourceDrawBasic(gantt, res, timeScale, y, min, max);
|
||||||
|
// return new ResourceDrawVersion2(gantt, res, timeScale, y, min, max);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Collection<GanttConstraint> getConstraints(Task task) {
|
private Collection<GanttConstraint> getConstraints(Task task) {
|
||||||
@ -906,4 +910,20 @@ public class GanttDiagram extends TitledDiagram implements ToTaskDraw, WithSprit
|
|||||||
return Collections.unmodifiableList(result);
|
return Collections.unmodifiableList(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setIt(Task result) {
|
||||||
|
this.it = result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Task getIt() {
|
||||||
|
return it;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final Resource getThey() {
|
||||||
|
return they;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final void setThey(Resource they) {
|
||||||
|
this.they = they;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -52,7 +52,7 @@ import net.sourceforge.plantuml.project.core.Resource;
|
|||||||
import net.sourceforge.plantuml.project.time.Day;
|
import net.sourceforge.plantuml.project.time.Day;
|
||||||
import net.sourceforge.plantuml.project.timescale.TimeScale;
|
import net.sourceforge.plantuml.project.timescale.TimeScale;
|
||||||
|
|
||||||
public class ResourceDrawBasicImpl implements ResourceDraw {
|
public class ResourceDrawBasic implements ResourceDraw {
|
||||||
|
|
||||||
private final Resource res;
|
private final Resource res;
|
||||||
private final TimeScale timeScale;
|
private final TimeScale timeScale;
|
||||||
@ -61,7 +61,7 @@ public class ResourceDrawBasicImpl implements ResourceDraw {
|
|||||||
private final Day max;
|
private final Day max;
|
||||||
private final GanttDiagram gantt;
|
private final GanttDiagram gantt;
|
||||||
|
|
||||||
public ResourceDrawBasicImpl(GanttDiagram gantt, Resource res, TimeScale timeScale, double y, Day min, Day max) {
|
public ResourceDrawBasic(GanttDiagram gantt, Resource res, TimeScale timeScale, double y, Day min, Day max) {
|
||||||
this.res = res;
|
this.res = res;
|
||||||
this.timeScale = timeScale;
|
this.timeScale = timeScale;
|
||||||
this.y = y;
|
this.y = y;
|
44
src/net/sourceforge/plantuml/project/lang/Adverbial.java
Normal file
44
src/net/sourceforge/plantuml/project/lang/Adverbial.java
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* (C) Copyright 2009-2024, Arnaud Roques
|
||||||
|
*
|
||||||
|
* Project Info: https://plantuml.com
|
||||||
|
*
|
||||||
|
* If you like this project or if you find it useful, you can support us at:
|
||||||
|
*
|
||||||
|
* https://plantuml.com/patreon (only 1$ per month!)
|
||||||
|
* https://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.regex.IRegex;
|
||||||
|
|
||||||
|
public interface Adverbial {
|
||||||
|
|
||||||
|
public IRegex toRegex();
|
||||||
|
|
||||||
|
}
|
@ -58,8 +58,8 @@ public class ComplementDates implements Something {
|
|||||||
new RegexLeaf("BMONTH1" + suffix, "([\\d]{1,2})"), //
|
new RegexLeaf("BMONTH1" + suffix, "([\\d]{1,2})"), //
|
||||||
new RegexLeaf("\\D"), //
|
new RegexLeaf("\\D"), //
|
||||||
new RegexLeaf("BDAY1" + suffix, "([\\d]{1,2})"), //
|
new RegexLeaf("BDAY1" + suffix, "([\\d]{1,2})"), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
Words.exactly(Words.TO), //
|
||||||
new RegexLeaf("to"), //
|
Words.zeroOrMore(Words.THE), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
new RegexLeaf("BYEAR2" + suffix, "([\\d]{4})"), //
|
new RegexLeaf("BYEAR2" + suffix, "([\\d]{4})"), //
|
||||||
new RegexLeaf("\\D"), //
|
new RegexLeaf("\\D"), //
|
||||||
@ -73,8 +73,8 @@ public class ComplementDates implements Something {
|
|||||||
return new RegexConcat( //
|
return new RegexConcat( //
|
||||||
new RegexLeaf("[dD]\\+"), //
|
new RegexLeaf("[dD]\\+"), //
|
||||||
new RegexLeaf("ECOUNT1" + suffix, "([\\d]+)"), //
|
new RegexLeaf("ECOUNT1" + suffix, "([\\d]+)"), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
Words.exactly(Words.TO), //
|
||||||
new RegexLeaf("to"), //
|
Words.zeroOrMore(Words.THE), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
new RegexLeaf("[dD]\\+"), //
|
new RegexLeaf("[dD]\\+"), //
|
||||||
new RegexLeaf("ECOUNT2" + suffix, "([\\d]+)") //
|
new RegexLeaf("ECOUNT2" + suffix, "([\\d]+)") //
|
||||||
|
@ -0,0 +1,58 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* (C) Copyright 2009-2024, Arnaud Roques
|
||||||
|
*
|
||||||
|
* Project Info: https://plantuml.com
|
||||||
|
*
|
||||||
|
* If you like this project or if you find it useful, you can support us at:
|
||||||
|
*
|
||||||
|
* https://plantuml.com/patreon (only 1$ per month!)
|
||||||
|
* https://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.project.Failable;
|
||||||
|
import net.sourceforge.plantuml.project.GanttDiagram;
|
||||||
|
import net.sourceforge.plantuml.project.core.Task;
|
||||||
|
import net.sourceforge.plantuml.regex.IRegex;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexLeaf;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexResult;
|
||||||
|
|
||||||
|
public class ComplementTask implements Something {
|
||||||
|
|
||||||
|
public IRegex toRegex(String suffix) {
|
||||||
|
return new RegexLeaf("COMPLEMENT" + suffix, "\\[([^\\[\\]]+?)\\]");
|
||||||
|
}
|
||||||
|
|
||||||
|
public Failable<Task> getMe(GanttDiagram gantt, RegexResult arg, String suffix) {
|
||||||
|
final String code = arg.get("COMPLEMENT" + suffix, 0);
|
||||||
|
final Task task = gantt.getExistingTask(code);
|
||||||
|
if (task == null)
|
||||||
|
return Failable.error("No such task " + code);
|
||||||
|
return Failable.ok(task);
|
||||||
|
}
|
||||||
|
}
|
@ -38,10 +38,15 @@ package net.sourceforge.plantuml.project.lang;
|
|||||||
import net.sourceforge.plantuml.command.CommandExecutionResult;
|
import net.sourceforge.plantuml.command.CommandExecutionResult;
|
||||||
import net.sourceforge.plantuml.project.GanttDiagram;
|
import net.sourceforge.plantuml.project.GanttDiagram;
|
||||||
import net.sourceforge.plantuml.regex.IRegex;
|
import net.sourceforge.plantuml.regex.IRegex;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexLeaf;
|
||||||
import net.sourceforge.plantuml.regex.RegexResult;
|
import net.sourceforge.plantuml.regex.RegexResult;
|
||||||
|
|
||||||
public interface Sentence {
|
public interface Sentence {
|
||||||
|
|
||||||
|
public final RegexLeaf OPTIONAL_FINAL_DOT = new RegexLeaf("\\s*[.]?\\s*$");
|
||||||
|
|
||||||
|
public final RegexLeaf SENTENCE_SEPARATOR = new RegexLeaf("\\s*(,|\\sand\\s)\\s*");
|
||||||
|
|
||||||
public IRegex toRegex();
|
public IRegex toRegex();
|
||||||
|
|
||||||
public CommandExecutionResult execute(GanttDiagram project, RegexResult arg);
|
public CommandExecutionResult execute(GanttDiagram project, RegexResult arg);
|
||||||
|
@ -56,37 +56,37 @@ public class SentenceAnd implements Sentence {
|
|||||||
public IRegex toRegex() {
|
public IRegex toRegex() {
|
||||||
return new RegexConcat(//
|
return new RegexConcat(//
|
||||||
RegexLeaf.start(), //
|
RegexLeaf.start(), //
|
||||||
sentence1.subjectii.toRegex(), //
|
sentence1.getSubject().toRegex(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence1.getVerbRegex(), //
|
sentence1.getVerbRegex(), //
|
||||||
|
sentence1.getAdverbialOrPropositon(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence1.complementii.toRegex("1"), //
|
sentence1.getComplement().toRegex("1"), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
SENTENCE_SEPARATOR, //
|
||||||
new RegexLeaf("and"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
sentence2.getVerbRegex(), //
|
sentence2.getVerbRegex(), //
|
||||||
|
sentence2.getAdverbialOrPropositon(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence2.complementii.toRegex("2"), //
|
sentence2.getComplement().toRegex("2"), //
|
||||||
RegexLeaf.end());
|
OPTIONAL_FINAL_DOT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final CommandExecutionResult execute(GanttDiagram project, RegexResult arg) {
|
public final CommandExecutionResult execute(GanttDiagram project, RegexResult arg) {
|
||||||
final Failable<? extends Object> subject = sentence1.subjectii.getMe(project, arg);
|
final Failable<? extends Object> subject = sentence1.getSubject().getMe(project, arg);
|
||||||
if (subject.isFail()) {
|
if (subject.isFail())
|
||||||
return CommandExecutionResult.error(subject.getError());
|
return CommandExecutionResult.error(subject.getError());
|
||||||
}
|
|
||||||
final Failable<? extends Object> complement1 = sentence1.complementii.getMe(project, arg, "1");
|
final Failable<? extends Object> complement1 = sentence1.getComplement().getMe(project, arg, "1");
|
||||||
if (complement1.isFail()) {
|
if (complement1.isFail())
|
||||||
return CommandExecutionResult.error(complement1.getError());
|
return CommandExecutionResult.error(complement1.getError());
|
||||||
}
|
|
||||||
final CommandExecutionResult result1 = sentence1.execute(project, subject.get(), complement1.get());
|
final CommandExecutionResult result1 = sentence1.execute(project, subject.get(), complement1.get());
|
||||||
if (result1.isOk() == false) {
|
if (result1.isOk() == false)
|
||||||
return result1;
|
return result1;
|
||||||
}
|
|
||||||
final Failable<? extends Object> complement2 = sentence2.complementii.getMe(project, arg, "2");
|
final Failable<? extends Object> complement2 = sentence2.getComplement().getMe(project, arg, "2");
|
||||||
if (complement2.isFail()) {
|
if (complement2.isFail())
|
||||||
return CommandExecutionResult.error(complement2.getError());
|
return CommandExecutionResult.error(complement2.getError());
|
||||||
}
|
|
||||||
return sentence2.execute(project, subject.get(), complement2.get());
|
return sentence2.execute(project, subject.get(), complement2.get());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -58,51 +58,50 @@ public class SentenceAndAnd implements Sentence {
|
|||||||
public IRegex toRegex() {
|
public IRegex toRegex() {
|
||||||
return new RegexConcat(//
|
return new RegexConcat(//
|
||||||
RegexLeaf.start(), //
|
RegexLeaf.start(), //
|
||||||
sentence1.subjectii.toRegex(), //
|
sentence1.getSubject().toRegex(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence1.getVerbRegex(), //
|
sentence1.getVerbRegex(), //
|
||||||
|
sentence1.getAdverbialOrPropositon(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence1.complementii.toRegex("1"), //
|
sentence1.getComplement().toRegex("1"), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
SENTENCE_SEPARATOR, //
|
||||||
new RegexLeaf("and"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
sentence2.getVerbRegex(), //
|
sentence2.getVerbRegex(), //
|
||||||
|
sentence2.getAdverbialOrPropositon(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence2.complementii.toRegex("2"), //
|
sentence2.getComplement().toRegex("2"), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
SENTENCE_SEPARATOR, //
|
||||||
new RegexLeaf("and"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
sentence3.getVerbRegex(), //
|
sentence3.getVerbRegex(), //
|
||||||
|
sentence3.getAdverbialOrPropositon(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
sentence3.complementii.toRegex("3"), //
|
sentence3.getComplement().toRegex("3"), //
|
||||||
RegexLeaf.end());
|
OPTIONAL_FINAL_DOT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final CommandExecutionResult execute(GanttDiagram project, RegexResult arg) {
|
public final CommandExecutionResult execute(GanttDiagram project, RegexResult arg) {
|
||||||
final Failable<? extends Object> subject = sentence1.subjectii.getMe(project, arg);
|
final Failable<? extends Object> subject = sentence1.getSubject().getMe(project, arg);
|
||||||
if (subject.isFail()) {
|
if (subject.isFail())
|
||||||
return CommandExecutionResult.error(subject.getError());
|
return CommandExecutionResult.error(subject.getError());
|
||||||
}
|
|
||||||
final Failable<? extends Object> complement1 = sentence1.complementii.getMe(project, arg, "1");
|
final Failable<? extends Object> complement1 = sentence1.getComplement().getMe(project, arg, "1");
|
||||||
if (complement1.isFail()) {
|
if (complement1.isFail())
|
||||||
return CommandExecutionResult.error(complement1.getError());
|
return CommandExecutionResult.error(complement1.getError());
|
||||||
}
|
|
||||||
final CommandExecutionResult result1 = sentence1.execute(project, subject.get(), complement1.get());
|
final CommandExecutionResult result1 = sentence1.execute(project, subject.get(), complement1.get());
|
||||||
if (result1.isOk() == false) {
|
if (result1.isOk() == false)
|
||||||
return result1;
|
return result1;
|
||||||
}
|
|
||||||
final Failable<? extends Object> complement2 = sentence2.complementii.getMe(project, arg, "2");
|
final Failable<? extends Object> complement2 = sentence2.getComplement().getMe(project, arg, "2");
|
||||||
if (complement2.isFail()) {
|
if (complement2.isFail())
|
||||||
return CommandExecutionResult.error(complement2.getError());
|
return CommandExecutionResult.error(complement2.getError());
|
||||||
}
|
|
||||||
final CommandExecutionResult result2 = sentence2.execute(project, subject.get(), complement2.get());
|
final CommandExecutionResult result2 = sentence2.execute(project, subject.get(), complement2.get());
|
||||||
if (result2.isOk() == false) {
|
if (result2.isOk() == false)
|
||||||
return result2;
|
return result2;
|
||||||
}
|
|
||||||
final Failable<? extends Object> complement3 = sentence3.complementii.getMe(project, arg, "3");
|
final Failable<? extends Object> complement3 = sentence3.getComplement().getMe(project, arg, "3");
|
||||||
if (complement3.isFail()) {
|
if (complement3.isFail())
|
||||||
return CommandExecutionResult.error(complement3.getError());
|
return CommandExecutionResult.error(complement3.getError());
|
||||||
}
|
|
||||||
final CommandExecutionResult result3 = sentence3.execute(project, subject.get(), complement3.get());
|
final CommandExecutionResult result3 = sentence3.execute(project, subject.get(), complement3.get());
|
||||||
return result3;
|
return result3;
|
||||||
|
|
||||||
|
@ -44,7 +44,8 @@ import net.sourceforge.plantuml.project.core.TaskInstant;
|
|||||||
public class SentenceHappens extends SentenceSimple {
|
public class SentenceHappens extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceHappens() {
|
public SentenceHappens() {
|
||||||
super(SubjectTask.ME, Verbs.happens, new ComplementBeforeOrAfterOrAtTaskStartOrEnd());
|
super(SubjectTask.ME, Verbs.happens, Words.zeroOrMore(Words.THE, Words.ON, Words.AT),
|
||||||
|
new ComplementBeforeOrAfterOrAtTaskStartOrEnd());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -44,7 +44,7 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentenceHappensDate extends SentenceSimple {
|
public class SentenceHappensDate extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceHappensDate() {
|
public SentenceHappensDate() {
|
||||||
super(SubjectTask.ME, Verbs.happens, ComplementDate.any());
|
super(SubjectTask.ME, Verbs.happens, Words.zeroOrMore(Words.THE, Words.ON, Words.AT), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -42,7 +42,8 @@ import net.sourceforge.plantuml.project.core.Task;
|
|||||||
public class SentenceIsColoredForCompletion extends SentenceSimple {
|
public class SentenceIsColoredForCompletion extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceIsColoredForCompletion() {
|
public SentenceIsColoredForCompletion() {
|
||||||
super(SubjectTask.ME, Verbs.isColoredForCompletion, new ComplementInColorsFromTo());
|
super(SubjectTask.ME, Verbs.isColored, Words.exactly(Words.FOR, Words.COMPLETION),
|
||||||
|
new ComplementInColorsFromTo());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -43,7 +43,8 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentencePausesDate extends SentenceSimple {
|
public class SentencePausesDate extends SentenceSimple {
|
||||||
|
|
||||||
public SentencePausesDate() {
|
public SentencePausesDate() {
|
||||||
super(SubjectTask.ME, Verbs.pauses, ComplementDate.any());
|
super(SubjectTask.ME, Verbs.pauses, Words.zeroOrMore(Words.THE, Words.ON, Words.AT, Words.FROM),
|
||||||
|
ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -44,20 +44,17 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentencePausesDates extends SentenceSimple {
|
public class SentencePausesDates extends SentenceSimple {
|
||||||
|
|
||||||
public SentencePausesDates() {
|
public SentencePausesDates() {
|
||||||
super(SubjectTask.ME, Verbs.pauses, new ComplementDates());
|
super(SubjectTask.ME, Verbs.pauses, Words.zeroOrMore(Words.THE, Words.ON, Words.AT, Words.FROM),
|
||||||
|
new ComplementDates());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
||||||
final Task task = (Task) subject;
|
final Task task = (Task) subject;
|
||||||
final DaysAsDates pauses = (DaysAsDates) complement;
|
final DaysAsDates pauses = (DaysAsDates) complement;
|
||||||
// final Day startingDate = project.getStartingDate();
|
for (Day day : pauses)
|
||||||
// if (startingDate == null) {
|
|
||||||
// return CommandExecutionResult.error("No starting date for the project");
|
|
||||||
// }
|
|
||||||
for (Day day : pauses) {
|
|
||||||
task.addPause(day);
|
task.addPause(day);
|
||||||
}
|
|
||||||
return CommandExecutionResult.ok();
|
return CommandExecutionResult.ok();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +43,8 @@ import net.sourceforge.plantuml.project.time.DayOfWeek;
|
|||||||
public class SentencePausesDayOfWeek extends SentenceSimple {
|
public class SentencePausesDayOfWeek extends SentenceSimple {
|
||||||
|
|
||||||
public SentencePausesDayOfWeek() {
|
public SentencePausesDayOfWeek() {
|
||||||
super(SubjectTask.ME, Verbs.pauses, new ComplementDayOfWeek());
|
super(SubjectTask.ME, Verbs.pauses, Words.zeroOrMore(Words.THE, Words.ON, Words.AT, Words.FROM),
|
||||||
|
new ComplementDayOfWeek());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -45,49 +45,57 @@ import net.sourceforge.plantuml.regex.RegexResult;
|
|||||||
|
|
||||||
public abstract class SentenceSimple implements Sentence {
|
public abstract class SentenceSimple implements Sentence {
|
||||||
|
|
||||||
protected final Subject subjectii;
|
private final Subject subject;
|
||||||
private final IRegex verb;
|
private final IRegex verb;
|
||||||
protected final Something complementii;
|
private final IRegex adverbialOrPropositon;
|
||||||
|
private final Something complement;
|
||||||
|
|
||||||
public SentenceSimple(Subject subject, IRegex verb, Something complement) {
|
public SentenceSimple(Subject subject, IRegex verb, Something complement) {
|
||||||
this.subjectii = subject;
|
this(subject, verb, new RegexLeaf(""), complement);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SentenceSimple(Subject subject, IRegex verb, IRegex adverbialOrPropositon, Something complement) {
|
||||||
|
this.subject = subject;
|
||||||
this.verb = verb;
|
this.verb = verb;
|
||||||
this.complementii = complement;
|
this.adverbialOrPropositon = adverbialOrPropositon;
|
||||||
|
this.complement = complement;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSignature() {
|
public String getSignature() {
|
||||||
return subjectii.getClass() + "/" + verb.getPattern() + "/" + complementii.getClass();
|
return subject.getClass() + "/" + verb.getPattern() + "/" + complement.getClass();
|
||||||
}
|
}
|
||||||
|
|
||||||
public final IRegex toRegex() {
|
public final IRegex toRegex() {
|
||||||
if (complementii instanceof ComplementEmpty)
|
if (complement instanceof ComplementEmpty)
|
||||||
return new RegexConcat(//
|
return new RegexConcat(//
|
||||||
RegexLeaf.start(), //
|
RegexLeaf.start(), //
|
||||||
subjectii.toRegex(), //
|
subject.toRegex(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
verb, //
|
verb, //
|
||||||
RegexLeaf.end());
|
adverbialOrPropositon, //
|
||||||
|
OPTIONAL_FINAL_DOT);
|
||||||
|
|
||||||
return new RegexConcat(//
|
return new RegexConcat(//
|
||||||
RegexLeaf.start(), //
|
RegexLeaf.start(), //
|
||||||
subjectii.toRegex(), //
|
subject.toRegex(), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
verb, //
|
verb, //
|
||||||
|
adverbialOrPropositon, //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
complementii.toRegex("0"), //
|
complement.toRegex("0"), //
|
||||||
RegexLeaf.end());
|
OPTIONAL_FINAL_DOT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final CommandExecutionResult execute(GanttDiagram project, RegexResult arg) {
|
public final CommandExecutionResult execute(GanttDiagram project, RegexResult arg) {
|
||||||
final Failable<? extends Object> subject = subjectii.getMe(project, arg);
|
final Failable<? extends Object> currentSubject = subject.getMe(project, arg);
|
||||||
if (subject.isFail())
|
if (currentSubject.isFail())
|
||||||
return CommandExecutionResult.error(subject.getError());
|
return CommandExecutionResult.error(currentSubject.getError());
|
||||||
|
|
||||||
final Failable<? extends Object> complement = complementii.getMe(project, arg, "0");
|
final Failable<? extends Object> currentComplement = complement.getMe(project, arg, "0");
|
||||||
if (complement.isFail())
|
if (currentComplement.isFail())
|
||||||
return CommandExecutionResult.error(complement.getError());
|
return CommandExecutionResult.error(currentComplement.getError());
|
||||||
|
|
||||||
return execute(project, subject.get(), complement.get());
|
return execute(project, currentSubject.get(), currentComplement.get());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,4 +105,18 @@ public abstract class SentenceSimple implements Sentence {
|
|||||||
return verb;
|
return verb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected final IRegex getAdverbialOrPropositon() {
|
||||||
|
return adverbialOrPropositon;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final Subject getSubject() {
|
||||||
|
return subject;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final Something getComplement() {
|
||||||
|
return complement;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -43,9 +43,10 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentenceTaskEndsAbsolute extends SentenceSimple {
|
public class SentenceTaskEndsAbsolute extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceTaskEndsAbsolute() {
|
public SentenceTaskEndsAbsolute() {
|
||||||
super(SubjectTask.ME, Verbs.ends2, ComplementDate.any());
|
super(SubjectTask.ME, Verbs.ends, Words.zeroOrMore(Words.THE, Words.ON, Words.AT), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
||||||
final Task task = (Task) subject;
|
final Task task = (Task) subject;
|
||||||
|
@ -43,7 +43,8 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentenceTaskEndsOnlyRelative extends SentenceSimple {
|
public class SentenceTaskEndsOnlyRelative extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceTaskEndsOnlyRelative() {
|
public SentenceTaskEndsOnlyRelative() {
|
||||||
super(SubjectTask.ME, Verbs.ends2, ComplementDate.onlyRelative());
|
super(SubjectTask.ME, Verbs.ends, Words.zeroOrMore(Words.THE, Words.ON, Words.AT),
|
||||||
|
ComplementDate.onlyRelative());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -46,7 +46,7 @@ import net.sourceforge.plantuml.project.core.TaskInstant;
|
|||||||
public class SentenceTaskStarts extends SentenceSimple {
|
public class SentenceTaskStarts extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceTaskStarts() {
|
public SentenceTaskStarts() {
|
||||||
super(SubjectTask.ME, Verbs.starts2, new ComplementBeforeOrAfterOrAtTaskStartOrEnd());
|
super(SubjectTask.ME, Verbs.starts, new ComplementBeforeOrAfterOrAtTaskStartOrEnd());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -43,7 +43,7 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentenceTaskStartsAbsolute extends SentenceSimple {
|
public class SentenceTaskStartsAbsolute extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceTaskStartsAbsolute() {
|
public SentenceTaskStartsAbsolute() {
|
||||||
super(SubjectTask.ME, Verbs.starts3, ComplementDate.any());
|
super(SubjectTask.ME, Verbs.starts, Words.zeroOrMore(Words.THE, Words.ON, Words.AT), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -43,7 +43,8 @@ import net.sourceforge.plantuml.project.time.Day;
|
|||||||
public class SentenceTaskStartsOnlyRelative extends SentenceSimple {
|
public class SentenceTaskStartsOnlyRelative extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceTaskStartsOnlyRelative() {
|
public SentenceTaskStartsOnlyRelative() {
|
||||||
super(SubjectTask.ME, Verbs.starts3, ComplementDate.onlyRelative());
|
super(SubjectTask.ME, Verbs.starts, Words.zeroOrMore(Words.THE, Words.ON, Words.AT),
|
||||||
|
ComplementDate.onlyRelative());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -46,7 +46,7 @@ import net.sourceforge.plantuml.project.core.TaskInstant;
|
|||||||
public class SentenceTaskStartsWithColor extends SentenceSimple {
|
public class SentenceTaskStartsWithColor extends SentenceSimple {
|
||||||
|
|
||||||
public SentenceTaskStartsWithColor() {
|
public SentenceTaskStartsWithColor() {
|
||||||
super(SubjectTask.ME, Verbs.starts2,
|
super(SubjectTask.ME, Verbs.starts,
|
||||||
new PairOfSomething(new ComplementBeforeOrAfterOrAtTaskStartOrEnd(), new ComplementWithColorLink()));
|
new PairOfSomething(new ComplementBeforeOrAfterOrAtTaskStartOrEnd(), new ComplementWithColorLink()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,7 +68,8 @@ public class SubjectProject implements Subject {
|
|||||||
class Starts extends SentenceSimple {
|
class Starts extends SentenceSimple {
|
||||||
|
|
||||||
public Starts() {
|
public Starts() {
|
||||||
super(SubjectProject.this, Verbs.starts, ComplementDate.onlyAbsolute());
|
super(SubjectProject.this, Verbs.starts, Words.zeroOrMore(Words.ON, Words.FOR, Words.THE, Words.AT),
|
||||||
|
ComplementDate.onlyAbsolute());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -43,11 +43,12 @@ import net.sourceforge.plantuml.project.DaysAsDates;
|
|||||||
import net.sourceforge.plantuml.project.Failable;
|
import net.sourceforge.plantuml.project.Failable;
|
||||||
import net.sourceforge.plantuml.project.GanttDiagram;
|
import net.sourceforge.plantuml.project.GanttDiagram;
|
||||||
import net.sourceforge.plantuml.project.core.Resource;
|
import net.sourceforge.plantuml.project.core.Resource;
|
||||||
|
import net.sourceforge.plantuml.project.core.Task;
|
||||||
import net.sourceforge.plantuml.project.time.Day;
|
import net.sourceforge.plantuml.project.time.Day;
|
||||||
import net.sourceforge.plantuml.project.time.DayOfWeek;
|
import net.sourceforge.plantuml.project.time.DayOfWeek;
|
||||||
import net.sourceforge.plantuml.regex.IRegex;
|
import net.sourceforge.plantuml.regex.IRegex;
|
||||||
import net.sourceforge.plantuml.regex.RegexConcat;
|
|
||||||
import net.sourceforge.plantuml.regex.RegexLeaf;
|
import net.sourceforge.plantuml.regex.RegexLeaf;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexOr;
|
||||||
import net.sourceforge.plantuml.regex.RegexResult;
|
import net.sourceforge.plantuml.regex.RegexResult;
|
||||||
|
|
||||||
public class SubjectResource implements Subject {
|
public class SubjectResource implements Subject {
|
||||||
@ -57,30 +58,56 @@ public class SubjectResource implements Subject {
|
|||||||
private SubjectResource() {
|
private SubjectResource() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Failable<Resource> getMe(GanttDiagram project, RegexResult arg) {
|
public Failable<Resource> getMe(GanttDiagram gantt, RegexResult arg) {
|
||||||
final String s = arg.get("RESOURCE", 0);
|
if (arg.get("THEY", 0) != null) {
|
||||||
return Failable.ok(project.getResource(s));
|
final Resource they = gantt.getThey();
|
||||||
|
if (they == null)
|
||||||
|
return Failable.error("Not sure who are you refering to?");
|
||||||
|
return Failable.ok(they);
|
||||||
|
}
|
||||||
|
final String resource = arg.get("RESOURCE", 0);
|
||||||
|
final Resource result = gantt.getResource(resource);
|
||||||
|
gantt.setThey(result);
|
||||||
|
return Failable.ok(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Collection<? extends SentenceSimple> getSentences() {
|
public Collection<? extends SentenceSimple> getSentences() {
|
||||||
return Arrays.asList(new IsOffDate(), new IsOffDates(), new IsOffDayOfWeek(), new IsOnDate(), new IsOnDates(),
|
return Arrays.asList(new IsOffDate(), new IsOffDates(), new IsOffDayOfWeek(), new IsOnDate(), new IsOnDates(),
|
||||||
new IsOffBeforeDate(), new IsOffAfterDate());
|
new IsOffBeforeDate(), new IsOffAfterDate(), new WorksOn());
|
||||||
}
|
}
|
||||||
|
|
||||||
public IRegex toRegex() {
|
public IRegex toRegex() {
|
||||||
return new RegexConcat( //
|
return new RegexOr( //
|
||||||
|
new RegexLeaf("THEY", "(she|he|they)"), //
|
||||||
new RegexLeaf("RESOURCE", "\\{([^{}]+)\\}") //
|
new RegexLeaf("RESOURCE", "\\{([^{}]+)\\}") //
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class WorksOn extends SentenceSimple {
|
||||||
|
|
||||||
|
public WorksOn() {
|
||||||
|
super(SubjectResource.this, Verbs.worksOn, new ComplementTask());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
|
final Resource resource = (Resource) subject;
|
||||||
|
final Task task = (Task) complement;
|
||||||
|
task.addResource(resource, 100);
|
||||||
|
return CommandExecutionResult.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public class IsOffBeforeDate extends SentenceSimple {
|
public class IsOffBeforeDate extends SentenceSimple {
|
||||||
|
|
||||||
public IsOffBeforeDate() {
|
public IsOffBeforeDate() {
|
||||||
super(SubjectResource.this, Verbs.isOffBefore, ComplementDate.any());
|
super(SubjectResource.this, Verbs.isOff,
|
||||||
|
Words.concat(Words.exactly(Words.BEFORE), Words.zeroOrMore(Words.THE)), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
final Day when = (Day) complement;
|
final Day when = (Day) complement;
|
||||||
resource.setOffBeforeDate(when);
|
resource.setOffBeforeDate(when);
|
||||||
@ -92,11 +119,12 @@ public class SubjectResource implements Subject {
|
|||||||
public class IsOffAfterDate extends SentenceSimple {
|
public class IsOffAfterDate extends SentenceSimple {
|
||||||
|
|
||||||
public IsOffAfterDate() {
|
public IsOffAfterDate() {
|
||||||
super(SubjectResource.this, Verbs.isOffAfter, ComplementDate.any());
|
super(SubjectResource.this, Verbs.isOff,
|
||||||
|
Words.concat(Words.exactly(Words.AFTER), Words.zeroOrMore(Words.THE)), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
final Day when = (Day) complement;
|
final Day when = (Day) complement;
|
||||||
resource.setOffAfterDate(when);
|
resource.setOffAfterDate(when);
|
||||||
@ -108,11 +136,12 @@ public class SubjectResource implements Subject {
|
|||||||
public class IsOffDate extends SentenceSimple {
|
public class IsOffDate extends SentenceSimple {
|
||||||
|
|
||||||
public IsOffDate() {
|
public IsOffDate() {
|
||||||
super(SubjectResource.this, Verbs.isOff, ComplementDate.any());
|
super(SubjectResource.this, Verbs.isOff,
|
||||||
|
Words.zeroOrMore(Words.FROM, Words.ON, Words.FOR, Words.THE, Words.AT), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
final Day when = (Day) complement;
|
final Day when = (Day) complement;
|
||||||
resource.addCloseDay(when);
|
resource.addCloseDay(when);
|
||||||
@ -124,11 +153,12 @@ public class SubjectResource implements Subject {
|
|||||||
public class IsOffDates extends SentenceSimple {
|
public class IsOffDates extends SentenceSimple {
|
||||||
|
|
||||||
public IsOffDates() {
|
public IsOffDates() {
|
||||||
super(SubjectResource.this, Verbs.isOff, new ComplementDates());
|
super(SubjectResource.this, Verbs.isOff,
|
||||||
|
Words.zeroOrMore(Words.FROM, Words.ON, Words.FOR, Words.THE, Words.AT), new ComplementDates());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
for (Day when : (DaysAsDates) complement) {
|
for (Day when : (DaysAsDates) complement) {
|
||||||
resource.addCloseDay(when);
|
resource.addCloseDay(when);
|
||||||
@ -141,11 +171,12 @@ public class SubjectResource implements Subject {
|
|||||||
public class IsOffDayOfWeek extends SentenceSimple {
|
public class IsOffDayOfWeek extends SentenceSimple {
|
||||||
|
|
||||||
public IsOffDayOfWeek() {
|
public IsOffDayOfWeek() {
|
||||||
super(SubjectResource.this, Verbs.isOff, new ComplementDayOfWeek());
|
super(SubjectResource.this, Verbs.isOff,
|
||||||
|
Words.zeroOrMore(Words.FROM, Words.ON, Words.FOR, Words.THE, Words.AT), new ComplementDayOfWeek());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
resource.addCloseDay(((DayOfWeek) complement));
|
resource.addCloseDay(((DayOfWeek) complement));
|
||||||
return CommandExecutionResult.ok();
|
return CommandExecutionResult.ok();
|
||||||
@ -156,11 +187,12 @@ public class SubjectResource implements Subject {
|
|||||||
public class IsOnDate extends SentenceSimple {
|
public class IsOnDate extends SentenceSimple {
|
||||||
|
|
||||||
public IsOnDate() {
|
public IsOnDate() {
|
||||||
super(SubjectResource.this, Verbs.isOn, ComplementDate.any());
|
super(SubjectResource.this, Verbs.isOn,
|
||||||
|
Words.zeroOrMore(Words.FROM, Words.ON, Words.FOR, Words.THE, Words.AT), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
final Day when = (Day) complement;
|
final Day when = (Day) complement;
|
||||||
resource.addForceOnDay(when);
|
resource.addForceOnDay(when);
|
||||||
@ -172,11 +204,12 @@ public class SubjectResource implements Subject {
|
|||||||
public class IsOnDates extends SentenceSimple {
|
public class IsOnDates extends SentenceSimple {
|
||||||
|
|
||||||
public IsOnDates() {
|
public IsOnDates() {
|
||||||
super(SubjectResource.this, Verbs.isOn, new ComplementDates());
|
super(SubjectResource.this, Verbs.isOn,
|
||||||
|
Words.zeroOrMore(Words.FROM, Words.ON, Words.FOR, Words.THE, Words.AT), new ComplementDates());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommandExecutionResult execute(GanttDiagram project, Object subject, Object complement) {
|
public CommandExecutionResult execute(GanttDiagram gantt, Object subject, Object complement) {
|
||||||
final Resource resource = (Resource) subject;
|
final Resource resource = (Resource) subject;
|
||||||
for (Day when : (DaysAsDates) complement) {
|
for (Day when : (DaysAsDates) complement) {
|
||||||
resource.addForceOnDay(when);
|
resource.addForceOnDay(when);
|
||||||
|
@ -69,7 +69,7 @@ public class SubjectSeparator implements Subject {
|
|||||||
class JustBefore extends SentenceSimple {
|
class JustBefore extends SentenceSimple {
|
||||||
|
|
||||||
public JustBefore() {
|
public JustBefore() {
|
||||||
super(SubjectSeparator.this, Verbs.justBefore, ComplementDate.any());
|
super(SubjectSeparator.this, Verbs.just, Words.exactly(Words.BEFORE), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -85,7 +85,7 @@ public class SubjectSeparator implements Subject {
|
|||||||
class JustAfter extends SentenceSimple {
|
class JustAfter extends SentenceSimple {
|
||||||
|
|
||||||
public JustAfter() {
|
public JustAfter() {
|
||||||
super(SubjectSeparator.this, Verbs.justAfter, ComplementDate.any());
|
super(SubjectSeparator.this, Verbs.just, Words.exactly(Words.AFTER), ComplementDate.any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -46,6 +46,7 @@ import net.sourceforge.plantuml.regex.IRegex;
|
|||||||
import net.sourceforge.plantuml.regex.RegexConcat;
|
import net.sourceforge.plantuml.regex.RegexConcat;
|
||||||
import net.sourceforge.plantuml.regex.RegexLeaf;
|
import net.sourceforge.plantuml.regex.RegexLeaf;
|
||||||
import net.sourceforge.plantuml.regex.RegexOptional;
|
import net.sourceforge.plantuml.regex.RegexOptional;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexOr;
|
||||||
import net.sourceforge.plantuml.regex.RegexResult;
|
import net.sourceforge.plantuml.regex.RegexResult;
|
||||||
|
|
||||||
public class SubjectTask implements Subject {
|
public class SubjectTask implements Subject {
|
||||||
@ -55,23 +56,32 @@ public class SubjectTask implements Subject {
|
|||||||
private SubjectTask() {
|
private SubjectTask() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Failable<Task> getMe(GanttDiagram project, RegexResult arg) {
|
public Failable<Task> getMe(GanttDiagram gantt, RegexResult arg) {
|
||||||
final String s = arg.get("SUBJECT", 0);
|
final Task result;
|
||||||
|
if (arg.get("IT", 0) != null) {
|
||||||
|
result = gantt.getIt();
|
||||||
|
if (result == null)
|
||||||
|
return Failable.error("Not sure what are you refering to?");
|
||||||
|
} else {
|
||||||
|
final String subject = arg.get("SUBJECT", 0);
|
||||||
final String shortName = arg.get("SUBJECT", 1);
|
final String shortName = arg.get("SUBJECT", 1);
|
||||||
final String then = arg.get("THEN", 0);
|
final String then = arg.get("THEN", 0);
|
||||||
final String resource = arg.get("RESOURCE", 0);
|
result = gantt.getOrCreateTask(subject, shortName, then != null);
|
||||||
final Task result = project.getOrCreateTask(s, shortName, then != null);
|
gantt.setIt(result);
|
||||||
if (result == null) {
|
|
||||||
throw new IllegalStateException();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (result == null)
|
||||||
|
throw new IllegalStateException();
|
||||||
|
|
||||||
|
final String resource = arg.get("RESOURCE", 0);
|
||||||
if (resource != null) {
|
if (resource != null) {
|
||||||
for (final StringTokenizer st = new StringTokenizer(resource, "{}"); st.hasMoreTokens();) {
|
for (final StringTokenizer st = new StringTokenizer(resource, "{}"); st.hasMoreTokens();) {
|
||||||
final String part = st.nextToken().trim();
|
final String part = st.nextToken().trim();
|
||||||
if (part.length() > 0) {
|
if (part.length() > 0) {
|
||||||
final boolean ok = project.affectResource(result, part);
|
final boolean ok = gantt.affectResource(result, part);
|
||||||
if (ok == false) {
|
if (ok == false)
|
||||||
return Failable.error("Bad argument for resource");
|
return Failable.error("Bad argument for resource");
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,8 +100,9 @@ public class SubjectTask implements Subject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public IRegex toRegex() {
|
public IRegex toRegex() {
|
||||||
return new RegexConcat( //
|
return new RegexOr( //
|
||||||
new RegexLeaf("THEN", "(then[%s]+)?"), //
|
new RegexLeaf("IT", "(it)"), //
|
||||||
|
new RegexConcat(new RegexLeaf("THEN", "(then[%s]+)?"), //
|
||||||
new RegexLeaf("SUBJECT", "\\[([^\\[\\]]+?)\\](?:[%s]+as[%s]+\\[([^\\[\\]]+?)\\])?"), //
|
new RegexLeaf("SUBJECT", "\\[([^\\[\\]]+?)\\](?:[%s]+as[%s]+\\[([^\\[\\]]+?)\\])?"), //
|
||||||
new RegexOptional( //
|
new RegexOptional( //
|
||||||
new RegexConcat( //
|
new RegexConcat( //
|
||||||
@ -99,8 +110,7 @@ public class SubjectTask implements Subject {
|
|||||||
new RegexLeaf("on"), //
|
new RegexLeaf("on"), //
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
RegexLeaf.spaceOneOrMore(), //
|
||||||
new RegexLeaf("RESOURCE", "((?:\\{[^{}]+\\}[%s]*)+)") //
|
new RegexLeaf("RESOURCE", "((?:\\{[^{}]+\\}[%s]*)+)") //
|
||||||
)) //
|
))));
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -36,103 +36,28 @@
|
|||||||
package net.sourceforge.plantuml.project.lang;
|
package net.sourceforge.plantuml.project.lang;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.regex.IRegex;
|
import net.sourceforge.plantuml.regex.IRegex;
|
||||||
import net.sourceforge.plantuml.regex.RegexConcat;
|
|
||||||
import net.sourceforge.plantuml.regex.RegexLeaf;
|
import net.sourceforge.plantuml.regex.RegexLeaf;
|
||||||
import net.sourceforge.plantuml.regex.RegexOptional;
|
|
||||||
import net.sourceforge.plantuml.regex.RegexOr;
|
|
||||||
|
|
||||||
public class Verbs {
|
public class Verbs {
|
||||||
|
|
||||||
public static IRegex are = new RegexLeaf("are");
|
public static IRegex are = new RegexLeaf("are");
|
||||||
|
|
||||||
public static IRegex areColored = new RegexLeaf("are[%s]+colou?red");
|
public static IRegex areColored = new RegexLeaf("are[%s]+colou?red");
|
||||||
|
|
||||||
public static IRegex displayOnSameRowAs = new RegexLeaf("displays?[%s]+on[%s]+same[%s]+row[%s]+as");
|
public static IRegex displayOnSameRowAs = new RegexLeaf("displays?[%s]+on[%s]+same[%s]+row[%s]+as");
|
||||||
|
|
||||||
public static IRegex ends = new RegexLeaf("ends");
|
public static IRegex ends = new RegexLeaf("ends");
|
||||||
|
public static IRegex happens = new RegexLeaf("happens");
|
||||||
public static IRegex ends2 = new RegexLeaf("ends[%s]*(the[%s]*|on[%s]*|at[%s]*)*");
|
|
||||||
|
|
||||||
public static IRegex happens = new RegexLeaf("happens?[%s]*(at[%s]*|the[%s]*|on[%s]*)*");
|
|
||||||
|
|
||||||
public static IRegex pauses = new RegexLeaf("pauses?[%s]*(at[%s]*|the[%s]*|on[%s]*|from[%s]*)*");
|
|
||||||
|
|
||||||
public static IRegex isDeleted = new RegexLeaf("is[%s]+deleted");
|
|
||||||
|
|
||||||
public static IRegex is = new RegexLeaf("is");
|
public static IRegex is = new RegexLeaf("is");
|
||||||
|
|
||||||
public static IRegex isColored = new RegexLeaf("is[%s]+colou?red");
|
public static IRegex isColored = new RegexLeaf("is[%s]+colou?red");
|
||||||
|
public static IRegex isDeleted = new RegexLeaf("is[%s]+deleted");
|
||||||
public static IRegex isColoredForCompletion = new RegexLeaf("is[%s]+colou?red[%s]+for[%s]+completion");
|
public static IRegex isOff = new RegexLeaf("is[%s]+off");
|
||||||
|
public static IRegex isOn = new RegexLeaf("is[%s]+on");
|
||||||
public static IRegex isOff = new RegexConcat(new RegexLeaf("is"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexLeaf("off"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexOr(//
|
|
||||||
new RegexLeaf("from"), //
|
|
||||||
new RegexLeaf("on"), //
|
|
||||||
new RegexLeaf("for"), //
|
|
||||||
new RegexLeaf("the"), //
|
|
||||||
new RegexLeaf("at") //
|
|
||||||
));
|
|
||||||
|
|
||||||
public static IRegex isOffBefore = new RegexConcat(new RegexLeaf("is"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexLeaf("off"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexLeaf("before") //
|
|
||||||
);
|
|
||||||
|
|
||||||
public static IRegex isOffAfter = new RegexConcat(new RegexLeaf("is"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexLeaf("off"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexLeaf("after") //
|
|
||||||
);
|
|
||||||
|
|
||||||
public static IRegex isOn = new RegexConcat(new RegexLeaf("is"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexLeaf("on"), //
|
|
||||||
RegexLeaf.spaceOneOrMore(), //
|
|
||||||
new RegexOr(//
|
|
||||||
new RegexLeaf("from"), //
|
|
||||||
new RegexLeaf("on"), //
|
|
||||||
new RegexLeaf("for"), //
|
|
||||||
new RegexLeaf("the"), //
|
|
||||||
new RegexLeaf("at") //
|
|
||||||
) //
|
|
||||||
);
|
|
||||||
|
|
||||||
public static IRegex isOrAre = new RegexLeaf("(is|are)");
|
public static IRegex isOrAre = new RegexLeaf("(is|are)");
|
||||||
|
|
||||||
public static IRegex isOrAreNamed = new RegexLeaf("(is|are)[%s]+named");
|
public static IRegex isOrAreNamed = new RegexLeaf("(is|are)[%s]+named");
|
||||||
|
|
||||||
public static IRegex requires = new RegexLeaf("(lasts|requires?)");
|
|
||||||
|
|
||||||
public static IRegex linksTo = new RegexLeaf("links to");
|
|
||||||
|
|
||||||
public static IRegex occurs = new RegexLeaf("occurs?");
|
|
||||||
|
|
||||||
public static IRegex starts3 = new RegexLeaf("starts[%s]*(the[%s]*|on[%s]*|at[%s]*)*");
|
|
||||||
|
|
||||||
public static IRegex starts2 = new RegexLeaf("starts");
|
|
||||||
|
|
||||||
public static IRegex starts = 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 = new RegexLeaf("just");
|
public static IRegex just = new RegexLeaf("just");
|
||||||
|
public static IRegex linksTo = new RegexLeaf("links[%s]+to");
|
||||||
public static IRegex justBefore = new RegexLeaf("just[%s]*before");
|
public static IRegex occurs = new RegexLeaf("occurs");
|
||||||
|
public static IRegex pauses = new RegexLeaf("pauses");
|
||||||
public static IRegex justAfter = new RegexLeaf("just[%s]*after");
|
public static IRegex requires = new RegexLeaf("(lasts|requires)");
|
||||||
|
public static IRegex starts = new RegexLeaf("starts");
|
||||||
|
public static IRegex worksOn = new RegexLeaf("works[%s]+on");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
77
src/net/sourceforge/plantuml/project/lang/Words.java
Normal file
77
src/net/sourceforge/plantuml/project/lang/Words.java
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* (C) Copyright 2009-2024, Arnaud Roques
|
||||||
|
*
|
||||||
|
* Project Info: https://plantuml.com
|
||||||
|
*
|
||||||
|
* If you like this project or if you find it useful, you can support us at:
|
||||||
|
*
|
||||||
|
* https://plantuml.com/patreon (only 1$ per month!)
|
||||||
|
* https://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.regex.IRegex;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexConcat;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexLeaf;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexOr;
|
||||||
|
import net.sourceforge.plantuml.regex.RegexRepeatedZeroOrMore;
|
||||||
|
|
||||||
|
public class Words {
|
||||||
|
|
||||||
|
public final static String AFTER = "after";
|
||||||
|
public final static String AT = "at";
|
||||||
|
public final static String BEFORE = "before";
|
||||||
|
public final static String COMPLETION = "completion";
|
||||||
|
public final static String FOR = "for";
|
||||||
|
public final static String FROM = "from";
|
||||||
|
public final static String ON = "on";
|
||||||
|
public final static String THE = "the";
|
||||||
|
public final static String TO = "to";
|
||||||
|
|
||||||
|
public static IRegex zeroOrMore(String... words) {
|
||||||
|
final IRegex tmp[] = new IRegex[words.length];
|
||||||
|
for (int i = 0; i < words.length; i++)
|
||||||
|
tmp[i] = new RegexLeaf(words[i]);
|
||||||
|
|
||||||
|
final RegexOr or = new RegexOr(tmp);
|
||||||
|
return new RegexRepeatedZeroOrMore(new RegexConcat(RegexLeaf.spaceOneOrMore(), or));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static IRegex exactly(String... words) {
|
||||||
|
final IRegex tmp[] = new IRegex[words.length];
|
||||||
|
for (int i = 0; i < words.length; i++)
|
||||||
|
tmp[i] = new RegexConcat(RegexLeaf.spaceOneOrMore(), new RegexLeaf(words[i]));
|
||||||
|
|
||||||
|
return new RegexConcat(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static IRegex concat(IRegex... expressions) {
|
||||||
|
return new RegexConcat(expressions);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,58 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* (C) Copyright 2009-2024, Arnaud Roques
|
||||||
|
*
|
||||||
|
* Project Info: https://plantuml.com
|
||||||
|
*
|
||||||
|
* If you like this project or if you find it useful, you can support us at:
|
||||||
|
*
|
||||||
|
* https://plantuml.com/patreon (only 1$ per month!)
|
||||||
|
* https://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.regex;
|
||||||
|
|
||||||
|
import net.sourceforge.plantuml.text.StringLocated;
|
||||||
|
|
||||||
|
public class RegexRepeatedZeroOrMore extends RegexComposed implements IRegex {
|
||||||
|
|
||||||
|
public RegexRepeatedZeroOrMore(IRegex partial) {
|
||||||
|
super(partial);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected String getFullSlow() {
|
||||||
|
final StringBuilder sb = new StringBuilder("(?:");
|
||||||
|
sb.append(partials().get(0).getPattern());
|
||||||
|
sb.append(")*");
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean match(StringLocated full) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user