Class DebuggingStringFormulaManager
- java.lang.Object
-
- org.sosy_lab.java_smt.delegate.debugging.DebuggingStringFormulaManager
-
- All Implemented Interfaces:
StringFormulaManager
public class DebuggingStringFormulaManager extends Object implements StringFormulaManager
-
-
Constructor Summary
Constructors Constructor Description DebuggingStringFormulaManager(StringFormulaManager pDelegate, org.sosy_lab.java_smt.delegate.debugging.DebuggingAssertions pDebugging)
-
Method Summary
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.sosy_lab.java_smt.api.StringFormulaManager
concat, concat, range
-
-
-
-
Constructor Detail
-
DebuggingStringFormulaManager
public DebuggingStringFormulaManager(StringFormulaManager pDelegate, org.sosy_lab.java_smt.delegate.debugging.DebuggingAssertions pDebugging)
-
-
Method Detail
-
makeString
public StringFormula makeString(String value)
Description copied from interface:StringFormulaManager
Returns aStringFormula
representing the given constant.- Specified by:
makeString
in interfaceStringFormulaManager
- Parameters:
value
- the string value the returnedFormula
should represent- Returns:
- a Formula representing the given value
-
makeVariable
public StringFormula makeVariable(String pVar)
Description copied from interface:StringFormulaManager
Creates a variable of type String with exactly the given name.This variable (symbol) represents a "String" for which the SMT solver needs to find a model.
Please make sure that the given name is valid in SMT-LIB2. Take a look at
FormulaManager.isValidName(java.lang.String)
for further information.This method does not quote or unquote the given name, but uses the plain name "AS IS".
Formula.toString()
can return a different String than the given one.- Specified by:
makeVariable
in interfaceStringFormulaManager
-
equal
public BooleanFormula equal(StringFormula str1, StringFormula str2)
- Specified by:
equal
in interfaceStringFormulaManager
-
greaterThan
public BooleanFormula greaterThan(StringFormula str1, StringFormula str2)
- Specified by:
greaterThan
in interfaceStringFormulaManager
-
greaterOrEquals
public BooleanFormula greaterOrEquals(StringFormula str1, StringFormula str2)
- Specified by:
greaterOrEquals
in interfaceStringFormulaManager
-
lessThan
public BooleanFormula lessThan(StringFormula str1, StringFormula str2)
- Specified by:
lessThan
in interfaceStringFormulaManager
-
lessOrEquals
public BooleanFormula lessOrEquals(StringFormula str1, StringFormula str2)
- Specified by:
lessOrEquals
in interfaceStringFormulaManager
-
prefix
public BooleanFormula prefix(StringFormula prefix, StringFormula str)
Description copied from interface:StringFormulaManager
Check whether the given prefix is a real prefix of str.- Specified by:
prefix
in interfaceStringFormulaManager
-
suffix
public BooleanFormula suffix(StringFormula suffix, StringFormula str)
Description copied from interface:StringFormulaManager
Check whether the given suffix is a real suffix of str.- Specified by:
suffix
in interfaceStringFormulaManager
-
contains
public BooleanFormula contains(StringFormula str, StringFormula part)
- Specified by:
contains
in interfaceStringFormulaManager
-
indexOf
public NumeralFormula.IntegerFormula indexOf(StringFormula str, StringFormula part, NumeralFormula.IntegerFormula startIndex)
Description copied from interface:StringFormulaManager
Get the first index for a substring in a String, or -1 if the substring is not found. startIndex (inlcuded) denotes the start of the search for the index.- Specified by:
indexOf
in interfaceStringFormulaManager
-
charAt
public StringFormula charAt(StringFormula str, NumeralFormula.IntegerFormula index)
Description copied from interface:StringFormulaManager
Get a substring of length 1 from the given String.The result is underspecified, if the index is out of bounds for the given String.
- Specified by:
charAt
in interfaceStringFormulaManager
-
substring
public StringFormula substring(StringFormula str, NumeralFormula.IntegerFormula index, NumeralFormula.IntegerFormula length)
Description copied from interface:StringFormulaManager
Get a substring from the given String.The result is underspecified, if the start index is out of bounds for the given String or if the requested length is negative. The length of the result is the minimum of the requested length and the remaining length of the given String.
- Specified by:
substring
in interfaceStringFormulaManager
-
replace
public StringFormula replace(StringFormula fullStr, StringFormula target, StringFormula replacement)
Description copied from interface:StringFormulaManager
Replace the first appearances of target in fullStr with the replacement.- Specified by:
replace
in interfaceStringFormulaManager
-
replaceAll
public StringFormula replaceAll(StringFormula fullStr, StringFormula target, StringFormula replacement)
Description copied from interface:StringFormulaManager
Replace all appearances of target in fullStr with the replacement.- Specified by:
replaceAll
in interfaceStringFormulaManager
-
length
public NumeralFormula.IntegerFormula length(StringFormula str)
- Specified by:
length
in interfaceStringFormulaManager
-
concat
public StringFormula concat(List<StringFormula> parts)
- Specified by:
concat
in interfaceStringFormulaManager
-
in
public BooleanFormula in(StringFormula str, RegexFormula regex)
- Specified by:
in
in interfaceStringFormulaManager
- Parameters:
str
- formula representing the string to matchregex
- formula representing the regular expression- Returns:
- a formula representing the acceptance of the string by the regular expression
-
makeRegex
public RegexFormula makeRegex(String value)
Description copied from interface:StringFormulaManager
Returns aRegexFormula
representing the given constant.This method does not parse an existing regex from String, but uses the String directly as a constant.
- Specified by:
makeRegex
in interfaceStringFormulaManager
- Parameters:
value
- the regular expression the returnedFormula
should represent
-
none
public RegexFormula none()
- Specified by:
none
in interfaceStringFormulaManager
- Returns:
- formula denoting the empty set of strings
-
all
public RegexFormula all()
Description copied from interface:StringFormulaManager
Note: The size of the used alphabet depends on the underlying SMT solver.- Specified by:
all
in interfaceStringFormulaManager
- Returns:
- formula denoting the set of all strings, also known as Regex
".*"
.
-
allChar
public RegexFormula allChar()
Description copied from interface:StringFormulaManager
Note: The size of the used alphabet depends on the underlying SMT solver.- Specified by:
allChar
in interfaceStringFormulaManager
- Returns:
- formula denoting the set of all strings of length 1, also known as DOT operator which
represents one arbitrary char, or as Regex
"."
.
-
range
public RegexFormula range(StringFormula start, StringFormula end)
- Specified by:
range
in interfaceStringFormulaManager
- Returns:
- formula denoting the range regular expression over two sequences of length 1.
-
concatRegex
public RegexFormula concatRegex(List<RegexFormula> parts)
- Specified by:
concatRegex
in interfaceStringFormulaManager
- Returns:
- formula denoting the concatenation
-
union
public RegexFormula union(RegexFormula regex1, RegexFormula regex2)
- Specified by:
union
in interfaceStringFormulaManager
- Returns:
- formula denoting the union
-
intersection
public RegexFormula intersection(RegexFormula regex1, RegexFormula regex2)
- Specified by:
intersection
in interfaceStringFormulaManager
- Returns:
- formula denoting the intersection
-
complement
public RegexFormula complement(RegexFormula regex)
- Specified by:
complement
in interfaceStringFormulaManager
- Returns:
- formula denoting the Kleene closure
-
closure
public RegexFormula closure(RegexFormula regex)
- Specified by:
closure
in interfaceStringFormulaManager
- Returns:
- formula denoting the Kleene closure (0 or more), also known as STAR operand.
-
difference
public RegexFormula difference(RegexFormula regex1, RegexFormula regex2)
- Specified by:
difference
in interfaceStringFormulaManager
- Returns:
- formula denoting the difference
-
cross
public RegexFormula cross(RegexFormula regex)
- Specified by:
cross
in interfaceStringFormulaManager
- Returns:
- formula denoting the Kleene cross (1 or more), also known as PLUS operand.
-
optional
public RegexFormula optional(RegexFormula regex)
- Specified by:
optional
in interfaceStringFormulaManager
- Returns:
- formula denoting the optionality, also known as QUESTIONMARK operand.
-
times
public RegexFormula times(RegexFormula regex, int repetitions)
- Specified by:
times
in interfaceStringFormulaManager
- Returns:
- formula denoting the concatenation n times
-
toIntegerFormula
public NumeralFormula.IntegerFormula toIntegerFormula(StringFormula str)
Description copied from interface:StringFormulaManager
Interpret a String formula as an Integer formula.The number is interpreted in base 10 and has no leading zeros. The method works as expected for positive numbers, including zero. It returns the constant value of
-1
for negative numbers or invalid number representations, for example if any char is no digit.- Specified by:
toIntegerFormula
in interfaceStringFormulaManager
-
toStringFormula
public StringFormula toStringFormula(NumeralFormula.IntegerFormula number)
Description copied from interface:StringFormulaManager
Interpret an Integer formula as a String formula.The number is in base 10. The method works as expected for positive numbers, including zero. It returns the empty string
""
for negative numbers.- Specified by:
toStringFormula
in interfaceStringFormulaManager
-
-