blob: e938a02ea2b975c207c2af3d13a2f31bc5e72e43 [file] [log] [blame]
# Copyright 2014 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
{
'variables': {
'shared_generated_dir': '<(SHARED_INTERMEDIATE_DIR)/third_party/stp',
},
'targets': [
{
'target_name': 'stp',
'type': '<(component)',
'cflags': [
'-U_DEBUG',
'-Wno-dangling-else',
'-Wno-empty-body',
'-Wno-header-guard',
'-Wno-implicit-function-declaration',
'-Wno-mismatched-tags',
'-Wno-overloaded-virtual',
'-Wno-parentheses-equality',
'-Wno-return-type',
'-Wno-sign-compare',
'-Wno-sometimes-uninitialized',
'-Wno-string-conversion',
'-Wno-tautological-constant-out-of-range-compare',
'-Wno-unused-const-variable',
'-Wno-unused-function',
'-Wno-unused-private-field',
],
'cflags_cc': [
'-fexceptions',
],
'direct_dependent_settings': {
'include_dirs': [
'src/include',
],
},
'include_dirs': [
'config',
'src/include',
'src/lib',
'src/lib/Sat',
'src/lib/Sat/cryptominisat2/mtl',
'src/lib/extlib-abc',
'<(shared_generated_dir)/src/include',
],
'sources': [
'config/stp/config.h',
'src/include/stp/AbsRefineCounterExample/AbsRefine_CounterExample.h',
'src/include/stp/AST/ArrayTransformer.h',
'src/include/stp/AST/ASTBVConst.h',
'src/include/stp/AST/AST.h',
'src/include/stp/AST/ASTInterior.h',
'src/include/stp/AST/ASTInternal.h',
'src/include/stp/AST/ASTInternalWithChildren.h',
'src/include/stp/AST/ASTNode.h',
'src/include/stp/AST/ASTSymbol.h',
'src/include/stp/AST/NodeFactory/HashingNodeFactory.h',
'src/include/stp/AST/NodeFactory/NodeFactory.h',
'src/include/stp/AST/NodeFactory/SimplifyingNodeFactory.h',
'src/include/stp/AST/NodeFactory/TypeChecker.h',
'src/include/stp/AST/RunTimes.h',
'src/include/stp/AST/STLport_config.h',
'src/include/stp/AST/UsefulDefs.h',
'src/include/stp/c_interface.h',
'src/include/stp/cpp_interface.h',
'src/include/stp/Globals/Globals.h',
'src/include/stp/Interface/fdstream.h',
'src/include/stp/Parser/LetMgr.h',
'src/include/stp/Parser/parser.h',
'src/include/stp/Printer/AssortedPrinters.h',
'src/include/stp/Printer/printers.h',
'src/include/stp/Printer/SMTLIBPrinter.h',
'src/include/stp/Sat/CryptoMinisat.h',
'src/include/stp/Sat/MinisatCore.h',
'src/include/stp/Sat/MinisatCore_prop.h',
'src/include/stp/Sat/SATSolver.h',
'src/include/stp/Sat/SimplifyingMinisat.h',
'src/include/stp/Simplifier/AIGSimplifyPropositionalCore.h',
'src/include/stp/Simplifier/AlwaysTrue.h',
'src/include/stp/Simplifier/bvsolver.h',
'src/include/stp/Simplifier/constantBitP/ConstantBitP_MaxPrecision.h',
'src/include/stp/Simplifier/constantBitP/ConstantBitPropagation.h',
'src/include/stp/Simplifier/constantBitP/ConstantBitP_TransferFunctions.h',
'src/include/stp/Simplifier/constantBitP/ConstantBitP_Utility.h',
'src/include/stp/Simplifier/constantBitP/Dependencies.h',
'src/include/stp/Simplifier/constantBitP/FixedBits.h',
'src/include/stp/Simplifier/constantBitP/MersenneTwister.h',
'src/include/stp/Simplifier/constantBitP/multiplication/ColumnCounts.h',
'src/include/stp/Simplifier/constantBitP/multiplication/ColumnStats.h',
'src/include/stp/Simplifier/constantBitP/MultiplicationStats.h',
'src/include/stp/Simplifier/constantBitP/NodeToFixedBitsMap.h',
'src/include/stp/Simplifier/constantBitP/WorkList.h',
'src/include/stp/Simplifier/EstablishIntervals.h',
'src/include/stp/Simplifier/FindPureLiterals.h',
'src/include/stp/Simplifier/MutableASTNode.h',
'src/include/stp/Simplifier/PropagateEqualities.h',
'src/include/stp/Simplifier/RemoveUnconstrained.h',
'src/include/stp/Simplifier/simplifier.h',
'src/include/stp/Simplifier/SubstitutionMap.h',
'src/include/stp/Simplifier/Symbols.h',
'src/include/stp/Simplifier/UseITEContext.h',
'src/include/stp/Simplifier/VariablesInExpression.h',
'src/include/stp/STPManager/DifficultyScore.h',
'src/include/stp/STPManager/NodeIterator.h',
'src/include/stp/STPManager/STP.h',
'src/include/stp/STPManager/STPManager.h',
'src/include/stp/STPManager/UserDefinedFlags.h',
'src/include/stp/ToSat/AIG/BBNodeAIG.h',
'src/include/stp/ToSat/AIG/BBNodeManagerAIG.h',
'src/include/stp/ToSat/AIG/ToCNFAIG.h',
'src/include/stp/ToSat/AIG/ToSATAIG.h',
'src/include/stp/ToSat/ASTNode/BBNodeManagerASTNode.h',
'src/include/stp/ToSat/ASTNode/ClauseList.h',
'src/include/stp/ToSat/ASTNode/ToCNF.h',
'src/include/stp/ToSat/ASTNode/ToSAT.h',
'src/include/stp/ToSat/BitBlaster.h',
'src/include/stp/ToSat/ToSATBase.h',
'src/lib/AbsRefineCounterExample/AbstractionRefinement.cpp',
'src/lib/AbsRefineCounterExample/CounterExample.cpp',
'src/lib/AST/ArrayTransformer.cpp',
'src/lib/AST/ASTBVConst.cpp',
'src/lib/AST/ASTInterior.cpp',
'src/lib/AST/ASTmisc.cpp',
'src/lib/AST/ASTNode.cpp',
'src/lib/AST/ASTSymbol.cpp',
'src/lib/AST/ASTUtil.cpp',
'src/lib/AST/NodeFactory/HashingNodeFactory.cpp',
'src/lib/AST/NodeFactory/NodeFactory.cpp',
'src/lib/AST/NodeFactory/SimplifyingNodeFactory.cpp',
'src/lib/AST/NodeFactory/TypeChecker.cpp',
'src/lib/AST/RunTimes.cpp',
'src/lib/extlib-abc/aig/aig/aigCheck.c',
'src/lib/extlib-abc/aig/aig/aigDfs.c',
'src/lib/extlib-abc/aig/aig/aigFanout.c',
'src/lib/extlib-abc/aig/aig/aigMan.c',
'src/lib/extlib-abc/aig/aig/aigMem.c',
'src/lib/extlib-abc/aig/aig/aigMffc.c',
'src/lib/extlib-abc/aig/aig/aigObj.c',
'src/lib/extlib-abc/aig/aig/aigOper.c',
'src/lib/extlib-abc/aig/aig/aigOrder.c',
'src/lib/extlib-abc/aig/aig/aigPart.c',
'src/lib/extlib-abc/aig/aig/aigRepr.c',
'src/lib/extlib-abc/aig/aig/aigRet.c',
'src/lib/extlib-abc/aig/aig/aigScl.c',
'src/lib/extlib-abc/aig/aig/aigSeq.c',
'src/lib/extlib-abc/aig/aig/aigShow.c',
'src/lib/extlib-abc/aig/aig/aigTable.c',
'src/lib/extlib-abc/aig/aig/aigTime.c',
'src/lib/extlib-abc/aig/aig/aigTiming.c',
'src/lib/extlib-abc/aig/aig/aigTruth.c',
'src/lib/extlib-abc/aig/aig/aigTsim.c',
'src/lib/extlib-abc/aig/aig/aigUtil.c',
'src/lib/extlib-abc/aig/aig/aigWin.c',
'src/lib/extlib-abc/aig/cnf/cnfCore.c',
'src/lib/extlib-abc/aig/cnf/cnfCut.c',
'src/lib/extlib-abc/aig/cnf/cnfData.c',
'src/lib/extlib-abc/aig/cnf/cnfMan.c',
'src/lib/extlib-abc/aig/cnf/cnfMap.c',
'src/lib/extlib-abc/aig/cnf/cnfPost.c',
'src/lib/extlib-abc/aig/cnf/cnfUtil.c',
'src/lib/extlib-abc/aig/cnf/cnfWrite.c',
'src/lib/extlib-abc/aig/dar/darBalance.c',
'src/lib/extlib-abc/aig/dar/darCore.c',
'src/lib/extlib-abc/aig/dar/darCut.c',
'src/lib/extlib-abc/aig/dar/darData.c',
'src/lib/extlib-abc/aig/dar/darLib.c',
'src/lib/extlib-abc/aig/dar/darMan.c',
'src/lib/extlib-abc/aig/dar/darPrec.c',
'src/lib/extlib-abc/aig/dar/darRefact.c',
'src/lib/extlib-abc/aig/dar/darScript.c',
'src/lib/extlib-abc/aig.h',
'src/lib/extlib-abc/aig/kit/kitAig.c',
'src/lib/extlib-abc/aig/kit/kitGraph.c',
'src/lib/extlib-abc/aig/kit/kitIsop.c',
'src/lib/extlib-abc/aig/kit/kitSop.c',
'src/lib/extlib-abc/aig/kit/kitTruth.c',
'src/lib/extlib-abc/cnf.h',
'src/lib/extlib-abc/cnf_short.h',
'src/lib/extlib-abc/dar.h',
'src/lib/extlib-abc/darInt.h',
'src/lib/extlib-abc/kit.h',
'src/lib/extlib-abc/leaks.h',
'src/lib/extlib-abc/vecFlt.h',
'src/lib/extlib-abc/vec.h',
'src/lib/extlib-abc/vecInt.h',
'src/lib/extlib-abc/vecPtr.h',
'src/lib/extlib-abc/vecStr.h',
'src/lib/extlib-abc/vecVec.h',
'src/lib/extlib-constbv/constantbv.cpp',
'src/lib/extlib-constbv/constantbv.h',
'src/lib/Globals/Globals.cpp',
'src/lib/Interface/c_interface.cpp',
'src/lib/Interface/cpp_interface.cpp',
'src/lib/Parser/LetMgr.cpp',
'src/lib/Printer/AssortedPrinters.cpp',
'src/lib/Printer/BenchPrinter.cpp',
'src/lib/Printer/CPrinter.cpp',
'src/lib/Printer/dotPrinter.cpp',
'src/lib/Printer/GDLPrinter.cpp',
'src/lib/Printer/LispPrinter.cpp',
'src/lib/Printer/PLPrinter.cpp',
'src/lib/Printer/SMTLIB1Printer.cpp',
'src/lib/Printer/SMTLIB2Printer.cpp',
'src/lib/Printer/SMTLIBPrinter.cpp',
'src/lib/Sat/cryptominisat2/BitArray.h',
'src/lib/Sat/cryptominisat2/BoundedQueue.h',
'src/lib/Sat/cryptominisat2/ClauseAllocator.cpp',
'src/lib/Sat/cryptominisat2/ClauseAllocator.h',
'src/lib/Sat/cryptominisat2/ClauseCleaner.cpp',
'src/lib/Sat/cryptominisat2/ClauseCleaner.h',
'src/lib/Sat/cryptominisat2/Clause.h',
'src/lib/Sat/cryptominisat2/constants.h',
'src/lib/Sat/cryptominisat2/CSet.h',
'src/lib/Sat/cryptominisat2/FailedVarSearcher.cpp',
'src/lib/Sat/cryptominisat2/FailedVarSearcher.h',
'src/lib/Sat/cryptominisat2/FindUndef.cpp',
'src/lib/Sat/cryptominisat2/FindUndef.h',
'src/lib/Sat/cryptominisat2/GaussianConfig.h',
'src/lib/Sat/cryptominisat2/Gaussian.cpp',
'src/lib/Sat/cryptominisat2/Gaussian.h',
'src/lib/Sat/cryptominisat2/Logger.cpp',
'src/lib/Sat/cryptominisat2/Logger.h',
'src/lib/Sat/cryptominisat2/MatrixFinder.cpp',
'src/lib/Sat/cryptominisat2/MatrixFinder.h',
'src/lib/Sat/cryptominisat2/MemoryPool/MemoryPool.h',
'src/lib/Sat/cryptominisat2/MemoryPool/MemoryPool.tcc',
'src/lib/Sat/cryptominisat2/MersenneTwister.h',
'src/lib/Sat/cryptominisat2/msvc/stdint.h',
'src/lib/Sat/cryptominisat2/mtl/Alg.h',
'src/lib/Sat/cryptominisat2/mtl/BasicHeap.h',
'src/lib/Sat/cryptominisat2/mtl/BoxedVec.h',
'src/lib/Sat/cryptominisat2/mtl/Heap.h',
'src/lib/Sat/cryptominisat2/mtl/Map.h',
'src/lib/Sat/cryptominisat2/mtl/Queue.h',
'src/lib/Sat/cryptominisat2/mtl/Vec.h',
'src/lib/Sat/cryptominisat2/OnlyNonLearntBins.cpp',
'src/lib/Sat/cryptominisat2/OnlyNonLearntBins.h',
'src/lib/Sat/cryptominisat2/PackedMatrix.h',
'src/lib/Sat/cryptominisat2/PackedRow.cpp',
'src/lib/Sat/cryptominisat2/PackedRow.h',
'src/lib/Sat/cryptominisat2/PartFinder.cpp',
'src/lib/Sat/cryptominisat2/PartFinder.h',
'src/lib/Sat/cryptominisat2/PartHandler.cpp',
'src/lib/Sat/cryptominisat2/PartHandler.h',
'src/lib/Sat/cryptominisat2/RestartTypeChooser.cpp',
'src/lib/Sat/cryptominisat2/RestartTypeChooser.h',
'src/lib/Sat/cryptominisat2/Solver.cpp',
'src/lib/Sat/cryptominisat2/Solver.h',
'src/lib/Sat/cryptominisat2/SolverTypes.h',
'src/lib/Sat/cryptominisat2/StateSaver.cpp',
'src/lib/Sat/cryptominisat2/StateSaver.h',
'src/lib/Sat/cryptominisat2/Subsumer.cpp',
'src/lib/Sat/cryptominisat2/Subsumer.h',
'src/lib/Sat/cryptominisat2/time_mem.cpp',
'src/lib/Sat/cryptominisat2/time_mem.h',
'src/lib/Sat/cryptominisat2/UselessBinRemover.cpp',
'src/lib/Sat/cryptominisat2/UselessBinRemover.h',
'src/lib/Sat/cryptominisat2/VarReplacer.cpp',
'src/lib/Sat/cryptominisat2/VarReplacer.h',
'src/lib/Sat/cryptominisat2/XorFinder.cpp',
'src/lib/Sat/cryptominisat2/XorFinder.h',
'src/lib/Sat/cryptominisat2/XorSubsumer.cpp',
'src/lib/Sat/cryptominisat2/XorSubsumer.h',
'src/lib/Sat/cryptominisat2/XSet.h',
'src/lib/Sat/CryptoMinisat.cpp',
'src/lib/Sat/MinisatCore.cpp',
'src/lib/Sat/minisat/core/Dimacs.h',
'src/lib/Sat/MinisatCore_prop.cpp',
'src/lib/Sat/minisat/core_prop/Solver_prop.cc',
'src/lib/Sat/minisat/core_prop/Solver_prop.h',
'src/lib/Sat/minisat/core/Solver.cc',
'src/lib/Sat/minisat/core/Solver.h',
'src/lib/Sat/minisat/core/SolverTypes.h',
'src/lib/Sat/minisat/mtl/Alg.h',
'src/lib/Sat/minisat/mtl/Alloc.h',
'src/lib/Sat/minisat/mtl/BasicHeap.h',
'src/lib/Sat/minisat/mtl/BoxedVec.h',
'src/lib/Sat/minisat/mtl/Heap.h',
'src/lib/Sat/minisat/mtl/IntTypesMtl.h',
'src/lib/Sat/minisat/mtl/Map.h',
'src/lib/Sat/minisat/mtl/Queue.h',
'src/lib/Sat/minisat/mtl/Sort.h',
'src/lib/Sat/minisat/mtl/Vec.h',
'src/lib/Sat/minisat/mtl/XAlloc.h',
'src/lib/Sat/minisat/simp/SimpSolver.cc',
'src/lib/Sat/minisat/simp/SimpSolver.h',
'src/lib/Sat/minisat/utils/Options.h',
'src/lib/Sat/minisat/utils/ParseUtils.h',
'src/lib/Sat/minisat/utils/System.cc',
'src/lib/Sat/minisat/utils/System.h',
'src/lib/Sat/SimplifyingMinisat.cpp',
'src/lib/Simplifier/bvsolver.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Arithmetic.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Boolean.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Comparison.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Division.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_MaxPrecision.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Multiplication.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitPropagation.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Shifting.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_TransferFunctions.cpp',
'src/lib/Simplifier/constantBitP/ConstantBitP_Utility.cpp',
'src/lib/Simplifier/constantBitP/FixedBits.cpp',
'src/lib/Simplifier/consteval.cpp',
'src/lib/Simplifier/MutableASTNode.cpp',
'src/lib/Simplifier/PropagateEqualities.cpp',
'src/lib/Simplifier/RemoveUnconstrained.cpp',
'src/lib/Simplifier/simplifier.cpp',
'src/lib/Simplifier/SubstitutionMap.cpp',
'src/lib/Simplifier/VariablesInExpression.cpp',
'src/lib/STPManager/STP.cpp',
'src/lib/STPManager/STPManager.cpp',
'src/lib/ToSat/AIG/BBNodeManagerAIG.cpp',
'src/lib/ToSat/AIG/ToCNFAIG.cpp',
'src/lib/ToSat/AIG/ToSATAIG.cpp',
'src/lib/ToSat/ASTNode/ClauseList.cpp',
'src/lib/ToSat/ASTNode/SimpBool.cpp',
'src/lib/ToSat/ASTNode/ToCNF.cpp',
'src/lib/ToSat/ASTNode/ToSAT.cpp',
'src/lib/ToSat/BitBlaster.cpp',
'src/lib/ToSat/ToSATBase.cpp',
'<(shared_generated_dir)/src/include/stp/AST/ASTKind.h',
'<(shared_generated_dir)/src/lib/AST/ASTKind.cpp',
'<(shared_generated_dir)/src/lib/Parser/lexcvc.cpp',
'<(shared_generated_dir)/src/lib/Parser/lexsmt.cpp',
'<(shared_generated_dir)/src/lib/Parser/lexsmt2.cpp',
'<(shared_generated_dir)/src/lib/Parser/parsecvc.cpp',
'<(shared_generated_dir)/src/lib/Parser/parsecvc.hpp',
'<(shared_generated_dir)/src/lib/Parser/parsesmt.cpp',
'<(shared_generated_dir)/src/lib/Parser/parsesmt.hpp',
'<(shared_generated_dir)/src/lib/Parser/parsesmt2.cpp',
'<(shared_generated_dir)/src/lib/Parser/parsesmt2.hpp',
],
'dependencies': [
'stp_generated_sources',
],
},
{
'target_name': 'stp_generated_sources',
'type': 'none',
'sources': [
'src/lib/AST/ASTKind.kinds',
'src/lib/Parser/cvc.lex',
'src/lib/Parser/cvc.y',
'src/lib/Parser/smt.lex',
'src/lib/Parser/smt.y',
'src/lib/Parser/smt2.lex',
'src/lib/Parser/smt2.y',
],
'actions': [
{
'action_name': 'generate_astkind',
'inputs': [
'genastkinds.py',
'src/lib/AST/ASTKind.kinds',
'src/lib/AST/genkinds.pl',
],
'outputs': [
'<(shared_generated_dir)/src/include/stp/AST/ASTKind.h',
'<(shared_generated_dir)/src/lib/AST/ASTKind.cpp',
],
'action': [
'python',
'genastkinds.py',
'src/lib/AST/genkinds.pl',
'src/lib/AST/ASTKind.kinds',
'<(shared_generated_dir)',
],
'message': 'Generating ASTKind ...',
},
],
'rules': [
{
'rule_name': 'generate_flex',
'extension': '.lex',
'inputs': [
'flex.py',
],
'outputs': [
'<(shared_generated_dir)/<(RULE_INPUT_DIRNAME)/lex<(RULE_INPUT_ROOT).cpp',
],
'action': [
'python',
'flex.py',
'<(RULE_INPUT_PATH)',
'<(RULE_INPUT_ROOT)',
'<(shared_generated_dir)/<(RULE_INPUT_DIRNAME)/lex<(RULE_INPUT_ROOT)',
],
'message': 'Generating <(RULE_INPUT_ROOT) lexer ...',
},
{
'rule_name': 'generate_bison',
'extension': '.y',
'inputs': [
'bison.py',
],
'outputs': [
'<(shared_generated_dir)/<(RULE_INPUT_DIRNAME)/parse<(RULE_INPUT_ROOT).cpp',
'<(shared_generated_dir)/<(RULE_INPUT_DIRNAME)/parse<(RULE_INPUT_ROOT).hpp',
],
'action': [
'python',
'bison.py',
'<(RULE_INPUT_PATH)',
'<(RULE_INPUT_ROOT)',
'<(shared_generated_dir)/<(RULE_INPUT_DIRNAME)/parse<(RULE_INPUT_ROOT)',
],
'message': 'Generating <(RULE_INPUT_ROOT) parser ...',
},
],
},
],
}