This file is indexed.

/usr/include/casacore/casa/OS/IBMConversion.h is in casacore-dev 2.2.0-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
//# IBMConversion.h: A class with static functions to convert IBM format
//# Copyright (C) 1996,1997,1999,2001
//# Associated Universities, Inc. Washington DC, USA.
//#
//# This library is free software; you can redistribute it and/or modify it
//# under the terms of the GNU Library General Public License as published by
//# the Free Software Foundation; either version 2 of the License, or (at your
//# option) any later version.
//#
//# This library 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 Library General Public
//# License for more details.
//#
//# You should have received a copy of the GNU Library General Public License
//# along with this library; if not, write to the Free Software Foundation,
//# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA.
//#
//# Correspondence concerning AIPS++ should be addressed as follows:
//#        Internet email: aips2-request@nrao.edu.
//#        Postal address: AIPS++ Project Office
//#                        National Radio Astronomy Observatory
//#                        520 Edgemont Road
//#                        Charlottesville, VA 22903-2475 USA
//#
//# $Id$

#ifndef CASA_IBMCONVERSION_H
#define CASA_IBMCONVERSION_H

//# Includes
#include <casacore/casa/aips.h>
#include <casacore/casa/OS/CanonicalConversion.h>


namespace casacore { //# NAMESPACE CASACORE - BEGIN

// Define the IBM sizes of the built-in data types.

#define SIZE_IBM_CHAR     1
#define SIZE_IBM_UCHAR    1
#define SIZE_IBM_SHORT    2
#define SIZE_IBM_USHORT   2
#define SIZE_IBM_INT      4
#define SIZE_IBM_UINT     4
#define SIZE_IBM_INT64    4
#define SIZE_IBM_UINT64   4
#define SIZE_IBM_FLOAT    4
#define SIZE_IBM_DOUBLE   8


// <summary>
// A class with static functions to convert IBM format
// </summary>

// <use visibility=export>

// <reviewed reviewer="Friso Olnon" date="1996/11/06" tests="tIBMConversion" demos="">
// </reviewed>

// <synopsis>
// This class contains static toLocal functions to convert data from IBM-360
// format to local format and vice-versa. It also handles the conversion
// of the IBM EBCDIC characters to ASCII characters (for data type char).
// <p>
// The functions work well on big-endian as well as little-endian machines.
// </synopsis>

// <motivation>
// Archived WSRT data can be stored in the old IBM format
// (EBCDIC characters and floats with base 16).
// Conversion functions are needed to read these data.
// </motivation>

// <todo asof="$DATE$">
//  <li> Support data type long double.
// </todo>


class IBMConversion
{
public:
    // Convert one value from IBM format to local format.
    // The from and to buffer should not overlap.
    // <note>
    // The char version converts from EBCDIC to ASCII, while the
    // unsigned char version is a simple copy.
    // </note>
    // <group>
    static void toLocal (char&           to, const void* from);
    static void toLocal (unsigned char&  to, const void* from);
    static void toLocal (short&          to, const void* from);
    static void toLocal (unsigned short& to, const void* from);
    static void toLocal (int&            to, const void* from);
    static void toLocal (unsigned int&   to, const void* from);
    static void toLocal (Int64&          to, const void* from);
    static void toLocal (uInt64&         to, const void* from);
    static void toLocal (float&          to, const void* from);
    static void toLocal (double&         to, const void* from);
    // </group>
    
    // Convert nr values from IBM format to local format.
    // The from and to buffer should not overlap.
    // <note>
    // The char version converts from EBCDIC to ASCII, while the
    // unsigned char version is a simple copy.
    // </note>
    // <group>
    static void toLocal (char*           to, const void* from,
			 size_t nr);
    static void toLocal (unsigned char*  to, const void* from,
			 size_t nr);
    static void toLocal (short*          to, const void* from,
			 size_t nr);
    static void toLocal (unsigned short* to, const void* from,
			 size_t nr);
    static void toLocal (int*            to, const void* from,
			 size_t nr);
    static void toLocal (unsigned int*   to, const void* from,
			 size_t nr);
    static void toLocal (Int64*          to, const void* from,
			 size_t nr);
    static void toLocal (uInt64*         to, const void* from,
			 size_t nr);
    static void toLocal (float*          to, const void* from,
			 size_t nr);
    static void toLocal (double*         to, const void* from,
			 size_t nr);
    // </group>

    // Convert one value from local format to IBM format.
    // The from and to buffer should not overlap.
    // <note>
    // The char version converts from ASCII to EBCDIC, while the
    // unsigned char version is a simple copy.
    // </note>
    // <group>
    static void fromLocal (void* to, char           from);
    static void fromLocal (void* to, unsigned char  from);
    static void fromLocal (void* to, short          from);
    static void fromLocal (void* to, unsigned short from);
    static void fromLocal (void* to, int            from);
    static void fromLocal (void* to, unsigned int   from);
    static void fromLocal (void* to, Int64          from);
    static void fromLocal (void* to, uInt64         from);
    static void fromLocal (void* to, float          from);
    static void fromLocal (void* to, double         from);
    // </group>
    
