/usr/include/dballe/msg/wr_exporters/common.h is in libdballe-dev 7.21-1build1.
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 | /*
* dballe/wr_exporter/common - Common infrastructure for wreport exporters
*
* Copyright (C) 2013--2015 ARPA-SIM <urpsim@smr.arpa.emr.it>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* Author: Enrico Zini <enrico@enricozini.com>
*/
#ifndef DBALLE_MSG_WREXPORTER_BASE_H
#define DBALLE_MSG_WREXPORTER_BASE_H
#include <dballe/msg/msg.h>
namespace wreport {
struct Subset;
struct Bulletin;
struct Var;
}
namespace dballe {
namespace msg {
namespace wr {
class ExporterModule
{
protected:
// Subset being written
wreport::Subset* subset;
const Msg* msg = 0;
const msg::Context* c_ana = 0;
const msg::Context* c_surface_instant = 0;
void add(wreport::Varcode code, const msg::Context* ctx, int shortcut) const;
void add(wreport::Varcode code, const msg::Context* ctx, wreport::Varcode srccode) const;
void add(wreport::Varcode code, const msg::Context* ctx) const;
void add(wreport::Varcode code, const wreport::Var* var) const;
public:
void init(const Msg& msg, wreport::Subset& subset);
void scan_context(const msg::Context& c);
void add_ecmwf_synop_head();
};
class CommonSynopExporter : public ExporterModule
{
protected:
const msg::Context* c_geopotential;
const msg::Context* c_thermo;
const msg::Context* c_tmax;
const msg::Context* c_tmin;
const msg::Context* c_prec1;
const msg::Context* c_prec2;
const msg::Context* c_prec24;
const msg::Context* c_cloud_cover;
const msg::Context* c_cloud_data[4];
const msg::Context* c_cloud_group[4];
const msg::Context* c_wind;
const msg::Context* c_gust1;
const msg::Context* c_gust2;
const msg::Context* c_visib;
const msg::Context* c_past_wtr;
const msg::Context* c_depth;
const msg::Context* c_swell_waves[2];
public:
const wreport::Var* v_press;
const wreport::Var* v_pressmsl;
const wreport::Var* v_pchange3;
const wreport::Var* v_pchange24;
const wreport::Var* v_ptend;
const wreport::Var* v_geopotential;
void init(const Msg& msg, wreport::Subset& subset);
void scan_context(const msg::Context& c);
// Pressure data
void add_D02001();
// synop: pressure data
void add_D02031();
// synop: temperature and humidity
void add_D02032();
// ship: temperature and humidity
void add_D02052();
// synop: extreme temperature data
void add_D02041();
// ship: extreme temperature data
void add_D02058();
void add_pressure();
void add_geopotential(wreport::Varcode code);
// Precipitation past 24 hours
void add_D02034();
// Precipitation measurement
void add_D02040();
// synop: wind data
void add_D02042();
// ship: wind data
void add_D02059();
// Present and past weather
void add_D02038();
void add_ecmwf_synop_weather();
// Basic synoptic "instantaneous" data
void add_D02035();
// Icing and ice
void add_D02055();
void add_ecmwf_ice();
// ship: visibility data
void add_D02053();
// Ship marine data
void add_D02056();
// Sea waves
void add_plain_waves();
// Ship waves (wind and swell)
void add_D02024();
/**
* Add B07032 sensor height, taking the value from the var attributes or
* the context, as appropriate.
*/
void add_sensor_height(const msg::Context& c, const wreport::Var* sample_var=NULL);
/**
* Add B07032 and B07033 sensor heights, taking the value from the var
* attributes or the context, as appropriate.
*/
void add_marine_sensor_height(const msg::Context& c, const wreport::Var* sample_var=NULL);
/**
* Add an extreme temperature group, with the measured value added with the
* given code, from temperature data found on the given context
*/
void add_xtemp_group(wreport::Varcode code, const msg::Context* c);
/**
* Add time period and total precipitation from the given context
*/
void add_prec_group(const msg::Context* c);
/**
* Add cloud data, as D02004 and a delayed replication of D02005
*/
void add_cloud_data();
/// Add a wind gust block with info from the given context
void add_wind_gust(const msg::Context* c);
/**
* Add a B04025 or B04025 time period variable, with data taken from its
* parameters as needed
*/
void add_time_period(wreport::Varcode code, const msg::Context& c, const wreport::Var* sample_var, const Trange& tr_std);
};
}
}
}
#endif
|