TF++, Miscellaneous classes and modules in C++:
tests/fortraniotest.cc

You will find and example for the module fortranio in tests/fortraniotest.cc and tests/fortranF77.f.

See also
tfxx::fortranio::FortranBinInput
tfxx::fortranio::FortranBinOutput
TEST: Fortran I/O and byte swapping.
FORTRAN I/O functions
#define FORTRANIOTEST_VERSION \
"FORTRANIOTEST V1.2 C++ part of the Fortran I/O test routines"
#include <iostream>
#include <cassert>
#include <tfxx/commandline.h>
#include <tfxx/fortranio.h>
#include <tfxx/complexio.h>
using std::cout;
using std::cerr;
using std::endl;
/*----------------------------------------------------------------------*/
template<class T>
void test_swap()
{
T v1,v2;
const int nbytes=sizeof(T);
char charpool[]="ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char charresult[26];
assert(nbytes<26);
for (int i=0; i<nbytes; i++)
{
u1.bytes[i]=charpool[i];
charresult[i]=charpool[i];
}
charresult[nbytes]='\0';
cout << "in: ";
cout.width(10);
cout << charresult;
// take the long way (using these types explicitely)
v1=u1.value;
u2.value=v2;
for (int i=0; i<nbytes; i++)
{
charresult[i]=u2.bytes[i];
}
charresult[nbytes]='\0';
cout << " out: ";
cout.width(12);
cout << charresult << endl;
}
#define SWAPIT( T ) \
cout.width(40); \
cout << " swap test with \'" #T "\': "; \
test_swap<T>();
void cpu_type()
{
switch (tfxx::ioswap::cpu()) {
cout << "We are running on an Intel type CPU" << endl;
break;
cout << "We are running on a Motorola type CPU" << endl;
break;
cout << "The type of this CPU is unknown" << endl;
break;
default:
cerr << "ERROR: illegal return value from " <<
"tfxx::ioswap::cpu()" << endl;
abort();
}
}
const char mymagic[]="ABCD";
void write_data(const std::string& name, const bool& verbose=false)
{
if (verbose) cout << "write data to \'" << name << "\'" << endl;
std::ofstream os(name.c_str());
const int nval=10;
fo << nval;
cout << "nval: " << nval << endl;
for (int i=0; i<nval; i++)
{
int val1=(i+1)*4;
int val2=100*val1;
fo << val1 << val2;
cout << " val1/2: " << val1 << ", " << val2 << endl;
}
fo.end_block();
for (int i=0; i<nval; i++)
{
double val=(i+1)*15.;
cout << " val: " << val << endl;
fo << val;
}
fo.end_block();
long long int llint=1551;
long int lint=2662;
std::complex<double> dcplx(4.5,5.4);
std::complex<float> scplx(14.5,15.4);
fo << llint << lint << dcplx << scplx;
cout << "extra: " << llint << ", " << lint << ", "
<< dcplx << ", " << scplx << endl;;
}
void read_data(const std::string& name, const bool& verbose=false)
{
if (verbose) cout << "read data from \'" << name << "\'" << endl;
std::ifstream is(name.c_str());
if (verbose) {
switch(match) {
cout << "Bytesex matches" << endl;
break;
cout << "Magic number found, byte data has to be swapped" << endl;
break;
cout << "Magic number not found" << endl;
break;
default:
cerr << "ERROR: illegal return value from " <<
"tfxx::ioswap::file_magic_test()" << endl;
break;
}
}
{
int nval;
fi >> nval;
cout << "nval: " << nval << endl;
for (int i=0; i<nval; i++)
{
int val1,val2;
fi >> val1 >> val2;
cout << " val1/2: " << val1 << ", " << val2 << endl;
}
for (int i=0; i<nval; i++)
{
double val;
fi >> val;
cout << " val: " << val << endl;
}
long long int llint;
long int lint;
std::complex<double> dcplx;
std::complex<float> scplx;
fi >> llint >> lint >> dcplx >> scplx;
cout << "extra: " << llint << ", " << lint << ", "
<< dcplx << ", " << scplx << endl;;
}
}
/*----------------------------------------------------------------------*/
int main(int iargc, char* argv[])
{
// define usage information
char usage_text[]=
{
"usage: fortraniotest [-v] [-c] [-s] [-C]" "\n"
" [-w [file]] [-r [file]]" "\n"
" or: fortraniotest --help|-h" "\n"
};
// define full help text
char help_text[]=
{
" " "\n"
"-v be verbose" "\n"
"-c check byte size of data types" "\n"
"-s test byte swapping" "\n"
"-C tell us about the CPU model" "\n"
"-w [file] write to file" "\n"
"-r [file] read from file" "\n"
FORTRANIOTEST_CVSID
};
// define commandline options
using namespace tfxx::cmdline;
static Declare options[]=
{
// 0: print help
{"help",arg_no,"-"},
// 1: verbose mode
{"v",arg_no,"-"},
// 2: check byte size
{"c",arg_no,"-"},
// 3: test byte swapping
{"s",arg_no,"-"},
// 4: tell about CPU
{"C",arg_no,"-"},
// 5: write to file
{"w",arg_opt,"junk"},
// 6: write to file
{"r",arg_opt,"junk"},
{NULL}
};
// no arguments? print usage...
if (iargc<2)
{
cerr << usage_text << endl;
exit(0);
}
// collect options from commandline
Commandline cmdline(iargc, argv, options);
// help requested? print full help text...
if (cmdline.optset(0))
{
cerr << usage_text << endl;
cerr << help_text << endl;
exit(0);
}
bool verbose=cmdline.optset(1);
bool check_size=cmdline.optset(2);
bool byte_swapping=cmdline.optset(3);
bool tell_CPU=cmdline.optset(4);
bool write_file=cmdline.optset(5);
std::string outfile=cmdline.string_arg(5);
bool read_file=cmdline.optset(6);
std::string infile=cmdline.string_arg(6);
if (verbose) { cout << FORTRANIOTEST_VERSION << endl << endl; }
if (check_size)
{
cout << "NOTICE: check_assumed_size() no longer exists!"
<< endl
<< " and the even better news: there is no need for it"
<< endl;
}
if (byte_swapping)
{
SWAPIT(char)
SWAPIT(int)
SWAPIT(long int)
SWAPIT(long long int)
SWAPIT(float)
SWAPIT(double)
}
if (tell_CPU) cpu_type();
if (write_file) write_data(outfile, verbose);
if (read_file) read_data(infile, verbose);
}
/* ----- END OF fortraniotest.cc ----- */