BOSS 7.0.4
BESIII Offline Software System
Loading...
Searching...
No Matches
convert_ros.cxx File Reference
#include <fstream>
#include <iostream>
#include <cstdlib>
#include "eformat/old/eformat.h"
#include "eformat/write/eformat.h"
#include "eformat/eformat.h"

Go to the source code of this file.

Functions

int main (int argc, char **argv)
 

Variables

const size_t MAX_ROS_SIZE = 2500000
 

Detailed Description

Author
<a href="Andre.nosp@m..dos.nosp@m..Anjo.nosp@m.s@ce.nosp@m.rn.ch>Andr� Rabello dos ANJOS
Author
zhangy
Revision
1.1.1.1
Date
2009/06/19 07:35:41

This source code describes a small test program based on the eformat library. It will read a file containing ROS fragments in v2.4 format and convert the fragment into v3.0. The output is dumped to an output file.

Definition in file convert_ros.cxx.

Function Documentation

◆ main()

int main ( int  argc,
char **  argv 
)

Reads a file and check its validity (for the time being)

Definition at line 32 of file convert_ros.cxx.

33{
34 using namespace eformat;
35
36 if ( argc != 3 ) {
37 std::cerr << "usage: " << argv[0] << " <v2.4 file> <v3.0 file>"
38 << std::endl;
39 std::exit(1);
40 }
41
42 //open normally a file
43 std::fstream in(argv[1], std::ios::in|std::ios::binary);
44 if (!in) {
45 std::cerr << "File `" << argv[1] << "' does not exist?!" << std::endl;
46 std::exit(1);
47 }
48 //open normally a file
49 std::fstream out(argv[2], std::ios::out|std::ios::binary);
50 if (!out) {
51 std::cerr << "Cannot write to `" << argv[1] << "?!" << std::endl;
52 std::exit(1);
53 }
54
55 uint32_t* fragment = new uint32_t[MAX_ROS_SIZE];
56 uint32_t* nfragment = new uint32_t[MAX_ROS_SIZE];
57
58 while (true) {
59
60 if (!(next_fragment(in, fragment, MAX_ROS_SIZE*4))) break;
61 uint32_t l1id = 0;
62
63 old::ROSFragment ros(fragment);
64
65 try {
66 ros.check_tree();
67 }
68 catch (eformat::BadVersionIssue& ex) {
69 std::cerr << " !! WARNING: found ROS fragment with format version = "
70 << HEX(ex.current()) << std::endl;
71 if (ex.current() != MAJOR_DEFAULT_VERSION) {
72 std::cerr << " -> I cannot cope with this format. Skipping..."
73 << std::endl;
74 continue;
75 }
76 else {
77 std::cout << " -> ROS fragment will be simply copied..." << std::endl;
78 }
79 }
80 catch (eformat::Issue& ex) {
81 std::cerr << "Uncaught eformat issue: " << ex.what() << std::endl;
82 std::cerr << " -> Trying to continue..."
83 << std::endl;
84 continue;
85 }
86 catch (...) {
87 std::cerr << std::endl << "Uncaught unknown exception" << std::endl;
88 delete[] fragment;
89 delete[] nfragment;
90 std::exit(1);
91 }
92
93 try {
94 //if check is ok, print the lvl1 identifier
95 std::cout << "ROS #" << ros.lvl1_id() << " [" << HEX(ros.version())
96 << "] -> [" << HEX(0x03000000) << "]" << std::endl;
97 old::convert(fragment, nfragment, MAX_ROS_SIZE);
98 ROSFragment<const uint32_t*> nros(nfragment);
99 nros.check_tree();
100 l1id = nros.lvl1_id();
101 }
102 catch (eformat::Issue& ex) {
103 std::cerr << "Uncaught eformat issue: " << ex.what() << std::endl;
104 std::cerr << " -> Trying to continue..."
105 << std::endl;
106 continue;
107 std::exit(1);
108 }
109 catch (ers::Issue& ex) {
110 std::cerr << "Uncaught ERS issue: " << ex.what() << std::endl;
111 delete[] fragment;
112 delete[] nfragment;
113 std::exit(1);
114 }
115 catch (std::exception& ex) {
116 std::cerr << "Uncaught std exception: " << ex.what() << std::endl;
117 delete[] fragment;
118 delete[] nfragment;
119 std::exit(1);
120 }
121 catch (...) {
122 std::cerr << std::endl << "Uncaught unknown exception" << std::endl;
123 delete[] fragment;
124 delete[] nfragment;
125 std::exit(1);
126 }
127 out.write(reinterpret_cast<char*>(nfragment),
128 sizeof(uint32_t)*nfragment[1]);
129 //if check is ok, print the lvl1 identifier
130 std::cout << " -> (new) ROS fragment #" << l1id
131 << " converted, checked and saved."
132 << std::endl;
133 }
134
135 delete[] fragment;
136 delete[] nfragment;
137 return 0;
138}
const char * what() const
Human description message.
const size_t MAX_ROS_SIZE
Definition: convert_ros.cxx:27
uint32_t * next_fragment(std::fstream &fs, uint32_t *addr=0, size_t size=0)
Definition: util.cxx:22

Variable Documentation

◆ MAX_ROS_SIZE

const size_t MAX_ROS_SIZE = 2500000

The maximum event size, in words

Definition at line 27 of file convert_ros.cxx.

Referenced by main().