    // Convert nr values from local format to IBM format.
    // The from and to buffer should not overlap.
    // <note>
    // The char version converts from ASCII to EBCDIC, while the
    // unsigned char version is a simple copy.
    // </note>
    // <group>
    static void fromLocal (void* to, const char*           from,
			   size_t nr);
    static void fromLocal (void* to, const unsigned char*  from,
			   size_t nr);
    static void fromLocal (void* to, const short*          from,
			   size_t nr);
    static void fromLocal (void* to, const unsigned short* from,
			   size_t nr);
    static void fromLocal (void* to, const int*            from,
			   size_t nr);
    static void fromLocal (void* to, const unsigned int*   from,
			   size_t nr);
    static void fromLocal (void* to, const Int64*          from,
			   size_t nr);
    static void fromLocal (void* to, const uInt64*         from,
			   size_t nr);
    static void fromLocal (void* to, const float*          from,
			   size_t nr);
    static void fromLocal (void* to, const double*         from,
			   size_t nr);
    // </group>
    
private:
    // This class should not be constructed
    // (so declare the constructor private).
    IBMConversion();
};



inline void IBMConversion::toLocal (unsigned char& to, const void* from)
{
    CanonicalConversion::toLocal (to, from);
}

inline void IBMConversion::toLocal (short& to, const void* from)
{
    CanonicalConversion::toLocal (to, from);
}

inline void IBMConversion::toLocal (unsigned short& to, const void* from)
{
    CanonicalConversion::toLocal (to, from);
}

inline void IBMConversion::toLocal (int& to, const void* from)
{
    CanonicalConversion::toLocal (to, from);
}

inline void IBMConversion::toLocal (unsigned int& to, const void* from)
{
    CanonicalConversion::toLocal (to, from);
}

inline void IBMConversion::toLocal (Int64& to, const void* from)
{
    if (sizeof(Int64) != 4) {
	if (((signed char*)from)[0] < 0) {
	    to = -1;
	}else{
	    to = 0;
	}
    }
#if defined(AIPS_LITTLE_ENDIAN)
    CanonicalConversion::reverse4 (&to, from);
#else
    CanonicalConversion::move4 (((char*)&to)+sizeof(Int64)-4, from);
#endif
}

inline void IBMConversion::toLocal (uInt64& to, const void* from)
{
    if (sizeof(uInt64) != 4) {
	to = 0;
    }
#if defined(AIPS_LITTLE_ENDIAN)
    CanonicalConversion::reverse4 (&to, from);
#else
    CanonicalConversion::move4 (((char*)&to)+sizeof(uInt64)-4, from);
#endif
}

inline void IBMConversion::toLocal (float& to, const void* from)
{
    toLocal (&to, from, 1);
}

inline void IBMConversion::toLocal (double& to, const void* from)
{
    toLocal (&to, from, 1);
}

inline void IBMConversion::toLocal (unsigned char* to, const void* from,
				    size_t nr)
{
    CanonicalConversion::toLocal (to, from, nr);
}

inline void IBMConversion::toLocal (short* to, const void* from,
				    size_t nr)
{
    CanonicalConversion::toLocal (to, from, nr);
}

inline void IBMConversion::toLocal (unsigned short* to, const void* from,
				    size_t nr)
{
    CanonicalConversion::toLocal (to, from, nr);
}

inline void IBMConversion::toLocal (int* to, const void* from,
				    size_t nr)
{
    CanonicalConversion::toLocal (to, from, nr);
}

inline void IBMConversion::toLocal (unsigned int* to, const void* from,
				    size_t nr)
{
    CanonicalConversion::toLocal (to, from, nr);
}


inline void IBMConversion::fromLocal (void* to, unsigned char from)
{
    CanonicalConversion::fromLocal (to, from);
}

inline void IBMConversion::fromLocal (void* to, short from)
{
    CanonicalConversion::fromLocal (to, from);
}

inline void IBMConversion::fromLocal (void* to, unsigned short from)
{
    CanonicalConversion::fromLocal (to, from);
}

inline void IBMConversion::fromLocal (void* to, int from)
{
    CanonicalConversion::fromLocal (to, from);
}

inline void IBMConversion::fromLocal (void* to, unsigned int from)
{
    CanonicalConversion::fromLocal (to, from);
}

inline void IBMConversion::fromLocal (void* to, Int64 from)
{
#if defined(AIPS_LITTLE_ENDIAN)
    CanonicalConversion::reverse4 (to, &from);
#else
    CanonicalConversion::move4 (to, ((char*)&from)+sizeof(Int64)-4);
#endif
}

inline void IBMConversion::fromLocal (void* to, uInt64 from)
{
#if defined(AIPS_LITTLE_ENDIAN)
    CanonicalConversion::reverse4 (to, &from);
#else
    CanonicalConversion::move4 (to,((char*)&from)+sizeof(uInt64)-4);
#endif
}

inline void IBMConversion::fromLocal (void* to, float from)
{
    fromLocal (to, &from, 1);
}

inline void IBMConversion::fromLocal (void* to, double from)
{
    fromLocal (to, &from, 1);
}


inline void IBMConversion::fromLocal (void* to, const unsigned char* from,
				      size_t nr)
{ 
    CanonicalConversion::fromLocal (to, from, nr);
}

inline void IBMConversion::fromLocal (void* to, const short* from,
				      size_t nr)
{ 
    CanonicalConversion::fromLocal (to, from, nr);
}

inline void IBMConversion::fromLocal (void* to, const unsigned short* from,
				      size_t nr)
{ 
    CanonicalConversion::fromLocal (to, from, nr);
}

inline void IBMConversion::fromLocal (void* to, const int* from,
				      size_t nr)
{ 
    CanonicalConversion::fromLocal (to, from, nr);
}

inline void IBMConversion::fromLocal (void* to, const unsigned int* from,
				      size_t nr)
{ 
    CanonicalConversion::fromLocal (to, from, nr);
}




} //# NAMESPACE CASACORE - END

#endif