52     for (
const auto &
s : labels) {
 
   65            bool desc, 
bool formulas)
 
   66     : fname(file), timeChunk(chunking),
 
   67       enableDescriptions(desc), enableFormula(formulas),
 
   73     H5::Exception::dontPrint();
 
   86                         dumpCount > 0 ? H5F_ACC_RDWR : H5F_ACC_TRUNC);
 
  115     } 
catch (
const H5::FileIException& 
e) {
 
  117     } 
catch (
const H5::GroupIException& 
e) {
 
  127     assert(!
path.empty());
 
  137     hsize_t fdims[1] = { 0, };
 
  152     warn_once(
"HDF5 stat files don't support distributions.\n");
 
  158     warn_once(
"HDF5 stat files don't support vector distributions.\n");
 
  167     hsize_t fdims[3] = { 0, info.
x, info.
y };
 
  168     H5::DataSet data_set = 
appendStat(info, 3, fdims, info.
cvec.data());
 
  197     warn_once(
"HDF5 stat files don't support sparse histograms.\n");
 
  207     hsize_t fdims[2] = { 0, vr.size() };
 
  208     H5::DataSet data_set = 
appendStat(info, 2, fdims, vr.data());
 
  224     H5::Group group = 
path.top();
 
  225     H5::DataSet data_set;
 
  226     H5::DataSpace fspace;
 
  233         data_set = group.openDataSet(info.
name);
 
  234         data_set.extend(dims);
 
  235         fspace = data_set.getSpace();
 
  239         H5::DSetCreatPropList props;
 
  243         std::copy(dims, dims + rank, max_dims.begin());
 
  244         max_dims[0] = H5S_UNLIMITED;
 
  248         std::copy(dims, dims + rank, chunk_dims.begin());
 
  250         props.setChunk(rank, chunk_dims.data());
 
  255         fspace = H5::DataSpace(rank, dims, max_dims.data());
 
  257             data_set = group.createDataSet(info.
name,
 
  258                 H5::PredType::NATIVE_DOUBLE, fspace, props);
 
  259         } 
catch (
const H5::Exception &
e) {
 
  260           std::string 
err = 
"Failed creating H5::DataSet " +  info.
name + 
"; ";
 
  261           err += 
e.getDetailMsg() + 
" in " + 
e.getFuncName();
 
  263           throw std::runtime_error(
err);
 
  273     H5::DataSpace mspace(rank, dims);
 
  277     fspace.selectHyperslab(H5S_SELECT_SET, dims, foffset.data());
 
  278     data_set.write(
data, H5::PredType::NATIVE_DOUBLE, mspace, fspace);
 
  287     H5::StrType 
type(H5::PredType::C_S1, H5T_VARIABLE);
 
  288     hsize_t dims[1] = { values.size(), };
 
  289     H5::DataSpace space(1, dims);
 
  290     H5::Attribute attribute = loc.createAttribute(
name, 
type, space);
 
  291     attribute.write(
type, values.data());
 
  299     for (
int i = 0; 
i < values.size(); ++
i)
 
  300         cstrs[
i] = values[
i].c_str();
 
  307                   const std::string &value)
 
  309     H5::StrType 
type(H5::PredType::C_S1, value.length() + 1);
 
  310     hsize_t dims[1] = { 1, };
 
  311     H5::DataSpace space(1, dims);
 
  312     H5::Attribute attribute = loc.createAttribute(
name, 
type, space);
 
  313     attribute.write(
type, value.c_str());
 
  319     hsize_t dims[1] = { 1, };
 
  320     H5::DataSpace space(1, dims);
 
  321     H5::Attribute attribute = loc.createAttribute(
 
  322         name, H5::PredType::NATIVE_DOUBLE, space);
 
  323     attribute.write(H5::PredType::NATIVE_DOUBLE, &value);
 
  327 std::unique_ptr<Output>
 
  328 initHDF5(
const std::string &filename, 
unsigned chunking,
 
  329          bool desc, 
bool formulas)
 
  331     return  std::unique_ptr<Output>(