mirror of
https://github.com/Z3Prover/z3
synced 2025-11-25 23:19:32 +00:00
* Reworked phantom reference handling. - Replaced IDecRefQueue with a new Z3ReferenceQueue class - Z3ReferenceQueue manages custom subclasses of phantom references in a doubly-linked list - Replaced all subclasses of IDecRefQueue with subclasses of Z3ReferenceQueue.Reference. These custom reference classes are embedded in the class they reference count. - Context now owns a single Z3ReferenceQueue for all types of references. * Made Statistics.Entry a static subclass * Made Context.close idempotent (as recommended) * Update CMakeLists.txt for building the Java API. * Updated CMakeLists.txt again. * Use correct SuppressWarning annotation to silence the compiler * Formatting
217 lines
5.5 KiB
Java
217 lines
5.5 KiB
Java
/**
|
|
Copyright (c) 2012-2014 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
FuncInterp.java
|
|
|
|
Abstract:
|
|
|
|
Author:
|
|
|
|
@author Christoph Wintersteiger (cwinter) 2012-03-15
|
|
|
|
Notes:
|
|
|
|
**/
|
|
|
|
package com.microsoft.z3;
|
|
|
|
import java.lang.ref.ReferenceQueue;
|
|
|
|
/**
|
|
* A function interpretation is represented as a finite map and an 'else' value.
|
|
* Each entry in the finite map represents the value of a function given a set
|
|
* of arguments.
|
|
**/
|
|
@SuppressWarnings("unchecked")
|
|
public class FuncInterp<R extends Sort> extends Z3Object {
|
|
|
|
/**
|
|
* An Entry object represents an element in the finite map used to encode a
|
|
* function interpretation.
|
|
**/
|
|
public static class Entry<R extends Sort> extends Z3Object {
|
|
|
|
/**
|
|
* Return the (symbolic) value of this entry.
|
|
*
|
|
* @throws Z3Exception
|
|
* @throws Z3Exception on error
|
|
**/
|
|
public Expr<R> getValue()
|
|
{
|
|
return (Expr<R>) Expr.create(getContext(),
|
|
Native.funcEntryGetValue(getContext().nCtx(), getNativeObject()));
|
|
}
|
|
|
|
/**
|
|
* The number of arguments of the entry.
|
|
* @throws Z3Exception on error
|
|
**/
|
|
public int getNumArgs()
|
|
{
|
|
return Native.funcEntryGetNumArgs(getContext().nCtx(), getNativeObject());
|
|
}
|
|
|
|
/**
|
|
* The arguments of the function entry.
|
|
*
|
|
* @throws Z3Exception
|
|
* @throws Z3Exception on error
|
|
**/
|
|
public Expr<?>[] getArgs()
|
|
{
|
|
int n = getNumArgs();
|
|
Expr<?>[] res = new Expr[n];
|
|
for (int i = 0; i < n; i++)
|
|
res[i] = Expr.create(getContext(), Native.funcEntryGetArg(
|
|
getContext().nCtx(), getNativeObject(), i));
|
|
return res;
|
|
}
|
|
|
|
/**
|
|
* A string representation of the function entry.
|
|
**/
|
|
@Override
|
|
public String toString()
|
|
{
|
|
int n = getNumArgs();
|
|
String res = "[";
|
|
Expr<?>[] args = getArgs();
|
|
for (int i = 0; i < n; i++)
|
|
res += args[i] + ", ";
|
|
return res + getValue() + "]";
|
|
}
|
|
|
|
Entry(Context ctx, long obj) {
|
|
super(ctx, obj);
|
|
}
|
|
|
|
@Override
|
|
void incRef() {
|
|
Native.funcEntryIncRef(getContext().nCtx(), getNativeObject());
|
|
}
|
|
|
|
@Override
|
|
void addToReferenceQueue() {
|
|
getContext().getReferenceQueue().storeReference(this, FuncEntryRef::new);
|
|
}
|
|
|
|
private static class FuncEntryRef extends Z3ReferenceQueue.Reference<Entry<?>> {
|
|
|
|
private FuncEntryRef(Entry<?> referent, ReferenceQueue<Z3Object> q) {
|
|
super(referent, q);
|
|
}
|
|
|
|
@Override
|
|
void decRef(Context ctx, long z3Obj) {
|
|
Native.funcEntryDecRef(ctx.nCtx(), z3Obj);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* The number of entries in the function interpretation.
|
|
* @throws Z3Exception on error
|
|
* @return an int
|
|
**/
|
|
public int getNumEntries()
|
|
{
|
|
return Native.funcInterpGetNumEntries(getContext().nCtx(), getNativeObject());
|
|
}
|
|
|
|
/**
|
|
* The entries in the function interpretation
|
|
*
|
|
* @throws Z3Exception
|
|
* @throws Z3Exception on error
|
|
**/
|
|
public Entry<R>[] getEntries()
|
|
{
|
|
int n = getNumEntries();
|
|
Entry<R>[] res = new Entry[n];
|
|
for (int i = 0; i < n; i++)
|
|
res[i] = new Entry<>(getContext(), Native.funcInterpGetEntry(getContext()
|
|
.nCtx(), getNativeObject(), i));
|
|
return res;
|
|
}
|
|
|
|
/**
|
|
* The (symbolic) `else' value of the function interpretation.
|
|
*
|
|
* @throws Z3Exception
|
|
* @throws Z3Exception on error
|
|
* @return an Expr
|
|
**/
|
|
public Expr<R> getElse()
|
|
{
|
|
return (Expr<R>) Expr.create(getContext(),
|
|
Native.funcInterpGetElse(getContext().nCtx(), getNativeObject()));
|
|
}
|
|
|
|
/**
|
|
* The arity of the function interpretation
|
|
* @throws Z3Exception on error
|
|
* @return an int
|
|
**/
|
|
public int getArity()
|
|
{
|
|
return Native.funcInterpGetArity(getContext().nCtx(), getNativeObject());
|
|
}
|
|
|
|
/**
|
|
* A string representation of the function interpretation.
|
|
**/
|
|
public String toString()
|
|
{
|
|
String res = "";
|
|
res += "[";
|
|
for (Entry<R> e : getEntries())
|
|
{
|
|
int n = e.getNumArgs();
|
|
if (n > 1)
|
|
res += "[";
|
|
Expr<?>[] args = e.getArgs();
|
|
for (int i = 0; i < n; i++)
|
|
{
|
|
if (i != 0)
|
|
res += ", ";
|
|
res += args[i];
|
|
}
|
|
if (n > 1)
|
|
res += "]";
|
|
res += " -> " + e.getValue() + ", ";
|
|
}
|
|
res += "else -> " + getElse();
|
|
res += "]";
|
|
return res;
|
|
}
|
|
|
|
FuncInterp(Context ctx, long obj)
|
|
{
|
|
super(ctx, obj);
|
|
}
|
|
|
|
@Override
|
|
void incRef() {
|
|
Native.funcInterpIncRef(getContext().nCtx(), getNativeObject());
|
|
}
|
|
|
|
@Override
|
|
void addToReferenceQueue() {
|
|
getContext().getReferenceQueue().storeReference(this, FuncInterpRef::new);
|
|
}
|
|
|
|
private static class FuncInterpRef extends Z3ReferenceQueue.Reference<FuncInterp<?>> {
|
|
|
|
private FuncInterpRef(FuncInterp<?> referent, ReferenceQueue<Z3Object> q) {
|
|
super(referent, q);
|
|
}
|
|
|
|
@Override
|
|
void decRef(Context ctx, long z3Obj) {
|
|
Native.funcInterpDecRef(ctx.nCtx(), z3Obj);
|
|
}
|
|
}
|
|
}
|