2021-04-12 12:31:43 -07:00
|
|
|
/******************************************************************************
|
|
|
|
|
* Top contributors (to current version):
|
2024-03-12 09:35:09 -07:00
|
|
|
* Aina Niemetz, Andrew Reynolds, Makai Mann
|
2021-04-12 12:31:43 -07:00
|
|
|
*
|
|
|
|
|
* This file is part of the cvc5 project.
|
|
|
|
|
*
|
2025-01-23 09:54:20 -08:00
|
|
|
* Copyright (c) 2009-2025 by the authors listed in the file AUTHORS
|
2021-04-12 12:31:43 -07:00
|
|
|
* in the top-level source directory and their institutional affiliations.
|
|
|
|
|
* All rights reserved. See the file COPYING in the top-level source
|
|
|
|
|
* directory for licensing information.
|
|
|
|
|
* ****************************************************************************
|
|
|
|
|
*
|
|
|
|
|
* White box testing of the Term class.
|
|
|
|
|
*/
|
2021-03-03 17:17:17 -08:00
|
|
|
|
|
|
|
|
#include "test_api.h"
|
|
|
|
|
|
2022-03-29 16:23:01 -07:00
|
|
|
namespace cvc5::internal {
|
2021-03-03 17:17:17 -08:00
|
|
|
|
|
|
|
|
namespace test {
|
|
|
|
|
|
|
|
|
|
class TestApiWhiteTerm : public TestApi
|
|
|
|
|
{
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
TEST_F(TestApiWhiteTerm, getOp)
|
|
|
|
|
{
|
2024-03-08 11:39:13 -08:00
|
|
|
Sort intsort = d_tm.getIntegerSort();
|
|
|
|
|
Sort bvsort = d_tm.mkBitVectorSort(8);
|
|
|
|
|
Sort arrsort = d_tm.mkArraySort(bvsort, intsort);
|
|
|
|
|
Sort funsort = d_tm.mkFunctionSort({intsort}, bvsort);
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2024-03-08 11:39:13 -08:00
|
|
|
Term x = d_tm.mkConst(intsort, "x");
|
|
|
|
|
Term a = d_tm.mkConst(arrsort, "a");
|
|
|
|
|
Term b = d_tm.mkConst(bvsort, "b");
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2024-03-08 11:39:13 -08:00
|
|
|
Term ab = d_tm.mkTerm(Kind::SELECT, {a, b});
|
|
|
|
|
Op ext = d_tm.mkOp(Kind::BITVECTOR_EXTRACT, {4, 0});
|
|
|
|
|
Term extb = d_tm.mkTerm(ext, {b});
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2024-03-08 11:39:13 -08:00
|
|
|
ASSERT_EQ(ab.getOp(), Op(&d_solver->getTermManager(), Kind::SELECT));
|
2021-03-03 17:17:17 -08:00
|
|
|
// can compare directly to a Kind (will invoke Op constructor)
|
2024-03-08 11:39:13 -08:00
|
|
|
ASSERT_EQ(ab.getOp(), Op(&d_solver->getTermManager(), Kind::SELECT));
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2024-03-08 11:39:13 -08:00
|
|
|
Term f = d_tm.mkConst(funsort, "f");
|
|
|
|
|
Term fx = d_tm.mkTerm(Kind::APPLY_UF, {f, x});
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2024-03-08 11:39:13 -08:00
|
|
|
ASSERT_EQ(fx.getOp(), Op(&d_solver->getTermManager(), Kind::APPLY_UF));
|
2021-03-03 17:17:17 -08:00
|
|
|
// testing rebuild from op and children
|
|
|
|
|
|
|
|
|
|
// Test Datatypes Ops
|
2024-03-08 11:39:13 -08:00
|
|
|
Sort sort = d_tm.mkParamSort("T");
|
|
|
|
|
DatatypeDecl listDecl = d_tm.mkDatatypeDecl("paramlist", {sort});
|
|
|
|
|
DatatypeConstructorDecl cons = d_tm.mkDatatypeConstructorDecl("cons");
|
|
|
|
|
DatatypeConstructorDecl nil = d_tm.mkDatatypeConstructorDecl("nil");
|
2021-03-03 17:17:17 -08:00
|
|
|
cons.addSelector("head", sort);
|
|
|
|
|
cons.addSelectorSelf("tail");
|
|
|
|
|
listDecl.addConstructor(cons);
|
|
|
|
|
listDecl.addConstructor(nil);
|
2024-03-08 11:39:13 -08:00
|
|
|
Sort listSort = d_tm.mkDatatypeSort(listDecl);
|
2021-03-03 17:17:17 -08:00
|
|
|
Sort intListSort =
|
2024-03-08 11:39:13 -08:00
|
|
|
listSort.instantiate(std::vector<Sort>{d_tm.getIntegerSort()});
|
|
|
|
|
Term c = d_tm.mkConst(intListSort, "c");
|
2021-03-03 17:17:17 -08:00
|
|
|
Datatype list = listSort.getDatatype();
|
|
|
|
|
// list datatype constructor and selector operator terms
|
2022-04-02 11:57:50 -07:00
|
|
|
Term consOpTerm = list.getConstructor("cons").getTerm();
|
|
|
|
|
Term nilOpTerm = list.getConstructor("nil").getTerm();
|
|
|
|
|
Term headOpTerm = list["cons"].getSelector("head").getTerm();
|
|
|
|
|
Term tailOpTerm = list["cons"].getSelector("tail").getTerm();
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2024-03-08 11:39:13 -08:00
|
|
|
Term nilTerm = d_tm.mkTerm(Kind::APPLY_CONSTRUCTOR, {nilOpTerm});
|
|
|
|
|
Term consTerm = d_tm.mkTerm(Kind::APPLY_CONSTRUCTOR,
|
|
|
|
|
{consOpTerm, d_tm.mkInteger(0), nilTerm});
|
|
|
|
|
Term headTerm = d_tm.mkTerm(Kind::APPLY_SELECTOR, {headOpTerm, consTerm});
|
|
|
|
|
Term tailTerm = d_tm.mkTerm(Kind::APPLY_SELECTOR, {tailOpTerm, consTerm});
|
2021-03-03 17:17:17 -08:00
|
|
|
|
2023-08-22 11:17:16 -07:00
|
|
|
ASSERT_EQ(nilTerm.getOp(),
|
2024-03-08 11:39:13 -08:00
|
|
|
Op(&d_solver->getTermManager(), Kind::APPLY_CONSTRUCTOR));
|
2023-08-22 11:17:16 -07:00
|
|
|
ASSERT_EQ(consTerm.getOp(),
|
2024-03-08 11:39:13 -08:00
|
|
|
Op(&d_solver->getTermManager(), Kind::APPLY_CONSTRUCTOR));
|
2023-08-22 11:17:16 -07:00
|
|
|
ASSERT_EQ(headTerm.getOp(),
|
2024-03-08 11:39:13 -08:00
|
|
|
Op(&d_solver->getTermManager(), Kind::APPLY_SELECTOR));
|
2023-08-22 11:17:16 -07:00
|
|
|
ASSERT_EQ(tailTerm.getOp(),
|
2024-03-08 11:39:13 -08:00
|
|
|
Op(&d_solver->getTermManager(), Kind::APPLY_SELECTOR));
|
2021-03-03 17:17:17 -08:00
|
|
|
}
|
|
|
|
|
} // namespace test
|
2022-03-29 16:23:01 -07:00
|
|
|
} // namespace cvc5::internal
|