de.learnlib.oracles.AbstractQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of learnlib-core Show documentation
Show all versions of learnlib-core Show documentation
Infrastructure and core functionalities of LearnLib
/* Copyright (C) 2013-2014 TU Dortmund
* This file is part of LearnLib, http://www.learnlib.de/.
*
* LearnLib is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 3.0 as published by the Free Software Foundation.
*
* LearnLib is 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with LearnLib; if not, see
* http://www.gnu.de/documents/lgpl.en.html.
*/
package de.learnlib.oracles;
import javax.annotation.Nonnull;
import javax.annotation.ParametersAreNonnullByDefault;
import net.automatalib.words.Word;
import de.learnlib.api.Query;
@ParametersAreNonnullByDefault
public abstract class AbstractQuery extends Query {
protected final Word prefix;
protected final Word suffix;
public AbstractQuery(Word prefix, Word suffix) {
this.prefix = prefix;
this.suffix = suffix;
}
public AbstractQuery(Word queryWord) {
this(Word.epsilon(), queryWord);
}
public AbstractQuery(Query query) {
this(query.getPrefix(), query.getSuffix());
}
@Override
@Nonnull
public Word getPrefix() {
return prefix;
}
@Override
@Nonnull
public Word getSuffix() {
return suffix;
}
/**
* Returns the string representation of this query, including a possible answer.
* This method should be used by classes extending {@link AbstractQuery} for their
* toString method to ensure output consistency.
*
* @return A string of the form {@code "Query[| / ]"}. If the query
* has not been answered yet, {@code } will be null.
*/
public String toStringWithAnswer(D answer) {
return "Query[" + prefix + '|' + suffix + " / " + answer + ']';
}
}