* src/sanity/style.test: Add a test. * iface/dve2/dve2.cc, iface/dve2/dve2check.cc, src/bin/common_output.cc, src/bin/dstar2tgba.cc, src/bin/ltl2tgba.cc, src/bin/ltlcross.cc, src/dstarparse/dra2ba.cc, src/dstarparse/fmterror.cc, src/dstarparse/nsa2tgba.cc, src/kripke/kripkeprint.cc, src/kripkeparse/fmterror.cc, src/ltlast/atomic_prop.cc, src/ltlast/bunop.cc, src/ltltest/ltlrel.cc, src/ltltest/reduc.cc, src/ltltest/syntimpl.cc, src/ltlvisit/dotty.cc, src/ltlvisit/lbt.cc, src/ltlvisit/randomltl.cc, src/ltlvisit/relabel.cc, src/ltlvisit/simplify.cc, src/ltlvisit/tostring.cc, src/misc/bitvect.cc, src/misc/optionmap.cc, src/misc/timer.cc, src/neverparse/fmterror.cc, src/priv/freelist.cc, src/saba/sabacomplementtgba.cc, src/sabaalgos/sabadotty.cc, src/taalgos/dotty.cc, src/taalgos/minimize.cc, src/tgba/bdddict.cc, src/tgba/bddprint.cc, src/tgba/futurecondcol.cc, src/tgba/taatgba.hh, src/tgba/tgbakvcomplement.cc, src/tgba/tgbasafracomplement.cc, src/tgbaalgos/compsusp.cc, src/tgbaalgos/cycles.cc, src/tgbaalgos/dotty.cc, src/tgbaalgos/dtbasat.cc, src/tgbaalgos/dtgbasat.cc, src/tgbaalgos/emptiness.cc, src/tgbaalgos/gtec/gtec.cc, src/tgbaalgos/gv04.cc, src/tgbaalgos/lbtt.cc, src/tgbaalgos/ltl2tgba_fm.cc, src/tgbaalgos/minimize.cc, src/tgbaalgos/neverclaim.cc, src/tgbaalgos/powerset.cc, src/tgbaalgos/replayrun.cc, src/tgbaalgos/save.cc, src/tgbaalgos/scc.cc, src/tgbaalgos/sccfilter.cc, src/tgbaalgos/weight.cc, src/tgbaalgos/word.cc, src/tgbaparse/fmterror.cc, src/tgbatest/bitvect.cc, src/tgbatest/complementation.cc, src/tgbatest/intvcmp2.cc, src/tgbatest/intvcomp.cc, src/tgbatest/ltl2tgba.cc, src/tgbatest/randtgba.cc: Replace << "c" by << 'c' when appropriate.
221 lines
6.5 KiB
C++
221 lines
6.5 KiB
C++
// -*- coding: utf-8 -*-
|
|
// Copyright (C) 2011, 2014 Laboratoire de Recherche et Developpement
|
|
// de l'Epita (LRDE).
|
|
//
|
|
// This file is part of Spot, a model checking library.
|
|
//
|
|
// Spot is free software; you can redistribute it and/or modify it
|
|
// under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation; either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Spot is distributed in the hope that it will be useful, but WITHOUT
|
|
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
// License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#include <iostream>
|
|
#include "misc/intvcomp.hh"
|
|
#include <cstring>
|
|
|
|
int check_vv(int* data, int size, unsigned expected = 0)
|
|
{
|
|
|
|
std::vector<int> input;
|
|
input.reserve(size);
|
|
for (int i = 0; i < size; ++i)
|
|
input.push_back(data[i]);
|
|
|
|
std::vector<unsigned int> output;
|
|
spot::int_vector_vector_compress(input, output);
|
|
|
|
std::cout << "WC[" << output.size() << "] ";
|
|
for (size_t i = 0; i < output.size(); ++i)
|
|
std::cout << output[i] << ' ';
|
|
std::cout << '\n';
|
|
|
|
std::vector<int> decomp;
|
|
spot::int_vector_vector_decompress(output, decomp, size);
|
|
|
|
std::cout << "WD[" << decomp.size() << "] ";
|
|
for (size_t i = 0; i < decomp.size(); ++i)
|
|
std::cout << decomp[i] << ' ';
|
|
std::cout << '\n';
|
|
|
|
int res = (decomp != input);
|
|
|
|
if (res)
|
|
{
|
|
std::cout << "*** cmp error *** " << std::endl;
|
|
std::cout << "WE[" << size << "] ";
|
|
for (int i = 0; i < size; ++i)
|
|
std::cout << data[i] << ' ';
|
|
std::cout << '\n';
|
|
}
|
|
|
|
if (expected && (output.size() * sizeof(int) != expected))
|
|
{
|
|
std::cout << "*** size error *** (expected "
|
|
<< expected << " bytes, got " << output.size() * sizeof(int)
|
|
<< " bytes)" << std::endl;
|
|
res = 1;
|
|
}
|
|
|
|
std::cout << '\n';
|
|
|
|
return !!res;
|
|
}
|
|
|
|
int check_av(int* data, int size, unsigned expected = 0)
|
|
{
|
|
const std::vector<unsigned int>* v =
|
|
spot::int_array_vector_compress(data, size);
|
|
|
|
std::cout << "VC[" << v->size() << "] ";
|
|
for (size_t i = 0; i < v->size(); ++i)
|
|
std::cout << (*v)[i] << ' ';
|
|
std::cout << '\n';
|
|
|
|
int* decomp = new int[size];
|
|
spot::int_vector_array_decompress(v, decomp, size);
|
|
|
|
std::cout << "VD[" << size << "] ";
|
|
for (int i = 0; i < size; ++i)
|
|
std::cout << decomp[i] << ' ';
|
|
std::cout << '\n';
|
|
|
|
int res = memcmp(data, decomp, size * sizeof(int));
|
|
|
|
if (res)
|
|
{
|
|
std::cout << "*** cmp error *** " << res << std::endl;
|
|
std::cout << "VE[" << size << "] ";
|
|
for (int i = 0; i < size; ++i)
|
|
std::cout << data[i] << ' ';
|
|
std::cout << '\n';
|
|
}
|
|
|
|
if (expected && (v->size() * sizeof(int) != expected))
|
|
{
|
|
std::cout << "*** size error *** (expected "
|
|
<< expected << " bytes, got " << v->size() * sizeof(int)
|
|
<< " bytes)" << std::endl;
|
|
res = 1;
|
|
}
|
|
|
|
std::cout << '\n';
|
|
|
|
delete v;
|
|
delete[] decomp;
|
|
return !!res;
|
|
}
|
|
|
|
int check_aa(int* data, int size, unsigned expected = 0)
|
|
{
|
|
int* comp = new int[size *2];
|
|
size_t csize = size * 2;
|
|
spot::int_array_array_compress(data, size, comp, csize);
|
|
|
|
std::cout << "AC[" << csize << "] ";
|
|
for (size_t i = 0; i < csize; ++i)
|
|
std::cout << comp[i] << ' ';
|
|
std::cout << '\n';
|
|
|
|
int* decomp = new int[size];
|
|
spot::int_array_array_decompress(comp, csize, decomp, size);
|
|
|
|
std::cout << "AD[" << size << "] ";
|
|
for (int i = 0; i < size; ++i)
|
|
std::cout << decomp[i] << ' ';
|
|
std::cout << '\n';
|
|
|
|
int res = memcmp(data, decomp, size * sizeof(int));
|
|
|
|
if (res)
|
|
{
|
|
std::cout << "*** cmp error *** " << res << std::endl;
|
|
std::cout << "AE[" << size << "] ";
|
|
for (int i = 0; i < size; ++i)
|
|
std::cout << data[i] << ' ';
|
|
std::cout << '\n';
|
|
}
|
|
|
|
if (expected && (csize * sizeof(int) != expected))
|
|
{
|
|
std::cout << "*** size error *** (expected "
|
|
<< expected << " bytes, got " << csize * sizeof(int)
|
|
<< " bytes)" << std::endl;
|
|
res = 1;
|
|
}
|
|
|
|
std::cout << '\n';
|
|
|
|
delete[] comp;
|
|
delete[] decomp;
|
|
return !!res;
|
|
}
|
|
|
|
int check(int* comp, int size, unsigned expected = 0)
|
|
{
|
|
return
|
|
check_vv(comp, size, expected) +
|
|
check_av(comp, size, expected) +
|
|
check_aa(comp, size, expected);
|
|
}
|
|
|
|
int main()
|
|
{
|
|
int errors = 0;
|
|
|
|
int comp1[] = { 1, 0, 0, 0, 0, 0, 3, 3, 4, 0, 0, 0 };
|
|
errors += check(comp1, sizeof(comp1) / sizeof(*comp1));
|
|
|
|
int comp2[] = { 3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5, 8, 9, 7, 9, 3, 1 };
|
|
errors += check(comp2, sizeof(comp2) / sizeof(*comp2));
|
|
|
|
int comp3[] = { 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1,
|
|
0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 0,
|
|
0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1,
|
|
0, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 1,
|
|
0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0 };
|
|
errors += check(comp3, sizeof(comp3) / sizeof(*comp3));
|
|
|
|
int comp4[] = { 1, 2, 1, 2, 1, 2, 2, 0 }; // 32 bits
|
|
errors += check(comp4, sizeof(comp4) / sizeof(*comp4), 4);
|
|
|
|
int comp5[] = { 1, 2, 1, 2, 1, 2, 2, 0, 1, 2, 1, 2, 1, 2, 2, 0 }; // 64 bits
|
|
errors += check(comp5, sizeof(comp5) / sizeof(*comp5), 8);
|
|
|
|
int comp6[] = { 1, 2, 1, 2, 1, 2, 2, 0, 1, 2, 1, 2, 1, 2, 2, 0,
|
|
1, 2, 1, 2, 1, 2, 2, 0, 1, 2, 1, 2, 1, 2, 2, 0 }; // 128 bits
|
|
errors += check(comp6, sizeof(comp6) / sizeof(*comp6), 16);
|
|
|
|
int comp7[] = { -4, -8, -10, 3, 49, 50, 0, 20, 13 };
|
|
errors += check(comp7, sizeof(comp7) / sizeof(*comp7));
|
|
|
|
int comp8[] = { 4959, 6754, 8133, 10985, 11121, 14413, 17335, 20754,
|
|
21317, 30008, 30381, 33494, 34935, 41210, 41417 };
|
|
errors += check(comp8, sizeof(comp8) / sizeof(*comp8));
|
|
|
|
int comp9[] = { 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
|
|
errors += check(comp9, sizeof(comp9) / sizeof(*comp9));
|
|
|
|
int comp10[] = { 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 0, 0, 0,
|
|
0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0,
|
|
9, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 10,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 9 };
|
|
errors += check(comp10, sizeof(comp10) / sizeof(*comp10));
|
|
|
|
return errors;
|
|
}
|