GRIB2Reader

Struct GRIB2Reader 

Source
pub struct GRIB2Reader {
    pub packets: RefCell<Vec<Grib2Sections>>,
    pub idxs: Vec<Grib2SectionLocations>,
}
Expand description

§GRIB2 Reader

§Description

This class reads a GRIB2 file and returns a list of GRIB2 products.

Implements the FeatureReader trait

§Usage

The methods you have access to:

Associated methods that are useful:

  • [fetch_gfs_data]: Fetch ATMOS or WAVE GFS data.
  • parsed_idx_from_url: Given an input URL pointing to an IDX file, parse the sections
  • parse_idx: Given an input string of an IDX file, parse the sections
use gistools::{parsers::{BufferReader, FeatureReader}, readers::{parse_idx, GRIB2Reader}};
use std::{fs, path::PathBuf};

let mut path = PathBuf::from(env!("CARGO_MANIFEST_DIR"));
path.push("tests/readers/grib2/fixtures/ref_sec0.gdas.t12z.pgrb2.1p00.anl.75r.grib2.txt");

// parse the .idx file and apply a filter that we only need 3 sections
let idx_data = fs::read_to_string(path).unwrap();
let sections = parse_idx(
    idx_data,
    vec![":DZDT:0.01 mb:".into(), ":TMP:0.4 mb:".into(), ":ABSV:0.4 mb:anl:".into()],
    None,
);

// grab the grib2 file itself building with the filtered IDX sections
let mut path = PathBuf::from(env!("CARGO_MANIFEST_DIR"));
path.push("tests/readers/grib2/fixtures/ref_sec0.gdas.t12z.pgrb2.1p00.anl.75r.grib2");
let bytes = std::fs::read(path.clone()).unwrap();
let grib2_reader = GRIB2Reader::from_idx(&BufferReader::from(bytes), sections);

let features: Vec<_> = grib2_reader.iter().collect();
assert_eq!(features.len(), 1);

§Parsing the entire grib file:

use gistools::{parsers::{BufferReader, FeatureReader}, readers::GRIB2Reader};
use std::{fs, path::PathBuf};

let mut path = PathBuf::from(env!("CARGO_MANIFEST_DIR"));
path.push("tests/readers/grib2/fixtures/ref_simple_packing.grib2");

let bytes = fs::read(path.clone()).unwrap();
let grib2_reader = GRIB2Reader::new(BufferReader::from(bytes).into(), vec![]);

let features: Vec<_> = grib2_reader.iter().collect();
assert_eq!(features.len(), 1);

Fields§

§packets: RefCell<Vec<Grib2Sections>>

The GRIB2 packets

§idxs: Vec<Grib2SectionLocations>

The list of section locations

Implementations§

Source§

impl GRIB2Reader

Source

pub fn new<T: Reader>( readers: GRIB2ReaderInput<T>, idxs: Vec<Grib2SectionLocations>, ) -> Self

Create a GRIB2Reader

§Parameters
  • readers: Reader(s) for entire GRIB file. If array, its grib chunks, otherwise it will be the entire file
  • idxs: The list of section locations we will be parsing
§Returns

A GRIB2Reader

Source

pub fn from_idx<T: Reader>( source: &T, idxs: Vec<Grib2SectionLocations>, ) -> GRIB2Reader

Create a GRIB2Reader from a .idx file

§Parameters
  • source: Either the http path to the .idx file or the entire GRIB file
  • idxs: The parsed .idx file with the locations of each section
§Returns

A GRIB2Reader of the specific sections

Source

pub fn get_data(&self) -> Option<VectorMultiPoint>

Get the Vector Point feature data

Source

pub fn get_feature(&self) -> Option<GRIB2VectorFeature>

Get the Vector Point feature

Trait Implementations§

Source§

impl Clone for GRIB2Reader

Source§

fn clone(&self) -> GRIB2Reader

Returns a duplicate of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for GRIB2Reader

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl FeatureReader<Vec<Grib2ProductDefinition>, Map<String, ValueType>, Map<String, ValueType>> for GRIB2Reader

A feature reader trait with a callback-based approach

Source§

type FeatureIterator<'a> = GRIB2Iterator<'a>

The Feature Reader should implement an iterator of some kind
Source§

fn iter(&self) -> Self::FeatureIterator<'_>

All readers have an iter function that returns a Iterator struct
Source§

fn par_iter( &self, _pool_size: usize, thread_id: usize, ) -> Self::FeatureIterator<'_>

All readers have a par_iter function that returns a ParallelIterator struct

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V