This file is indexed.

/usr/include/adios_read_ext.h is in libadios-dev 1.9.0-7build2.

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
/*
 * adios_read_ext.h
 *
 *  Created on: Apr 25, 2014
 *      Author: David A. Boyuka II
 */
#ifndef ADIOS_READ_EXT_H_
#define ADIOS_READ_EXT_H_

#ifdef ADIOS_USE_READ_API_1
#  error "Extended ADIOS Read API is not available in Read API v1"
#endif

#include <stdint.h>

#include "adios_read_v2.h"
#include "adios_selection.h"

/* An opaque type defining a particular view of the data.
 * Currently, there are only two possible values: LOGICAL_DATA_VIEW and PHYSICAL_DATA_VIEW 
 */
typedef const void* data_view_t;

/* LOGICAL_DATA_VIEW: the default, ADIOS presents the same view of the data as it was written to the
 *   file (e.g., if processes wrote to a 3D global array of doubles, the user API will present a 3D global
 *   array of doubles to the user when in this view mode).
 */
extern const data_view_t LOGICAL_DATA_VIEW;

/* PHYSICAL_DATA_VIEW: ADIOS will present the raw transport layer view of the data. If a variable is not
 *   transformed, its presentation is equivalent to that under LOGICAL_DATA_VIEW. If a variable is
 *   transformed, it will be presented as a 1D byte array, and reads will be answered directly from the
 *   transformed data with out any de-transformation applied.
 */
extern const data_view_t PHYSICAL_DATA_VIEW;

/* An identifier for a particular transform type (e.g., identity, zlib, etc.)
 * constant NO_TRANSFORM indicates the absence of any data transform being applied.
 */
typedef int adios_transform_type_t;

extern const adios_transform_type_t NO_TRANSFORM;

typedef struct {
	const void *content;
	uint64_t length;   /* in bytes */
} ADIOS_TRANSFORM_METADATA;

/* A transform information structure describing how a particular variable has been transformed */
typedef struct {
	int varid;       /* Copied from ADIOS_VARINFO, since it is needed for some ADIOS_VARTRANSFORM operations */
	int sum_nblocks; /* ... */

	adios_transform_type_t transform_type; /* The data transform applied to this variable */

	int should_free_transform_metadata; /* Used internally for free */

	/* An array of transform plugin-specific metadata buffers, one for each
       varblock in this file (number of varblocks == ADIOS_VARINFO.sum_nblocks).
	   Only needed by advanced applications requiring direct manipulation
	   of transformed data. */
	ADIOS_TRANSFORM_METADATA *transform_metadatas;
} ADIOS_VARTRANSFORM;



typedef struct {
	int timestep;
	int blockidx;
	int blockidx_in_timestep;
	ADIOS_SELECTION *pg_bounds_sel;    /* it is a global box (offset/start is global) */
	ADIOS_SELECTION *intersection_sel; /* it is a global box (offset/start is global) */
} ADIOS_PG_INTERSECTION ;


typedef struct {
	ADIOS_PG_INTERSECTION * intersections;
	int npg;
} ADIOS_PG_INTERSECTIONS;

#ifndef __INCLUDED_FROM_FORTRAN_API__

/* Sets the "data view" for this ADIOS file, which determines how ADIOS presents variables through
 * adios_inq_var*, and how reads are evaluated in adios_schedule_reads/adios_check_reads calls.
 * Currently, the choice is between a logical and physical view of the data, which only differ for
 * transformed variables; a logical view of a transformed variable presents the data as it was
 * originally written (this is the default), whereas a physical view presents the transformed data
 * as it actually exists on disk.
 * Returns the previous view that was set
 */
data_view_t adios_read_set_data_view(ADIOS_FILE *fp, data_view_t vt);

/* Populates data transform information about a given variable into an ADIOS_VARTRANSFORM struct
 * Return NULL if failed
 */
ADIOS_VARTRANSFORM *  adios_inq_var_transform(const ADIOS_FILE *fp, const ADIOS_VARINFO *varinfo);

/* Frees an ADIOS_VARTRANSFORM previous received from a call to adios_inq_var_transform */
void adios_free_var_transform(ADIOS_VARTRANSFORM *vartransform);

/* Returns the adios_transform_type_t constant for a data transformation method specified
 * by its unique ID, corresponding to the third argument in transforms/transform_plugins.h.
 * For example, to get ISOBAR's type constant:
 *
 * In transforms/transform_plugin.h:
 *   REGISTER_TRANSFORM_PLUGIN(isobar, "isobar", "ncsu-isobar", "ISOBAR compression")
 *                                               ^^^^^^^^^^^^^
 * const adios_transform_type_t ISOBAR_TTYPE = adios_get_transform_type_by_uid("ncsu-isobar");
 */
adios_transform_type_t adios_get_transform_type_by_uid(const char *transform_uid);

/* Creates a writeblock selection that only retrieves elements [start_elem, start_elem + num_elems)
 * within a variable. An element is a single value of whatever the varaible's datatype is (i.e.,
 * 1 element = 1 double if the variable type is double, 1 byte if the variable type is byte, etc.)
 */
ADIOS_SELECTION * adios_selection_writeblock_bounded(int index, uint64_t start_elem, uint64_t num_elems, int is_timestep_relative);

ADIOS_PG_INTERSECTIONS * adios_find_intersecting_pgs(
		const ADIOS_FILE *fp, int varid, const ADIOS_SELECTION *sel,
		const int from_step, const int nsteps);

int adios_get_absolute_writeblock_index(const ADIOS_VARINFO *varinfo, int timestep_relative_idx, int timestep);

void adios_free_pg_intersections(ADIOS_PG_INTERSECTIONS **intersections);

/* What is the dimension order of arrays in the file?
 * 0: C ordering (row-major), last dimension is the fastest dimension
 * 1: Fortran ordering (column-major), first dimension is the fastest dimension
 */
int adios_read_get_dimension_order (ADIOS_FILE *);

#endif  /*__INCLUDED_FROM_FORTRAN_API__*/

#endif /* ADIOS_READ_EXT_H_ */