z3-z3-4.13.0.src.api.dotnet.AST.cs Maven / Gradle / Ivy
The newest version!
/*++
Copyright (c) 2012 Microsoft Corporation
Module Name:
AST.cs
Abstract:
Z3 Managed API: ASTs
Author:
Christoph Wintersteiger (cwinter) 2012-03-16
Notes:
--*/
using System.Diagnostics;
using System;
using System.Collections;
using System.Collections.Generic;
namespace Microsoft.Z3
{
///
/// The abstract syntax tree (AST) class.
///
public class AST : Z3Object, IComparable
{
///
/// Comparison operator.
///
/// An AST
/// An AST
/// True if and are from the same context
/// and represent the same sort; false otherwise.
public static bool operator ==(AST a, AST b)
{
return Object.ReferenceEquals(a, b) ||
(!Object.ReferenceEquals(a, null) &&
!Object.ReferenceEquals(b, null) &&
a.Context.nCtx == b.Context.nCtx &&
0 != Native.Z3_is_eq_ast(a.Context.nCtx, a.NativeObject, b.NativeObject));
}
///
/// Comparison operator.
///
/// An AST
/// An AST
/// True if and are not from the same context
/// or represent different sorts; false otherwise.
public static bool operator !=(AST a, AST b)
{
return !(a == b);
}
///
/// Object comparison.
///
public override bool Equals(object o)
{
AST casted = o as AST;
if (casted == null) return false;
return this == casted;
}
///
/// Object Comparison.
///
/// Another AST
/// Negative if the object should be sorted before , positive if after else zero.
public virtual int CompareTo(object other)
{
if (other == null) return 1;
AST oAST = other as AST;
if (oAST == null)
return 1;
else
{
if (Id < oAST.Id)
return -1;
else if (Id > oAST.Id)
return +1;
else
return 0;
}
}
///
/// The AST's hash code.
///
/// A hash code
public override int GetHashCode()
{
return (int)Native.Z3_get_ast_hash(Context.nCtx, NativeObject);
}
///
/// A unique identifier for the AST (unique among all ASTs).
///
public uint Id
{
get { return Native.Z3_get_ast_id(Context.nCtx, NativeObject); }
}
///
/// Translates (copies) the AST to the Context .
///
/// A context
/// A copy of the AST which is associated with
public AST Translate(Context ctx)
{
Debug.Assert(ctx != null);
if (ReferenceEquals(Context, ctx))
return this;
else
return Create(ctx, Native.Z3_translate(Context.nCtx, NativeObject, ctx.nCtx));
}
///
/// The kind of the AST.
///
public Z3_ast_kind ASTKind
{
get { return (Z3_ast_kind)Native.Z3_get_ast_kind(Context.nCtx, NativeObject); }
}
///
/// Indicates whether the AST is an Expr
///
public bool IsExpr
{
get
{
switch (ASTKind)
{
case Z3_ast_kind.Z3_APP_AST:
case Z3_ast_kind.Z3_NUMERAL_AST:
case Z3_ast_kind.Z3_QUANTIFIER_AST:
case Z3_ast_kind.Z3_VAR_AST: return true;
default: return false;
}
}
}
///
/// Indicates whether the AST is an application
///
public bool IsApp
{
get { return this.ASTKind == Z3_ast_kind.Z3_APP_AST; }
}
///
/// Indicates whether the AST is a BoundVariable
///
public bool IsVar
{
get { return this.ASTKind == Z3_ast_kind.Z3_VAR_AST; }
}
///
/// Indicates whether the AST is a Quantifier
///
public bool IsQuantifier
{
get { return this.ASTKind == Z3_ast_kind.Z3_QUANTIFIER_AST; }
}
///
/// Indicates whether the AST is a Sort
///
public bool IsSort
{
get { return this.ASTKind == Z3_ast_kind.Z3_SORT_AST; }
}
///
/// Indicates whether the AST is a FunctionDeclaration
///
public bool IsFuncDecl
{
get { return this.ASTKind == Z3_ast_kind.Z3_FUNC_DECL_AST; }
}
///
/// A string representation of the AST.
///
public override string ToString()
{
return Native.Z3_ast_to_string(Context.nCtx, NativeObject);
}
///
/// A string representation of the AST in s-expression notation.
///
public string SExpr()
{
return Native.Z3_ast_to_string(Context.nCtx, NativeObject);
}
#region Internal
internal AST(Context ctx) : base(ctx) { Debug.Assert(ctx != null); }
internal AST(Context ctx, IntPtr obj) : base(ctx, obj) { Debug.Assert(ctx != null); }
internal override void IncRef(IntPtr o)
{
if (Context != null && o != IntPtr.Zero)
Native.Z3_inc_ref(Context.nCtx, o);
}
internal override void DecRef(IntPtr o)
{
if (Context != null && o != IntPtr.Zero)
{
lock (Context)
{
if (Context.nCtx != IntPtr.Zero)
Native.Z3_dec_ref(Context.nCtx, o);
}
}
}
internal static AST Create(Context ctx, IntPtr obj)
{
Debug.Assert(ctx != null);
switch ((Z3_ast_kind)Native.Z3_get_ast_kind(ctx.nCtx, obj))
{
case Z3_ast_kind.Z3_FUNC_DECL_AST: return new FuncDecl(ctx, obj);
case Z3_ast_kind.Z3_QUANTIFIER_AST: return new Quantifier(ctx, obj);
case Z3_ast_kind.Z3_SORT_AST: return Sort.Create(ctx, obj);
case Z3_ast_kind.Z3_APP_AST:
case Z3_ast_kind.Z3_NUMERAL_AST:
case Z3_ast_kind.Z3_VAR_AST: return Expr.Create(ctx, obj);
default:
throw new Z3Exception("Unknown AST kind");
}
}
#endregion
}
}