// // Dimacs parser. // #include #include #include #include #include "common.h" #ifndef DPLL_DIMACSPARSER_H #define DPLL_DIMACSPARSER_H class DimacsParser { public: /** * Parse a dimacs file. * @param file_name dimacs file name * @return a parsed formula (if succeeds) */ static formula parse(const std::string &file_name) { std::ifstream fin(file_name); if (!fin) { std::cerr << "file not found: " << file_name << "'" << std::endl; std::exit(1); } int n = 0, m = 0; while (!fin.eof()) { char ch; fin >> ch; if (ch == 'c') { // c-line: comment char buf[1024]; fin.getline(buf, 1024); } else if (ch == 'p') { // p-line: clauses will begin std::string buf; fin >> buf; assert(buf == "cnf"); fin >> n >> m; break; } else { // unexpected line std::cerr << "parse error at char '" << ch << "'" << std::endl; std::exit(1); } } // clauses begin std::vector clauses; for (int i = 0; i < m; i++) { clause c; while (!fin.eof()) { int v; fin >> v; if (v == 0) { clauses.push_back(c); break; } assert(VAR(v) <= n); c.push_back(v); } } assert(clauses.size() == m); return formula(n, clauses); } }; #endif //DPLL_DIMACSPARSER_H