#include "config.h"

#ifndef HAVE_CMPH
int main() {
  return 0;
}
#else

#include <iostream>
#include "weights.h"
#include "fdict.h"

using namespace std;

int main(int argc, char** argv) {
  if (argc != 2) { cerr << "Usage: " << argv[0] << " file.mphf\n"; return 1; }
  FD::EnableHash(argv[1]);
  cerr << "Number of keys: " << FD::NumFeats() << endl;
  cerr << "LexFE = " << FD::Convert("LexFE") << endl;
  cerr << "LexEF = " << FD::Convert("LexEF") << endl;
  {
    vector<weight_t> v(FD::NumFeats());
    v[FD::Convert("LexFE")] = 1.0;
    v[FD::Convert("LexEF")] = 0.5;
    cerr << "Writing...\n";
    Weights::WriteToFile("weights.bin", v);
    cerr << "Done.\n";
  }
  {
    vector<weight_t> v(FD::NumFeats());
    cerr << "Reading...\n";
    Weights::InitFromFile("weights.bin", &v);
    cerr << "Done.\n";
    assert(v[FD::Convert("LexFE")] == 1.0);
    assert(v[FD::Convert("LexEF")] == 0.5);
  }
}

#endif