/usr/include/pbseq/hdf/HDFRegionsWriter.hpp is in libpbihdf-dev 0~20161219-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 | // Author: Yuan Li
#ifndef _HDF_REGIONS_WRITER_HPP_
#define _HDF_REGIONS_WRITER_HPP_
#include <string>
// pbdata/
#include "../pbdata/Enumerations.h"
#include "../pbdata/reads/RegionTable.hpp"
#include "HDFFile.hpp"
#include "HDFArray.hpp"
#include "HDF2DArray.hpp"
#include "HDFAtom.hpp"
#include "HDFWriterBase.hpp"
using namespace H5;
using namespace std;
class HDFRegionsWriter: public HDFWriterBase {
public:
/// \name Constructor and destructor
/// \{
/// \param[in] filename, hdf file name
/// \param[in] parentGroup, parent hdf group in hirarchy
HDFRegionsWriter(const std::string & filename,
HDFGroup & parentGroup,
const std::vector<std::string> & regionTypes = PacBio::AttributeValues::Regions::regiontypes);
~HDFRegionsWriter(void);
/// \}
private:
/// \name Private variables for hdf IO.
/// \{
HDFGroup & parentGroup_; //< parent hdf group
/// A vector of strings of region types for RegionTypeIndex to look up. Order matters!
std::vector<std::string> regionTypes_;
HDF2DArray<int> regionsArray_; //< HDF2DArray for writing regions to hdf
int curRow_; //< which row to write
static const int NCOLS = 5; //< number of columns in Regions table.
/// \brief Write attributes of the 'regions' group
bool WriteAttributes(void);
/// \}
public:
/// \name Method to write region annotations.
/// \{
/// \brief Append a vector of region annotations to 'regions'
/// \param[in] annotations - region annotations to append.
/// \returns true if succeeded.
bool Write(const std::vector<RegionAnnotation> &annotations);
/// \brief Append a region annotation to 'regions'
/// \param[in] annotation - region annotation to append
/// \returns true if succeeded.
bool Write(const RegionAnnotation &annotation);
void Flush(void);
void Close(void);
};
#endif
|