LCOV - code coverage report
Current view: top level - buildbot/coverage/build/test/api/cpp/issues - proj-issue587.cpp (source / functions) Hit Total Coverage
Test: coverage.info Lines: 27 27 100.0 %
Date: 2026-03-04 11:41:08 Functions: 1 1 100.0 %
Branches: 0 0 -

           Branch data     Line data    Source code
       1                 :            : /******************************************************************************
       2                 :            :  * This file is part of the cvc5 project.
       3                 :            :  *
       4                 :            :  * Copyright (c) 2009-2026 by the authors listed in the file AUTHORS
       5                 :            :  * in the top-level source directory and their institutional affiliations.
       6                 :            :  * All rights reserved.  See the file COPYING in the top-level source
       7                 :            :  * directory for licensing information.
       8                 :            :  * ****************************************************************************
       9                 :            :  *
      10                 :            :  * Test for project issue #587
      11                 :            :  *
      12                 :            :  */
      13                 :            : #include <cvc5/cvc5.h>
      14                 :            : 
      15                 :            : using namespace cvc5;
      16                 :          1 : int main(void)
      17                 :            : {
      18                 :          1 :   TermManager tm;
      19                 :          1 :   Solver solver(tm);
      20                 :          1 :   solver.setOption("incremental", "false");
      21                 :          1 :   solver.setOption("sygus-core-connective", "true");
      22                 :          1 :   solver.setOption("produce-abducts", "true");
      23                 :          1 :   Sort s0 = tm.getBooleanSort();
      24                 :          1 :   Sort s1 = tm.mkSetSort(s0);
      25                 :          1 :   Sort s2 = tm.mkSetSort(s1);
      26                 :          1 :   Term t3 = tm.mkEmptySet(s2);
      27                 :          1 :   Term t4 = tm.mkConst(s1, "_x2");
      28                 :          1 :   Op o5 = tm.mkOp(Kind::SET_SINGLETON);
      29                 :          3 :   Term t6 = tm.mkTerm(o5, {t3});
      30                 :          1 :   Sort s7 = t6.getSort();
      31                 :          1 :   Op o8 = tm.mkOp(Kind::SET_SINGLETON);
      32                 :          3 :   Term t9 = tm.mkTerm(o5, {t6});
      33                 :          1 :   Sort s10 = t9.getSort();
      34                 :          1 :   Op o11 = tm.mkOp(Kind::SET_MINUS);
      35                 :          4 :   Term t12 = tm.mkTerm(o11, {t9, t9});
      36                 :          1 :   Op o13 = tm.mkOp(Kind::SET_IS_SINGLETON);
      37                 :          3 :   Term t14 = tm.mkTerm(o13, {t12});
      38                 :          1 :   solver.assertFormula(t14);
      39                 :          1 :   Op o15 = tm.mkOp(Kind::SET_MEMBER);
      40                 :          4 :   Term t16 = tm.mkTerm(o15, {t14, t4});
      41                 :          1 :   Term t17 = solver.getAbduct(t16);
      42                 :            : 
      43                 :          1 :   return 0;
      44                 :          1 : }

Generated by: LCOV version 1.14