/*++
Copyright (c) 2012 Microsoft Corporation
Module Name:
Tactic.cs
Abstract:
Z3 Managed API: Tactics
Author:
Christoph Wintersteiger (cwinter) 2012-03-21
Notes:
--*/
using System;
using System.Diagnostics;
namespace Microsoft.Z3
{
///
/// Tactics are the basic building block for creating custom solvers for specific problem domains.
/// The complete list of tactics may be obtained using Context.NumTactics
/// and Context.TacticNames.
/// It may also be obtained using the command (help-tactic) in the SMT 2.0 front-end.
///
public class Tactic : Z3Object
{
///
/// A string containing a description of parameters accepted by the tactic.
///
public string Help
{
get
{
return Native.Z3_tactic_get_help(Context.nCtx, NativeObject);
}
}
///
/// Retrieves parameter descriptions for Tactics.
///
public ParamDescrs ParameterDescriptions
{
get { return new ParamDescrs(Context, Native.Z3_tactic_get_param_descrs(Context.nCtx, NativeObject)); }
}
///
/// Execute the tactic over the goal.
///
public ApplyResult Apply(Goal g, Params p = null)
{
Debug.Assert(g != null);
Context.CheckContextMatch(g);
if (p == null)
return new ApplyResult(Context, Native.Z3_tactic_apply(Context.nCtx, NativeObject, g.NativeObject));
else
{
Context.CheckContextMatch(p);
return new ApplyResult(Context, Native.Z3_tactic_apply_ex(Context.nCtx, NativeObject, g.NativeObject, p.NativeObject));
}
}
///
/// Apply the tactic to a goal.
///
public ApplyResult this[Goal g]
{
get
{
Debug.Assert(g != null);
return Apply(g);
}
}
///
/// Creates a solver that is implemented using the given tactic.
///
///
public Solver Solver
{
get
{
return Context.MkSolver(this);
}
}
#region Internal
internal Tactic(Context ctx, IntPtr obj)
: base(ctx, obj)
{
Debug.Assert(ctx != null);
}
internal Tactic(Context ctx, string name)
: base(ctx, Native.Z3_mk_tactic(ctx.nCtx, name))
{
Debug.Assert(ctx != null);
}
internal override void IncRef(IntPtr o)
{
Native.Z3_tactic_inc_ref(Context.nCtx, o);
}
internal override void DecRef(IntPtr o)
{
lock (Context)
{
if (Context.nCtx != IntPtr.Zero)
Native.Z3_tactic_dec_ref(Context.nCtx, o);
}
}
#endregion
}
}