From 4f48a56469d2c226109745316cad4f21fa0f56ae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20Dr=C3=B6nner?= Date: Tue, 16 Jun 2020 15:48:13 +0200 Subject: [PATCH 1/6] editon="2018" + fmt --- Cargo.toml | 1 + examples/metadata.rs | 5 +- examples/rasterband.rs | 47 ++++--- examples/read_write_ogr.rs | 14 ++- examples/read_write_ogr_datetime.rs | 41 +++--- examples/write_ogr.rs | 4 +- gdal-sys/Cargo.toml | 3 +- gdal-sys/src/lib.rs | 2 - src/config.rs | 38 ++++-- src/errors.rs | 80 +++++++----- src/lib.rs | 8 -- src/metadata.rs | 36 ++++-- src/raster/dataset.rs | 95 ++++++-------- src/raster/driver.rs | 39 +++--- src/raster/mod.rs | 12 +- src/raster/rasterband.rs | 126 +++++++++---------- src/raster/tests.rs | 116 +++++++---------- src/raster/types.rs | 42 +++++-- src/raster/warp.rs | 30 ++--- src/spatial_ref/mod.rs | 4 +- src/spatial_ref/srs.rs | 94 ++++++++++---- src/spatial_ref/tests.rs | 64 ++++++---- src/utils.rs | 18 ++- src/vector/dataset.rs | 63 +++++----- src/vector/defn.rs | 46 +++---- src/vector/driver.rs | 29 ++--- src/vector/feature.rs | 189 ++++++++++++++++++---------- src/vector/gdal_to_geo.rs | 5 +- src/vector/geo_to_gdal.rs | 101 ++++++++++++--- src/vector/geometry.rs | 105 +++++++++------- src/vector/layer.rs | 64 ++++++---- src/vector/mod.rs | 21 ++-- src/vector/tests/convert_geo.rs | 2 +- src/vector/tests/mod.rs | 162 +++++++++++++++--------- src/version.rs | 4 +- 35 files changed, 991 insertions(+), 719 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 15303b48..4432a42e 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -9,6 +9,7 @@ authors = [ ] repository = "https://github.com/georust/gdal" documentation = "https://georust.github.io/gdal/" +edition = "2018" [features] bindgen = ["gdal-sys/bindgen"] diff --git a/examples/metadata.rs b/examples/metadata.rs index 27558f17..3816daa6 100644 --- a/examples/metadata.rs +++ b/examples/metadata.rs @@ -1,9 +1,9 @@ extern crate gdal; fn main() { - use std::path::Path; - use gdal::raster::dataset::Dataset; use gdal::metadata::Metadata; + use gdal::raster::dataset::Dataset; + use std::path::Path; let driver = gdal::raster::driver::Driver::get("mem").unwrap(); println!("driver description: {:?}", driver.description()); @@ -16,5 +16,4 @@ fn main() { let domain = "IMAGE_STRUCTURE"; let meta = dataset.metadata_item(key, domain); println!("domain: {:?} key: {:?} -> value: {:?}", domain, key, meta); - } diff --git a/examples/rasterband.rs b/examples/rasterband.rs index 3d8342e9..ddba86c0 100644 --- a/examples/rasterband.rs +++ b/examples/rasterband.rs @@ -1,26 +1,21 @@ -extern crate gdal; - -use std::path::Path; -use gdal::raster::{Dataset, RasterBand}; -use gdal::metadata::Metadata; - -fn main() { - - let path = Path::new("./fixtures/tinymarble.png"); - let dataset = Dataset::open(path).unwrap(); - println!("dataset description: {:?}", dataset.description()); - - let rasterband: RasterBand = dataset.rasterband(1).unwrap(); - println!("rasterband description: {:?}", rasterband.description()); - println!("rasterband no_data_value: {:?}", rasterband.no_data_value()); - println!("rasterband type: {:?}", rasterband.band_type()); - println!("rasterband scale: {:?}", rasterband.scale()); - println!("rasterband offset: {:?}", rasterband.offset()); - if let Ok(rv) = rasterband.read_as::( - (20, 30), - (2, 3), - (2, 3) - ) { - println!("{:?}", rv.data); - } -} +extern crate gdal; + +use gdal::metadata::Metadata; +use gdal::raster::{Dataset, RasterBand}; +use std::path::Path; + +fn main() { + let path = Path::new("./fixtures/tinymarble.png"); + let dataset = Dataset::open(path).unwrap(); + println!("dataset description: {:?}", dataset.description()); + + let rasterband: RasterBand = dataset.rasterband(1).unwrap(); + println!("rasterband description: {:?}", rasterband.description()); + println!("rasterband no_data_value: {:?}", rasterband.no_data_value()); + println!("rasterband type: {:?}", rasterband.band_type()); + println!("rasterband scale: {:?}", rasterband.scale()); + println!("rasterband offset: {:?}", rasterband.offset()); + if let Ok(rv) = rasterband.read_as::((20, 30), (2, 3), (2, 3)) { + println!("{:?}", rv.data); + } +} diff --git a/examples/read_write_ogr.rs b/examples/read_write_ogr.rs index 5e57375a..a3b963b0 100644 --- a/examples/read_write_ogr.rs +++ b/examples/read_write_ogr.rs @@ -1,17 +1,19 @@ extern crate gdal; -use std::fs; -use std::path::Path; use gdal::errors::Error; +use gdal::spatial_ref::{CoordTransform, SpatialRef}; use gdal::vector::*; -use gdal::spatial_ref::{SpatialRef, CoordTransform}; +use std::fs; +use std::path::Path; fn run() -> Result<(), Error> { let mut dataset_a = Dataset::open(Path::new("fixtures/roads.geojson"))?; let layer_a = dataset_a.layer(0)?; - let fields_defn = layer_a.defn().fields() - .map(|field| (field.name(), field.field_type(), field.width())) - .collect::>(); + let fields_defn = layer_a + .defn() + .fields() + .map(|field| (field.name(), field.field_type(), field.width())) + .collect::>(); // Create a new dataset: let _ = fs::remove_file("/tmp/abcde.shp"); diff --git a/examples/read_write_ogr_datetime.rs b/examples/read_write_ogr_datetime.rs index 46b42ba0..de6112f0 100644 --- a/examples/read_write_ogr_datetime.rs +++ b/examples/read_write_ogr_datetime.rs @@ -1,15 +1,10 @@ - -extern crate gdal; #[cfg(feature = "datetime")] extern crate chrono; +extern crate gdal; -use std::path::Path; -use gdal::errors::Error; -use gdal::vector::*; -use std::fs; #[cfg(feature = "datetime")] use chrono::Duration; -use std::ops::Add; +use gdal::errors::Error; #[cfg(feature = "datetime")] fn run() -> Result<(), Error> { @@ -38,22 +33,24 @@ fn run() -> Result<(), Error> { let mut ft = Feature::new(&defn)?; ft.set_geometry(feature_a.geometry().clone())?; // copy each field value of the feature: - for field in defn.fields() { - ft.set_field(&field.name(), &match feature_a.field(&field.name())? { + for field in defn.fields() { + ft.set_field( + &field.name(), + &match feature_a.field(&field.name())? { + // add one day to dates + FieldValue::DateValue(value) => { + println!("{} = {}", field.name(), value); + FieldValue::DateValue(value.add(Duration::days(1))) + } - // add one day to dates - FieldValue::DateValue(value) => { - println!("{} = {}", field.name(), value); - FieldValue::DateValue(value.add(Duration::days(1))) + // add 6 hours to datetimes + FieldValue::DateTimeValue(value) => { + println!("{} = {}", field.name(), value); + FieldValue::DateTimeValue(value.add(Duration::hours(6))) + } + v => v, }, - - // add 6 hours to datetimes - FieldValue::DateTimeValue(value) => { - println!("{} = {}", field.name(), value); - FieldValue::DateTimeValue(value.add(Duration::hours(6))) - }, - v => v - })?; + )?; } // Add the feature to the layer: ft.create(lyr)?; @@ -67,8 +64,6 @@ fn run() -> Result<(), Error> { Ok(()) } - fn main() { run().unwrap(); } - diff --git a/examples/write_ogr.rs b/examples/write_ogr.rs index f6fbebf5..fa43a5d5 100644 --- a/examples/write_ogr.rs +++ b/examples/write_ogr.rs @@ -1,9 +1,9 @@ extern crate gdal; -use std::path::Path; -use std::fs; use gdal::errors::Error; use gdal::vector::{Defn, Driver, Feature, FieldDefn, FieldValue, Geometry, OGRFieldType}; +use std::fs; +use std::path::Path; /// Example 1, the detailed way: fn example_1() -> Result<(), Error> { diff --git a/gdal-sys/Cargo.toml b/gdal-sys/Cargo.toml index 3ecaad71..294d2257 100644 --- a/gdal-sys/Cargo.toml +++ b/gdal-sys/Cargo.toml @@ -5,6 +5,7 @@ license = "MIT" version = "0.2.4" repository = "https://github.com/georust/gdal" authors = ["Johannes Drönner "] +edition = "2018" [features] default = ["min_gdal_version_1_11"] @@ -19,5 +20,5 @@ min_gdal_version_2_4 = [] libc = "0.2" [build-dependencies] -bindgen = { version = "0.48", optional = true } +bindgen = { version = "0.54", optional = true } pkg-config = "0.3" diff --git a/gdal-sys/src/lib.rs b/gdal-sys/src/lib.rs index 19ec424d..a38a13a8 100644 --- a/gdal-sys/src/lib.rs +++ b/gdal-sys/src/lib.rs @@ -2,6 +2,4 @@ #![allow(non_camel_case_types)] #![allow(non_snake_case)] -extern crate libc; - include!(concat!(env!("OUT_DIR"), "/bindings.rs")); diff --git a/src/config.rs b/src/config.rs index dcffd6d7..292d4dda 100644 --- a/src/config.rs +++ b/src/config.rs @@ -23,10 +23,10 @@ //! Refer to [GDAL `ConfigOptions`](https://trac.osgeo.org/gdal/wiki/ConfigOptions) for //! a full list of options. -use std::ffi::CString; -use utils::_string; +use crate::errors::Result; +use crate::utils::_string; use gdal_sys; -use errors::*; +use std::ffi::CString; /// Set a GDAL library configuration option /// @@ -36,7 +36,9 @@ use errors::*; pub fn set_config_option(key: &str, value: &str) -> Result<()> { let c_key = CString::new(key.as_bytes())?; let c_val = CString::new(value.as_bytes())?; - unsafe { gdal_sys::CPLSetConfigOption(c_key.as_ptr(), c_val.as_ptr()); }; + unsafe { + gdal_sys::CPLSetConfigOption(c_key.as_ptr(), c_val.as_ptr()); + }; Ok(()) } @@ -59,7 +61,9 @@ pub fn get_config_option(key: &str, default: &str) -> Result { /// a full list of options. pub fn clear_config_option(key: &str) -> Result<()> { let c_key = CString::new(key.as_bytes())?; - unsafe { gdal_sys::CPLSetConfigOption(c_key.as_ptr(), ::std::ptr::null()); }; + unsafe { + gdal_sys::CPLSetConfigOption(c_key.as_ptr(), ::std::ptr::null()); + }; Ok(()) } @@ -70,9 +74,15 @@ mod tests { #[test] fn test_set_get_option() { - assert!(set_config_option("GDAL_CACHEMAX","128").is_ok()); - assert_eq!(get_config_option("GDAL_CACHEMAX", "").unwrap_or("".to_string()), "128"); - assert_eq!(get_config_option("NON_EXISTANT_OPTION", "DEFAULT_VALUE").unwrap_or("".to_string()), "DEFAULT_VALUE"); + assert!(set_config_option("GDAL_CACHEMAX", "128").is_ok()); + assert_eq!( + get_config_option("GDAL_CACHEMAX", "").unwrap_or("".to_string()), + "128" + ); + assert_eq!( + get_config_option("NON_EXISTANT_OPTION", "DEFAULT_VALUE").unwrap_or("".to_string()), + "DEFAULT_VALUE" + ); } #[test] @@ -84,9 +94,15 @@ mod tests { #[test] fn test_clear_option() { - assert!(set_config_option("TEST_OPTION","256").is_ok()); - assert_eq!(get_config_option("TEST_OPTION", "DEFAULT").unwrap_or("".to_string()), "256"); + assert!(set_config_option("TEST_OPTION", "256").is_ok()); + assert_eq!( + get_config_option("TEST_OPTION", "DEFAULT").unwrap_or("".to_string()), + "256" + ); assert!(clear_config_option("TEST_OPTION").is_ok()); - assert_eq!(get_config_option("TEST_OPTION", "DEFAULT").unwrap_or("".to_string()), "DEFAULT"); + assert_eq!( + get_config_option("TEST_OPTION", "DEFAULT").unwrap_or("".to_string()), + "DEFAULT" + ); } } diff --git a/src/errors.rs b/src/errors.rs index 078bc7cf..311291d9 100644 --- a/src/errors.rs +++ b/src/errors.rs @@ -1,8 +1,8 @@ -use libc::{c_int}; +use libc::c_int; use std::{self, fmt, result}; +use failure::{Backtrace, Context, Fail}; use gdal_sys::{CPLErr, OGRErr, OGRFieldType}; -use failure::{Context, Fail, Backtrace}; pub type Result = result::Result; @@ -13,7 +13,6 @@ pub struct Error { #[derive(Clone, PartialEq, Debug, Fail)] pub enum ErrorKind { - #[fail(display = "FfiNulError")] FfiNulError(#[cause] std::ffi::NulError), #[fail(display = "StrUtf8Error")] @@ -21,54 +20,69 @@ pub enum ErrorKind { #[cfg(feature = "ndarray")] #[fail(display = "NdarrayShapeError")] NdarrayShapeError(#[cause] ndarray::ShapeError), - #[fail(display = "CPL error class: '{:?}', error number: '{}', error msg: '{}'", class, number, msg)] + #[fail( + display = "CPL error class: '{:?}', error number: '{}', error msg: '{}'", + class, number, msg + )] CplError { class: CPLErr::Type, number: c_int, - msg: String + msg: String, }, - #[fail(display ="GDAL method '{}' returned a NULL pointer. Error msg: '{}'", method_name, msg)] + #[fail( + display = "GDAL method '{}' returned a NULL pointer. Error msg: '{}'", + method_name, msg + )] NullPointer { method_name: &'static str, - msg: String + msg: String, }, #[fail(display = "Can't cast to f64")] CastToF64Error, - #[fail(display ="OGR method '{}' returned error: '{:?}'", method_name, err)] + #[fail(display = "OGR method '{}' returned error: '{:?}'", method_name, err)] OgrError { err: OGRErr::Type, - method_name: &'static str + method_name: &'static str, }, - #[fail(display ="Unhandled type {:?} on OGR method {}", field_type, method_name)] + #[fail( + display = "Unhandled type {:?} on OGR method {}", + field_type, method_name + )] UnhandledFieldType { field_type: OGRFieldType::Type, - method_name: &'static str + method_name: &'static str, }, - #[fail(display ="Invalid field name '{}' used on method {}", field_name, method_name)] + #[fail( + display = "Invalid field name '{}' used on method {}", + field_name, method_name + )] InvalidFieldName { field_name: String, - method_name: &'static str + method_name: &'static str, }, - #[fail(display ="Invalid field index {} used on method {}", index, method_name)] + #[fail( + display = "Invalid field index {} used on method {}", + index, method_name + )] InvalidFieldIndex { index: usize, - method_name: &'static str - }, - #[fail(display ="Unlinked Geometry on method {}", method_name)] - UnlinkedGeometry { - method_name: &'static str + method_name: &'static str, }, - #[fail(display ="Invalid coordinate range while transforming points from {} to {}: {:?}", from, to, msg)] + #[fail(display = "Unlinked Geometry on method {}", method_name)] + UnlinkedGeometry { method_name: &'static str }, + #[fail( + display = "Invalid coordinate range while transforming points from {} to {}: {:?}", + from, to, msg + )] InvalidCoordinateRange { from: String, to: String, - msg: Option - } - + msg: Option, + }, } impl Fail for Error { - fn cause(&self) -> Option<&Fail> { + fn cause(&self) -> Option<&dyn Fail> { self.inner.cause() } @@ -91,7 +105,9 @@ impl Error { impl From for Error { fn from(kind: ErrorKind) -> Error { - Error { inner: Context::new(kind) } + Error { + inner: Context::new(kind), + } } } @@ -103,19 +119,25 @@ impl From> for Error { impl From for Error { fn from(err: std::ffi::NulError) -> Error { - Error { inner: Context::new(ErrorKind::FfiNulError(err)) } + Error { + inner: Context::new(ErrorKind::FfiNulError(err)), + } } } impl From for Error { fn from(err: std::str::Utf8Error) -> Error { - Error { inner: Context::new(ErrorKind::StrUtf8Error(err)) } + Error { + inner: Context::new(ErrorKind::StrUtf8Error(err)), + } } } #[cfg(feature = "ndarray")] impl From for Error { fn from(err: ndarray::ShapeError) -> Error { - Error { inner: Context::new(ErrorKind::NdarrayShapeError(err)) } + Error { + inner: Context::new(ErrorKind::NdarrayShapeError(err)), + } } -} \ No newline at end of file +} diff --git a/src/lib.rs b/src/lib.rs index 30802b60..012c47ee 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -20,14 +20,6 @@ #![crate_name = "gdal"] #![crate_type = "lib"] -extern crate failure; -#[macro_use] -extern crate failure_derive; -extern crate gdal_sys; -extern crate geo_types; -extern crate libc; -extern crate num_traits; - #[cfg(feature = "ndarray")] extern crate ndarray; diff --git a/src/metadata.rs b/src/metadata.rs index 8e90d672..d76a189d 100644 --- a/src/metadata.rs +++ b/src/metadata.rs @@ -1,14 +1,12 @@ -use utils::{_string}; -use std::ffi::{CString}; -use gdal_major_object::MajorObject; -use utils::{_last_cpl_err, _last_null_pointer_err}; -use errors::*; +use crate::errors::*; +use crate::gdal_major_object::MajorObject; +use crate::utils::{_last_cpl_err, _last_null_pointer_err, _string}; use gdal_sys::{self, CPLErr}; +use std::ffi::CString; pub trait Metadata: MajorObject { - - fn description(&self) -> Result{ - let c_res = unsafe { gdal_sys::GDALGetDescription(self.gdal_object_ptr())}; + fn description(&self) -> Result { + let c_res = unsafe { gdal_sys::GDALGetDescription(self.gdal_object_ptr()) }; if c_res.is_null() { Err(_last_null_pointer_err("GDALGetDescription"))?; } @@ -17,8 +15,14 @@ pub trait Metadata: MajorObject { fn metadata_item(&self, key: &str, domain: &str) -> Option { if let Ok(c_key) = CString::new(key.to_owned()) { - if let Ok(c_domain) = CString::new(domain.to_owned()){ - let c_res = unsafe { gdal_sys::GDALGetMetadataItem(self.gdal_object_ptr(), c_key.as_ptr(), c_domain.as_ptr())}; + if let Ok(c_domain) = CString::new(domain.to_owned()) { + let c_res = unsafe { + gdal_sys::GDALGetMetadataItem( + self.gdal_object_ptr(), + c_key.as_ptr(), + c_domain.as_ptr(), + ) + }; if !c_res.is_null() { return Some(_string(c_res)); } @@ -30,13 +34,19 @@ pub trait Metadata: MajorObject { fn set_metadata_item(&mut self, key: &str, value: &str, domain: &str) -> Result<()> { let c_key = CString::new(key.to_owned())?; let c_domain = CString::new(domain.to_owned())?; - let c_value = CString::new(value.to_owned())?; + let c_value = CString::new(value.to_owned())?; - let c_res = unsafe { gdal_sys::GDALSetMetadataItem(self.gdal_object_ptr(), c_key.as_ptr(), c_value.as_ptr(), c_domain.as_ptr())}; + let c_res = unsafe { + gdal_sys::GDALSetMetadataItem( + self.gdal_object_ptr(), + c_key.as_ptr(), + c_value.as_ptr(), + c_domain.as_ptr(), + ) + }; if c_res != CPLErr::CE_None { Err(_last_cpl_err(c_res))?; } Ok(()) } - } diff --git a/src/raster/dataset.rs b/src/raster/dataset.rs index c67d3aa5..92752628 100644 --- a/src/raster/dataset.rs +++ b/src/raster/dataset.rs @@ -1,19 +1,19 @@ -use libc::{c_int, c_double}; -use std::ffi::{CString}; +use crate::gdal_major_object::MajorObject; +use crate::metadata::Metadata; +use crate::raster::driver::_register_drivers; +use crate::raster::types::GdalType; +use crate::raster::{Driver, RasterBand}; +use crate::utils::{_last_cpl_err, _last_null_pointer_err, _string}; +use gdal_sys::{self, CPLErr, GDALAccess, GDALDataType, GDALDatasetH, GDALMajorObjectH}; +use libc::{c_double, c_int}; +use std::ffi::CString; use std::path::Path; use std::ptr::null_mut; -use utils::{_string, _last_cpl_err, _last_null_pointer_err}; -use raster::{Driver, RasterBand}; -use raster::driver::_register_drivers; -use raster::types::GdalType; -use gdal_major_object::MajorObject; -use metadata::Metadata; -use gdal_sys::{self, CPLErr, GDALAccess, GDALDatasetH, GDALDataType, GDALMajorObjectH}; #[cfg(feature = "ndarray")] use ndarray::Array2; -use errors::*; +use crate::errors::*; pub type GeoTransform = [c_double; 6]; @@ -31,7 +31,9 @@ impl Metadata for Dataset {} impl Drop for Dataset { fn drop(&mut self) { - unsafe { gdal_sys::GDALClose(self.c_dataset); } + unsafe { + gdal_sys::GDALClose(self.c_dataset); + } } } @@ -44,7 +46,7 @@ impl Dataset { if c_dataset.is_null() { Err(_last_null_pointer_err("GDALOpen"))?; } - Ok(Dataset{c_dataset}) + Ok(Dataset { c_dataset }) } pub unsafe fn _with_c_ptr(c_dataset: GDALDatasetH) -> Dataset { @@ -97,7 +99,7 @@ impl Dataset { _string(rv) } - pub fn set_projection(&self, projection: &str) -> Result<()>{ + pub fn set_projection(&self, projection: &str) -> Result<()> { let c_projection = CString::new(projection)?; unsafe { gdal_sys::GDALSetProjection(self.c_dataset, c_projection.as_ptr()) }; Ok(()) @@ -137,12 +139,8 @@ impl Dataset { /// height of a pixel (y-resolution, typically negative) pub fn geo_transform(&self) -> Result { let mut transformation = GeoTransform::default(); - let rv = unsafe { - gdal_sys::GDALGetGeoTransform( - self.c_dataset, - transformation.as_mut_ptr() - ) - }; + let rv = + unsafe { gdal_sys::GDALGetGeoTransform(self.c_dataset, transformation.as_mut_ptr()) }; // check if the dataset has a GeoTransform if rv != CPLErr::CE_None { @@ -151,25 +149,23 @@ impl Dataset { Ok(transformation) } - pub fn create_copy( - &self, - driver: &Driver, - filename: &str - ) -> Result { + pub fn create_copy(&self, driver: &Driver, filename: &str) -> Result { let c_filename = CString::new(filename)?; - let c_dataset = unsafe { gdal_sys::GDALCreateCopy( + let c_dataset = unsafe { + gdal_sys::GDALCreateCopy( driver._c_ptr(), c_filename.as_ptr(), self.c_dataset, 0, null_mut(), None, - null_mut() - ) }; + null_mut(), + ) + }; if c_dataset.is_null() { Err(_last_null_pointer_err("GDALCreateCopy"))?; } - Ok(Dataset{c_dataset}) + Ok(Dataset { c_dataset }) } pub fn band_type(&self, band_index: isize) -> Result { @@ -182,29 +178,20 @@ impl Dataset { /// * window - the window position from top left /// * window_size - the window size (GDAL will interpolate data if window_size != buffer_size) /// * buffer_size - the desired size of the 'Buffer' - pub fn read_raster(&self, + pub fn read_raster( + &self, band_index: isize, window: (isize, isize), window_size: (usize, usize), - size: (usize, usize) - ) -> Result - { - self.read_raster_as::( - band_index, - window, - window_size, - size - ) + size: (usize, usize), + ) -> Result { + self.read_raster_as::(band_index, window, window_size, size) } /// Read a full 'Dataset' as 'Buffer'. /// # Arguments /// * band_index - the band_index - pub fn read_full_raster_as( - &self, - band_index: isize, - ) -> Result> - { + pub fn read_full_raster_as(&self, band_index: isize) -> Result> { self.rasterband(band_index)?.read_band_as() } @@ -220,9 +207,9 @@ impl Dataset { window: (isize, isize), window_size: (usize, usize), size: (usize, usize), - ) -> Result> - { - self.rasterband(band_index)?.read_as(window, window_size, size) + ) -> Result> { + self.rasterband(band_index)? + .read_as(window, window_size, size) } #[cfg(feature = "ndarray")] @@ -238,9 +225,9 @@ impl Dataset { window: (isize, isize), window_size: (usize, usize), array_size: (usize, usize), - ) -> Result> - { - self.rasterband(band_index)?.read_as_array(window, window_size, array_size) + ) -> Result> { + self.rasterband(band_index)? + .read_as_array(window, window_size, array_size) } /// Write a 'Buffer' into a 'Dataset'. @@ -248,16 +235,16 @@ impl Dataset { /// * band_index - the band_index /// * window - the window position from top left /// * window_size - the window size (GDAL will interpolate data if window_size != Buffer.size) - pub fn write_raster( + pub fn write_raster( &self, band_index: isize, window: (isize, isize), window_size: (usize, usize), - buffer: &Buffer + buffer: &Buffer, ) -> Result<()> { - self.rasterband(band_index)?.write(window, window_size, buffer) + self.rasterband(band_index)? + .write(window, window_size, buffer) } - } pub struct Buffer { @@ -267,7 +254,7 @@ pub struct Buffer { impl Buffer { pub fn new(size: (usize, usize), data: Vec) -> Buffer { - Buffer{size, data} + Buffer { size, data } } } diff --git a/src/raster/driver.rs b/src/raster/driver.rs index 1843b0ad..ff8df5f9 100644 --- a/src/raster/driver.rs +++ b/src/raster/driver.rs @@ -1,17 +1,17 @@ +use crate::gdal_major_object::MajorObject; +use crate::metadata::Metadata; +use crate::raster::types::GdalType; +use crate::raster::Dataset; +use crate::utils::{_last_null_pointer_err, _string}; +use gdal_sys::{self, GDALDriverH, GDALMajorObjectH}; use libc::c_int; use std::ffi::CString; use std::ptr::null_mut; -use std::sync::{Once, ONCE_INIT}; -use utils::{_string, _last_null_pointer_err}; -use raster::Dataset; -use raster::types::GdalType; -use gdal_major_object::MajorObject; -use metadata::Metadata; -use gdal_sys::{self, GDALDriverH, GDALMajorObjectH}; +use std::sync::Once; -use errors::*; +use crate::errors::*; -static START: Once = ONCE_INIT; +static START: Once = Once::new(); pub fn _register_drivers() { unsafe { @@ -21,13 +21,11 @@ pub fn _register_drivers() { } } - #[allow(missing_copy_implementations)] pub struct Driver { c_driver: GDALDriverH, } - impl Driver { pub fn get(name: &str) -> Result { _register_drivers(); @@ -36,7 +34,7 @@ impl Driver { if c_driver.is_null() { Err(_last_null_pointer_err("GDALGetDriverByName"))?; }; - Ok(Driver{c_driver}) + Ok(Driver { c_driver }) } pub unsafe fn _with_c_ptr(c_driver: GDALDriverH) -> Driver { @@ -62,14 +60,9 @@ impl Driver { filename: &str, size_x: isize, size_y: isize, - bands: isize + bands: isize, ) -> Result { - self.create_with_band_type::( - filename, - size_x, - size_y, - bands, - ) + self.create_with_band_type::(filename, size_x, size_y, bands) } pub fn create_with_band_type( @@ -80,15 +73,17 @@ impl Driver { bands: isize, ) -> Result { let c_filename = CString::new(filename)?; - let c_dataset = unsafe { gdal_sys::GDALCreate( + let c_dataset = unsafe { + gdal_sys::GDALCreate( self.c_driver, c_filename.as_ptr(), size_x as c_int, size_y as c_int, bands as c_int, T::gdal_type(), - null_mut() - ) }; + null_mut(), + ) + }; if c_dataset.is_null() { Err(_last_null_pointer_err("GDALCreate"))?; }; diff --git a/src/raster/mod.rs b/src/raster/mod.rs index 6378778b..a8a1a6cd 100644 --- a/src/raster/mod.rs +++ b/src/raster/mod.rs @@ -1,15 +1,15 @@ //! GDAL Raster Data -pub use raster::dataset::{Dataset, Buffer, ByteBuffer}; -pub use raster::driver::Driver; -pub use raster::warp::reproject; -pub use raster::rasterband::{RasterBand}; +pub use crate::raster::dataset::{Buffer, ByteBuffer, Dataset}; +pub use crate::raster::driver::Driver; +pub use crate::raster::rasterband::RasterBand; +pub use crate::raster::warp::reproject; -pub mod types; pub mod dataset; pub mod driver; -pub mod warp; pub mod rasterband; +pub mod types; +pub mod warp; #[cfg(test)] mod tests; diff --git a/src/raster/rasterband.rs b/src/raster/rasterband.rs index c25d0854..067a77c0 100644 --- a/src/raster/rasterband.rs +++ b/src/raster/rasterband.rs @@ -1,28 +1,31 @@ +use crate::gdal_major_object::MajorObject; +use crate::metadata::Metadata; +use crate::raster::types::GdalType; +use crate::raster::{Buffer, Dataset}; +use crate::utils::_last_cpl_err; +use gdal_sys::{self, CPLErr, GDALDataType, GDALMajorObjectH, GDALRWFlag, GDALRasterBandH}; use libc::c_int; -use raster::{Dataset, Buffer}; -use raster::types::GdalType; -use gdal_major_object::MajorObject; -use metadata::Metadata; -use gdal_sys::{self, CPLErr, GDALDataType, GDALMajorObjectH, GDALRasterBandH, GDALRWFlag}; -use utils::_last_cpl_err; #[cfg(feature = "ndarray")] -use ndarray::{Array2}; +use ndarray::Array2; -use errors::*; +use crate::errors::*; pub struct RasterBand<'a> { c_rasterband: GDALRasterBandH, owning_dataset: &'a Dataset, } -impl <'a> RasterBand<'a> { +impl<'a> RasterBand<'a> { pub fn owning_dataset(&self) -> &'a Dataset { self.owning_dataset } pub unsafe fn _with_c_ptr(c_rasterband: GDALRasterBandH, owning_dataset: &'a Dataset) -> Self { - RasterBand { c_rasterband, owning_dataset } + RasterBand { + c_rasterband, + owning_dataset, + } } /// Get block size from a 'Dataset'. @@ -30,13 +33,7 @@ impl <'a> RasterBand<'a> { let mut size_x = 0; let mut size_y = 0; - unsafe { - gdal_sys::GDALGetBlockSize( - self.c_rasterband, - &mut size_x, - &mut size_y - ) - }; + unsafe { gdal_sys::GDALGetBlockSize(self.c_rasterband, &mut size_x, &mut size_y) }; (size_x as usize, size_y as usize) } @@ -52,9 +49,7 @@ impl <'a> RasterBand<'a> { /// Get y-size of the band pub fn y_size(&self) -> usize { let out; - unsafe { - out = gdal_sys::GDALGetRasterBandYSize(self.c_rasterband) - } + unsafe { out = gdal_sys::GDALGetRasterBandYSize(self.c_rasterband) } out as usize } @@ -76,8 +71,7 @@ impl <'a> RasterBand<'a> { window: (isize, isize), window_size: (usize, usize), size: (usize, usize), - ) -> Result> - { + ) -> Result> { let pixels = (size.0 * size.1) as usize; let mut data: Vec = Vec::with_capacity(pixels); //let no_data: @@ -94,7 +88,7 @@ impl <'a> RasterBand<'a> { size.1 as c_int, T::gdal_type(), 0, - 0 + 0, ) }; if rv != CPLErr::CE_None { @@ -105,7 +99,7 @@ impl <'a> RasterBand<'a> { data.set_len(pixels); }; - Ok(Buffer{size, data}) + Ok(Buffer { size, data }) } #[cfg(feature = "ndarray")] @@ -121,8 +115,7 @@ impl <'a> RasterBand<'a> { window: (isize, isize), window_size: (usize, usize), array_size: (usize, usize), - ) -> Result> - { + ) -> Result> { let pixels = (array_size.0 * array_size.1) as usize; let mut data: Vec = Vec::with_capacity(pixels); @@ -139,7 +132,7 @@ impl <'a> RasterBand<'a> { array_size.1 as c_int, T::gdal_type(), 0, - 0 + 0, ) }; if values != CPLErr::CE_None { @@ -151,21 +144,18 @@ impl <'a> RasterBand<'a> { }; // Matrix shape is (rows, cols) and raster shape is (cols in x-axis, rows in y-axis) - Array2::from_shape_vec((array_size.1, array_size.0) , data).map_err(Into::into) + Array2::from_shape_vec((array_size.1, array_size.0), data).map_err(Into::into) } /// Read a full 'Dataset' as 'Buffer'. /// # Arguments /// * band_index - the band_index - pub fn read_band_as( - &self, - ) -> Result> - { + pub fn read_band_as(&self) -> Result> { let size = self.owning_dataset.size(); self.read_as::( (0, 0), (size.0 as usize, size.1 as usize), - (size.0 as usize, size.1 as usize) + (size.0 as usize, size.1 as usize), ) } @@ -175,11 +165,7 @@ impl <'a> RasterBand<'a> { /// * block_index - the block index /// # Docs /// The Matrix shape is (rows, cols) and raster shape is (cols in x-axis, rows in y-axis). - pub fn read_block( - &self, - block_index: (usize, usize) - ) -> Result> - { + pub fn read_block(&self, block_index: (usize, usize)) -> Result> { let size = self.block_size(); let pixels = (size.0 * size.1) as usize; let mut data: Vec = Vec::with_capacity(pixels); @@ -190,7 +176,7 @@ impl <'a> RasterBand<'a> { self.c_rasterband, block_index.0 as c_int, block_index.1 as c_int, - data.as_mut_ptr() as GDALRasterBandH + data.as_mut_ptr() as GDALRasterBandH, ) }; if rv != CPLErr::CE_None { @@ -209,27 +195,29 @@ impl <'a> RasterBand<'a> { /// * band_index - the band_index /// * window - the window position from top left /// * window_size - the window size (GDAL will interpolate data if window_size != Buffer.size) - pub fn write( + pub fn write( &self, window: (isize, isize), window_size: (usize, usize), - buffer: &Buffer + buffer: &Buffer, ) -> Result<()> { assert_eq!(buffer.data.len(), buffer.size.0 * buffer.size.1); - let rv = unsafe { gdal_sys::GDALRasterIO( - self.c_rasterband, - GDALRWFlag::GF_Write, - window.0 as c_int, - window.1 as c_int, - window_size.0 as c_int, - window_size.1 as c_int, - buffer.data.as_ptr() as GDALRasterBandH, - buffer.size.0 as c_int, - buffer.size.1 as c_int, - T::gdal_type(), - 0, - 0 - )}; + let rv = unsafe { + gdal_sys::GDALRasterIO( + self.c_rasterband, + GDALRWFlag::GF_Write, + window.0 as c_int, + window.1 as c_int, + window_size.0 as c_int, + window_size.1 as c_int, + buffer.data.as_ptr() as GDALRasterBandH, + buffer.size.0 as c_int, + buffer.size.1 as c_int, + T::gdal_type(), + 0, + 0, + ) + }; if rv != CPLErr::CE_None { Err(_last_cpl_err(rv))?; } @@ -240,9 +228,10 @@ impl <'a> RasterBand<'a> { unsafe { gdal_sys::GDALGetRasterDataType(self.c_rasterband) } } - pub fn no_data_value(&self) ->Option { + pub fn no_data_value(&self) -> Option { let mut pb_success = 1; - let no_data = unsafe { gdal_sys::GDALGetRasterNoDataValue(self.c_rasterband, &mut pb_success) }; + let no_data = + unsafe { gdal_sys::GDALGetRasterNoDataValue(self.c_rasterband, &mut pb_success) }; if pb_success == 1 { return Some(no_data as f64); } @@ -257,7 +246,7 @@ impl <'a> RasterBand<'a> { Ok(()) } - pub fn scale(&self) ->Option { + pub fn scale(&self) -> Option { let mut pb_success = 1; let scale = unsafe { gdal_sys::GDALGetRasterScale(self.c_rasterband, &mut pb_success) }; if pb_success == 1 { @@ -266,7 +255,7 @@ impl <'a> RasterBand<'a> { None } - pub fn offset(&self) ->Option { + pub fn offset(&self) -> Option { let mut pb_success = 1; let offset = unsafe { gdal_sys::GDALGetRasterOffset(self.c_rasterband, &mut pb_success) }; if pb_success == 1 { @@ -278,17 +267,18 @@ impl <'a> RasterBand<'a> { /// Get actual block size (at the edges) when block size /// does not divide band size. #[cfg(feature = "gdal_2_2")] - pub fn actual_block_size(&self, offset: (isize, isize)) - -> Result<(usize, usize)>{ + pub fn actual_block_size(&self, offset: (isize, isize)) -> Result<(usize, usize)> { let mut block_size_x = 0; let mut block_size_y = 0; - let rv = unsafe { gdal_sys::GDALGetActualBlockSize( - self.c_rasterband, - offset.0 as libc::c_int, - offset.1 as libc::c_int, - &mut block_size_x, - &mut block_size_y, - )}; + let rv = unsafe { + gdal_sys::GDALGetActualBlockSize( + self.c_rasterband, + offset.0 as libc::c_int, + offset.1 as libc::c_int, + &mut block_size_x, + &mut block_size_y, + ) + }; if rv != CPLErr::CE_None { Err(_last_cpl_err(rv))?; } diff --git a/src/raster/tests.rs b/src/raster/tests.rs index bb00fcd7..7cc6bf9b 100644 --- a/src/raster/tests.rs +++ b/src/raster/tests.rs @@ -1,24 +1,27 @@ -use std::path::Path; -use super::{ByteBuffer, Driver, Dataset, warp}; +use crate::metadata::Metadata; +use crate::raster::{ByteBuffer, Dataset, Driver}; use gdal_sys::GDALDataType; -use metadata::Metadata; +use std::path::Path; #[cfg(feature = "ndarray")] use ndarray::arr2; - macro_rules! fixture { - ($name:expr) => ( + ($name:expr) => { Path::new(file!()) - .parent().unwrap() - .parent().unwrap() - .parent().unwrap() - .join("fixtures").as_path() - .join($name).as_path() - ) + .parent() + .unwrap() + .parent() + .unwrap() + .parent() + .unwrap() + .join("fixtures") + .as_path() + .join($name) + .as_path() + }; } - #[test] fn test_open() { let dataset = Dataset::open(fixture!("tinymarble.png")); @@ -28,7 +31,6 @@ fn test_open() { assert!(missing_dataset.is_err()); } - #[test] fn test_get_raster_size() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); @@ -54,71 +56,50 @@ fn test_get_raster_count() { assert_eq!(count, 3); } - #[test] fn test_get_projection() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); //dataset.set_projection("WGS84"); let projection = dataset.projection(); - assert_eq!(projection.chars().take(16).collect::(), "GEOGCS[\"WGS 84\","); + assert_eq!( + projection.chars().take(16).collect::(), + "GEOGCS[\"WGS 84\"," + ); } - #[test] fn test_read_raster() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); - let rv = dataset.read_raster( - 1, - (20, 30), - (2, 3), - (2, 3) - ).unwrap(); + let rv = dataset.read_raster(1, (20, 30), (2, 3), (2, 3)).unwrap(); assert_eq!(rv.size.0, 2); assert_eq!(rv.size.1, 3); assert_eq!(rv.data, vec!(7, 7, 7, 10, 8, 12)); } - #[test] fn test_write_raster() { let driver = Driver::get("MEM").unwrap(); let dataset = driver.create("", 20, 10, 1).unwrap(); // create a 2x1 raster - let raster = ByteBuffer{ + let raster = ByteBuffer { size: (2, 1), - data: vec!(50u8, 20u8) + data: vec![50u8, 20u8], }; // epand it to fill the image (20x10) - let res = dataset.write_raster( - 1, - (0, 0), - (20, 10), - &raster - ); + let res = dataset.write_raster(1, (0, 0), (20, 10), &raster); assert!(res.is_ok()); // read a pixel from the left side - let left = dataset.read_raster( - 1, - (5, 5), - (1, 1), - (1, 1) - ).unwrap(); + let left = dataset.read_raster(1, (5, 5), (1, 1), (1, 1)).unwrap(); assert_eq!(left.data[0], 50u8); // read a pixel from the right side - let right = dataset.read_raster( - 1, - (15, 5), - (1, 1), - (1, 1) - ).unwrap(); + let right = dataset.read_raster(1, (15, 5), (1, 1), (1, 1)).unwrap(); assert_eq!(right.data[0], 20u8); } - #[test] fn test_get_dataset_driver() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); @@ -129,7 +110,6 @@ fn test_get_dataset_driver() { #[test] fn test_get_description() { - let driver = Driver::get("mem").unwrap(); assert_eq!(driver.description().unwrap(), "MEM".to_string()); } @@ -191,7 +171,6 @@ fn test_create_copy() { assert_eq!(copy.count(), 3); } - #[test] fn test_geo_transform() { let driver = Driver::get("MEM").unwrap(); @@ -213,16 +192,12 @@ fn test_get_driver_by_name() { assert_eq!(driver.long_name(), "GeoTIFF"); } - #[test] fn test_read_raster_as() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); - let rv = dataset.read_raster_as::( - 1, - (20, 30), - (2, 3), - (2, 3) - ).unwrap(); + let rv = dataset + .read_raster_as::(1, (20, 30), (2, 3), (2, 3)) + .unwrap(); assert_eq!(rv.data, vec!(7, 7, 7, 10, 8, 12)); assert_eq!(rv.size.0, 2); assert_eq!(rv.size.1, 3); @@ -237,20 +212,27 @@ fn test_read_raster_as_array() { let (window_size_x, window_size_y) = (3, 4); let (array_size_x, array_size_y) = (3, 4); let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); - let values = dataset.read_as_array::( - band_index, - (left, top), - (window_size_x, window_size_y), - (array_size_x, array_size_y) - ).unwrap(); - - let data = arr2(&[[226, 225, 157], - [215, 222, 225], - [213, 231, 229], - [171, 189, 192]]); + let values = dataset + .read_as_array::( + band_index, + (left, top), + (window_size_x, window_size_y), + (array_size_x, array_size_y), + ) + .unwrap(); + + let data = arr2(&[ + [226, 225, 157], + [215, 222, 225], + [213, 231, 229], + [171, 189, 192], + ]); assert_eq!(values, data); - assert_eq!(dataset.band_type(band_index).unwrap(), GDALDataType::GDT_Byte); + assert_eq!( + dataset.band_type(band_index).unwrap(), + GDALDataType::GDT_Byte + ); } #[test] @@ -310,7 +292,6 @@ fn test_read_block_data() { assert_eq!(array[[0, 99]], 51); } - #[test] fn test_get_band_type() { let driver = Driver::get("MEM").unwrap(); @@ -366,7 +347,6 @@ fn test_get_offset() { assert_eq!(offset, Some(0.0)); } - #[test] fn test_get_rasterband_size() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); @@ -388,6 +368,6 @@ fn test_get_rasterband_block_size() { fn test_get_rasterband_actual_block_size() { let dataset = Dataset::open(fixture!("tinymarble.png")).unwrap(); let rasterband = dataset.rasterband(1).unwrap(); - let size = rasterband.actual_block_size((0,40)); + let size = rasterband.actual_block_size((0, 40)); assert_eq!(size.unwrap(), (100, 1)); } diff --git a/src/raster/types.rs b/src/raster/types.rs index 6f96c0d8..b089a524 100644 --- a/src/raster/types.rs +++ b/src/raster/types.rs @@ -4,10 +4,38 @@ pub trait GdalType { fn gdal_type() -> GDALDataType::Type; } -impl GdalType for u8 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_Byte } } -impl GdalType for u16 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_UInt16 } } -impl GdalType for u32 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_UInt32 } } -impl GdalType for i16 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_Int16 } } -impl GdalType for i32 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_Int32 } } -impl GdalType for f32 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_Float32 } } -impl GdalType for f64 { fn gdal_type() -> GDALDataType::Type { GDALDataType::GDT_Float64 } } +impl GdalType for u8 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_Byte + } +} +impl GdalType for u16 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_UInt16 + } +} +impl GdalType for u32 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_UInt32 + } +} +impl GdalType for i16 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_Int16 + } +} +impl GdalType for i32 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_Int32 + } +} +impl GdalType for f32 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_Float32 + } +} +impl GdalType for f64 { + fn gdal_type() -> GDALDataType::Type { + GDALDataType::GDT_Float64 + } +} diff --git a/src/raster/warp.rs b/src/raster/warp.rs index 26cc262a..fadca95a 100644 --- a/src/raster/warp.rs +++ b/src/raster/warp.rs @@ -1,25 +1,25 @@ +use crate::raster::Dataset; +use crate::utils::_last_cpl_err; +use gdal_sys::{self, CPLErr, GDALResampleAlg}; use libc::c_double; use std::ptr::{null, null_mut}; -use raster::{Dataset}; -use gdal_sys::{self, CPLErr, GDALResampleAlg}; -use utils::_last_cpl_err; -use errors::*; +use crate::errors::*; pub fn reproject(src: &Dataset, dst: &Dataset) -> Result<()> { let rv = unsafe { gdal_sys::GDALReprojectImage( - src._c_ptr(), - null(), - dst._c_ptr(), - null(), - GDALResampleAlg::GRA_Bilinear, - 0.0, - 0.0 as c_double, - None, - null_mut(), - null_mut() - ) + src._c_ptr(), + null(), + dst._c_ptr(), + null(), + GDALResampleAlg::GRA_Bilinear, + 0.0, + 0.0 as c_double, + None, + null_mut(), + null_mut(), + ) }; if rv != CPLErr::CE_None { Err(_last_cpl_err(rv))?; diff --git a/src/spatial_ref/mod.rs b/src/spatial_ref/mod.rs index 8399c07d..7af005bb 100644 --- a/src/spatial_ref/mod.rs +++ b/src/spatial_ref/mod.rs @@ -1,5 +1,5 @@ -pub use spatial_ref::srs::SpatialRef; -pub use spatial_ref::srs::CoordTransform; +pub use crate::spatial_ref::srs::CoordTransform; +pub use crate::spatial_ref::srs::SpatialRef; mod srs; diff --git a/src/spatial_ref/srs.rs b/src/spatial_ref/srs.rs index ae3a7e39..02799105 100644 --- a/src/spatial_ref/srs.rs +++ b/src/spatial_ref/srs.rs @@ -1,13 +1,13 @@ +use crate::utils::{_last_cpl_err, _last_null_pointer_err, _string}; +use gdal_sys::{self, CPLErr, OGRCoordinateTransformationH, OGRErr, OGRSpatialReferenceH}; use libc::c_int; -use std::ffi::{CString, CStr}; +use std::ffi::{CStr, CString}; use std::ptr; use std::str::FromStr; -use utils::{_string, _last_null_pointer_err, _last_cpl_err}; -use gdal_sys::{self, CPLErr, OGRCoordinateTransformationH, OGRErr, OGRSpatialReferenceH}; -use errors::*; +use crate::errors::*; -pub struct CoordTransform{ +pub struct CoordTransform { inner: OGRCoordinateTransformationH, from: String, to: String, @@ -26,10 +26,10 @@ impl CoordTransform { if c_obj.is_null() { Err(_last_null_pointer_err("OCTNewCoordinateTransformation"))?; } - Ok(CoordTransform{ + Ok(CoordTransform { inner: c_obj, from: sp_ref1.authority().or_else(|_| sp_ref1.to_proj4())?, - to: sp_ref2.authority().or_else(|_| sp_ref2.to_proj4())? + to: sp_ref2.authority().or_else(|_| sp_ref2.to_proj4())?, }) } @@ -50,7 +50,7 @@ impl CoordTransform { Ok(()) } else { let err = _last_cpl_err(CPLErr::CE_Failure); - let msg = if let ErrorKind::CplError{msg, ..} = err { + let msg = if let ErrorKind::CplError { msg, .. } = err { if msg.trim().is_empty() { None } else { @@ -59,13 +59,18 @@ impl CoordTransform { } else { Err(err)? }; - Err(ErrorKind::InvalidCoordinateRange{from: self.from.clone(), to: self.to.clone(), msg})? + Err(ErrorKind::InvalidCoordinateRange { + from: self.from.clone(), + to: self.to.clone(), + msg, + })? } } #[deprecated(since = "0.3.1", note = "use `transform_coords` instead")] - pub fn transform_coord(&self, x: &mut [f64], y: &mut [f64], z: &mut [f64]){ - self.transform_coords(x, y, z).expect("Coordinate transform failed") + pub fn transform_coord(&self, x: &mut [f64], y: &mut [f64], z: &mut [f64]) { + self.transform_coords(x, y, z) + .expect("Coordinate transform failed") } pub fn to_c_hct(&self) -> OGRCoordinateTransformationH { @@ -77,15 +82,15 @@ impl CoordTransform { pub struct SpatialRef(OGRSpatialReferenceH); impl Drop for SpatialRef { - fn drop(&mut self){ - unsafe { gdal_sys::OSRRelease(self.0)}; + fn drop(&mut self) { + unsafe { gdal_sys::OSRRelease(self.0) }; self.0 = ptr::null_mut(); } } impl Clone for SpatialRef { fn clone(&self) -> SpatialRef { - let n_obj = unsafe { gdal_sys::OSRClone(self.0)}; + let n_obj = unsafe { gdal_sys::OSRClone(self.0) }; SpatialRef(n_obj) } } @@ -110,9 +115,13 @@ impl SpatialRef { if c_obj.is_null() { Err(_last_null_pointer_err("OSRNewSpatialReference"))?; } - let rv = unsafe { gdal_sys::OSRSetFromUserInput(c_obj, CString::new(definition)?.as_ptr()) }; + let rv = + unsafe { gdal_sys::OSRSetFromUserInput(c_obj, CString::new(definition)?.as_ptr()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRSetFromUserInput"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRSetFromUserInput", + })?; } Ok(SpatialRef(c_obj)) } @@ -131,7 +140,10 @@ impl SpatialRef { let c_obj = unsafe { gdal_sys::OSRNewSpatialReference(null_ptr) }; let rv = unsafe { gdal_sys::OSRImportFromEPSG(c_obj, epsg_code as c_int) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRImportFromEPSG"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRImportFromEPSG", + })? } else { Ok(SpatialRef(c_obj)) } @@ -143,7 +155,10 @@ impl SpatialRef { let c_obj = unsafe { gdal_sys::OSRNewSpatialReference(null_ptr) }; let rv = unsafe { gdal_sys::OSRImportFromProj4(c_obj, c_str.as_ptr()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRImportFromProj4"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRImportFromProj4", + })? } else { Ok(SpatialRef(c_obj)) } @@ -156,7 +171,10 @@ impl SpatialRef { let c_obj = unsafe { gdal_sys::OSRNewSpatialReference(null_ptr) }; let rv = unsafe { gdal_sys::OSRImportFromESRI(c_obj, ptrs.as_mut_ptr()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRImportFromESRI"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRImportFromESRI", + })? } else { Ok(SpatialRef(c_obj)) } @@ -165,7 +183,7 @@ impl SpatialRef { pub fn from_c_obj(c_obj: OGRSpatialReferenceH) -> Result { let mut_c_obj = unsafe { gdal_sys::OSRClone(c_obj) }; if mut_c_obj.is_null() { - Err(_last_null_pointer_err("OSRClone"))? + Err(_last_null_pointer_err("OSRClone"))? } else { Ok(SpatialRef(mut_c_obj)) } @@ -175,7 +193,10 @@ impl SpatialRef { let mut c_wkt = ptr::null_mut(); let rv = unsafe { gdal_sys::OSRExportToWkt(self.0, &mut c_wkt) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRExportToWkt"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRExportToWkt", + })? } else { Ok(_string(c_wkt)) } @@ -184,7 +205,10 @@ impl SpatialRef { pub fn morph_to_esri(&self) -> Result<()> { let rv = unsafe { gdal_sys::OSRMorphToESRI(self.0) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRMorphToESRI"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRMorphToESRI", + })?; } Ok(()) } @@ -193,7 +217,10 @@ impl SpatialRef { let mut c_wkt = ptr::null_mut(); let rv = unsafe { gdal_sys::OSRExportToPrettyWkt(self.0, &mut c_wkt, false as c_int) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRExportToPrettyWkt"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRExportToPrettyWkt", + })? } else { Ok(_string(c_wkt)) } @@ -203,7 +230,10 @@ impl SpatialRef { let mut c_raw_xml = ptr::null_mut(); let rv = unsafe { gdal_sys::OSRExportToXML(self.0, &mut c_raw_xml, ptr::null()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRExportToXML"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRExportToXML", + })? } else { Ok(_string(c_raw_xml)) } @@ -213,7 +243,11 @@ impl SpatialRef { let mut c_proj4str = ptr::null_mut(); let rv = unsafe { gdal_sys::OSRExportToProj4(self.0, &mut c_proj4str) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRExportToProj4"}.into()) + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRExportToProj4", + } + .into()) } else { Ok(_string(c_proj4str)) } @@ -237,7 +271,10 @@ impl SpatialRef { let epsg = i32::from_str(c_str.to_str()?); match epsg { Ok(n) => Ok(n), - Err(_) => Err(ErrorKind::OgrError{err: OGRErr::OGRERR_UNSUPPORTED_SRS, method_name: "OSRGetAuthorityCode"})? + Err(_) => Err(ErrorKind::OgrError { + err: OGRErr::OGRERR_UNSUPPORTED_SRS, + method_name: "OSRGetAuthorityCode", + })?, } } @@ -258,7 +295,10 @@ impl SpatialRef { pub fn auto_identify_epsg(&mut self) -> Result<()> { let rv = unsafe { gdal_sys::OSRAutoIdentifyEPSG(self.0) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OSRAutoIdentifyEPSG"})? + Err(ErrorKind::OgrError { + err: rv, + method_name: "OSRAutoIdentifyEPSG", + })? } else { Ok(()) } diff --git a/src/spatial_ref/tests.rs b/src/spatial_ref/tests.rs index a0d3183d..4dba1103 100644 --- a/src/spatial_ref/tests.rs +++ b/src/spatial_ref/tests.rs @@ -1,24 +1,33 @@ -use super::srs::{SpatialRef, CoordTransform}; -use vector::Geometry; -use errors::ErrorKind; -use assert_almost_eq; +use super::srs::{CoordTransform, SpatialRef}; +use crate::assert_almost_eq; +use crate::errors::ErrorKind; +use crate::vector::Geometry; #[test] fn from_wkt_to_proj4() { let spatial_ref = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); - assert_eq!("+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs ", spatial_ref.to_proj4().unwrap()); + assert_eq!( + "+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs ", + spatial_ref.to_proj4().unwrap() + ); let spatial_ref = SpatialRef::from_definition("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); - assert_eq!("+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs ", spatial_ref.to_proj4().unwrap()); + assert_eq!( + "+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs ", + spatial_ref.to_proj4().unwrap() + ); } #[test] -fn from_proj4_to_wkt(){ - let spatial_ref = SpatialRef::from_proj4("+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs").unwrap(); +fn from_proj4_to_wkt() { + let spatial_ref = SpatialRef::from_proj4( + "+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs", + ) + .unwrap(); assert_eq!(spatial_ref.to_wkt().unwrap(), "PROJCS[\"unnamed\",GEOGCS[\"GRS 1980(IUGG, 1980)\",DATUM[\"unknown\",SPHEROID[\"GRS80\",6378137,298.257222101]],PRIMEM[\"Greenwich\",0],UNIT[\"degree\",0.0174532925199433]],PROJECTION[\"Lambert_Azimuthal_Equal_Area\"],PARAMETER[\"latitude_of_center\",52],PARAMETER[\"longitude_of_center\",10],PARAMETER[\"false_easting\",4321000],PARAMETER[\"false_northing\",3210000],UNIT[\"Meter\",1]]"); } #[test] -fn from_epsg_to_wkt_proj4(){ +fn from_epsg_to_wkt_proj4() { let spatial_ref = SpatialRef::from_epsg(4326).unwrap(); let wkt = spatial_ref.to_wkt().unwrap(); assert_eq!("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",\"7030\"]],AUTHORITY[\"EPSG\",\"6326\"]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433,AUTHORITY[\"EPSG\",\"9122\"]],AUTHORITY[\"EPSG\",\"4326\"]]", wkt); @@ -34,7 +43,7 @@ fn from_esri_to_proj4() { } #[test] -fn comparison(){ +fn comparison() { let spatial_ref1 = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); let spatial_ref2 = SpatialRef::from_epsg(4326).unwrap(); let spatial_ref3 = SpatialRef::from_epsg(3025).unwrap(); @@ -48,24 +57,32 @@ fn comparison(){ } #[test] -fn transform_coordinates(){ +fn transform_coordinates() { let spatial_ref1 = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); let spatial_ref2 = SpatialRef::from_epsg(3035).unwrap(); let transform = CoordTransform::new(&spatial_ref1, &spatial_ref2).unwrap(); let mut xs = [23.43, 23.50]; let mut ys = [37.58, 37.70]; - transform.transform_coords(&mut xs, &mut ys, &mut [0.0, 0.0]).unwrap(); + transform + .transform_coords(&mut xs, &mut ys, &mut [0.0, 0.0]) + .unwrap(); assert_almost_eq(xs[0], 5509543.1508097); assert_almost_eq(ys[0], 1716062.1916192223); } #[test] -fn transform_ogr_geometry(){ +fn transform_ogr_geometry() { //let expected_value = "POLYGON ((5509543.150809700600803 1716062.191619219258428,5467122.000330002978444 1980151.204280239529908,5623571.028492723591626 2010213.310253676958382,5671834.921544363722205 1746968.078280254499987,5509543.150809700600803 1716062.191619219258428))"; //let expected_value = "POLYGON ((5509543.15080969966948 1716062.191619222285226,5467122.000330002047122 1980151.204280242323875,5623571.028492721728981 2010213.31025367998518,5671834.921544362790883 1746968.078280256595463,5509543.15080969966948 1716062.191619222285226))"; let expected_value = "POLYGON ((5509543.1508097 1716062.19161922,5467122.00033 1980151.20428024,5623571.02849272 2010213.31025368,5671834.92154436 1746968.07828026,5509543.1508097 1716062.19161922))"; - let geom = Geometry::from_wkt("POLYGON((23.43 37.58, 23.43 40.0, 25.29 40.0, 25.29 37.58, 23.43 37.58))").unwrap(); - let spatial_ref1 = SpatialRef::from_proj4("+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs").unwrap(); + let geom = Geometry::from_wkt( + "POLYGON((23.43 37.58, 23.43 40.0, 25.29 40.0, 25.29 37.58, 23.43 37.58))", + ) + .unwrap(); + let spatial_ref1 = SpatialRef::from_proj4( + "+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs", + ) + .unwrap(); let spatial_ref2 = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); let htransform = CoordTransform::new(&spatial_ref2, &spatial_ref1).unwrap(); geom.transform_inplace(&htransform).unwrap(); @@ -73,7 +90,7 @@ fn transform_ogr_geometry(){ } #[test] -fn authority(){ +fn authority() { let spatial_ref = SpatialRef::from_epsg(4326).unwrap(); assert_eq!(spatial_ref.auth_name().unwrap(), "EPSG".to_string()); assert_eq!(spatial_ref.auth_code().unwrap(), 4326); @@ -86,13 +103,15 @@ fn authority(){ assert!(spatial_ref.auth_name().is_err()); assert!(spatial_ref.auth_code().is_err()); assert!(spatial_ref.authority().is_err()); - let spatial_ref = SpatialRef::from_proj4("+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs").unwrap(); + let spatial_ref = SpatialRef::from_proj4( + "+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs", + ) + .unwrap(); assert!(spatial_ref.auth_name().is_err()); assert!(spatial_ref.auth_code().is_err()); assert!(spatial_ref.authority().is_err()); } - #[test] fn failing_transformation() { let wgs84 = SpatialRef::from_epsg(4326).unwrap(); @@ -117,7 +136,7 @@ fn failing_transformation() { let r = trafo.transform_coords(&mut x, &mut y, &mut z); assert_eq!(r.is_err(), true); - if let &ErrorKind::InvalidCoordinateRange{ref msg, ..} = r.unwrap_err().kind_ref() { + if let &ErrorKind::InvalidCoordinateRange { ref msg, .. } = r.unwrap_err().kind_ref() { assert_eq!(msg, &Some("latitude or longitude exceeded limits".into())); } else { panic!("Wrong error type"); @@ -126,7 +145,8 @@ fn failing_transformation() { #[test] fn auto_identify() { - let mut spatial_ref = SpatialRef::from_wkt(r#" + let mut spatial_ref = SpatialRef::from_wkt( + r#" PROJCS["WGS_1984_UTM_Zone_32N", GEOGCS["GCS_WGS_1984", DATUM["D_WGS_1984", @@ -140,7 +160,9 @@ fn auto_identify() { PARAMETER["false_easting",500000], PARAMETER["false_northing",0], UNIT["Meter",1]] - "#).unwrap(); + "#, + ) + .unwrap(); assert!(spatial_ref.auth_code().is_err()); spatial_ref.auto_identify_epsg().unwrap(); assert_eq!(spatial_ref.auth_code().unwrap(), 32632); diff --git a/src/utils.rs b/src/utils.rs index 28d0db54..f02ee714 100644 --- a/src/utils.rs +++ b/src/utils.rs @@ -1,33 +1,31 @@ +use gdal_sys::{self, CPLErr}; use libc::c_char; use std::ffi::CStr; -use gdal_sys::{self, CPLErr}; - -use errors::*; +use crate::errors::*; pub fn _string(raw_ptr: *const c_char) -> String { let c_str = unsafe { CStr::from_ptr(raw_ptr) }; c_str.to_string_lossy().into_owned() } - // TODO: inspect if this is sane... pub fn _last_cpl_err(cpl_err_class: CPLErr::Type) -> ErrorKind { let last_err_no = unsafe { gdal_sys::CPLGetLastErrorNo() }; - let last_err_msg = _string( unsafe { gdal_sys::CPLGetLastErrorMsg() } ); + let last_err_msg = _string(unsafe { gdal_sys::CPLGetLastErrorMsg() }); unsafe { gdal_sys::CPLErrorReset() }; - ErrorKind::CplError{ + ErrorKind::CplError { class: cpl_err_class, number: last_err_no, - msg: last_err_msg + msg: last_err_msg, } } pub fn _last_null_pointer_err(method_name: &'static str) -> ErrorKind { - let last_err_msg = _string( unsafe { gdal_sys::CPLGetLastErrorMsg() } ); + let last_err_msg = _string(unsafe { gdal_sys::CPLGetLastErrorMsg() }); unsafe { gdal_sys::CPLErrorReset() }; - ErrorKind::NullPointer{ + ErrorKind::NullPointer { method_name, - msg: last_err_msg + msg: last_err_msg, } } diff --git a/src/vector/dataset.rs b/src/vector/dataset.rs index 9106adef..facd67d9 100644 --- a/src/vector/dataset.rs +++ b/src/vector/dataset.rs @@ -1,16 +1,16 @@ +use crate::gdal_major_object::MajorObject; +use crate::metadata::Metadata; +use crate::spatial_ref::SpatialRef; +use crate::utils::_last_null_pointer_err; +use crate::vector::driver::_register_drivers; +use crate::vector::Layer; +use gdal_sys::{self, GDALMajorObjectH, OGRDataSourceH, OGRLayerH, OGRwkbGeometryType}; +use libc::c_int; use std::ffi::CString; use std::path::Path; use std::ptr::null_mut; -use libc::c_int; -use vector::Layer; -use vector::driver::_register_drivers; -use gdal_major_object::MajorObject; -use metadata::Metadata; -use gdal_sys::{self, GDALMajorObjectH, OGRDataSourceH, OGRLayerH, OGRwkbGeometryType}; -use utils::_last_null_pointer_err; -use spatial_ref::SpatialRef; -use errors::*; +use crate::errors::*; /// Vector dataset /// @@ -34,10 +34,12 @@ impl MajorObject for Dataset { impl Metadata for Dataset {} - impl Dataset { pub unsafe fn _with_c_dataset(c_dataset: OGRDataSourceH) -> Dataset { - Dataset{c_dataset, layers: vec!()} + Dataset { + c_dataset, + layers: vec![], + } } /// Open the dataset at `path`. @@ -47,9 +49,12 @@ impl Dataset { let c_filename = CString::new(filename.as_ref())?; let c_dataset = unsafe { gdal_sys::OGROpen(c_filename.as_ptr(), 0, null_mut()) }; if c_dataset.is_null() { - Err(_last_null_pointer_err("OGROpen"))?; + Err(_last_null_pointer_err("OGROpen"))?; }; - Ok(Dataset{c_dataset, layers: vec!()}) + Ok(Dataset { + c_dataset, + layers: vec![], + }) } /// Get number of layers. @@ -85,13 +90,15 @@ impl Dataset { /// Create a new layer with a blank definition. pub fn create_layer(&mut self) -> Result<&mut Layer> { let c_name = CString::new("")?; - let c_layer = unsafe { gdal_sys::OGR_DS_CreateLayer( - self.c_dataset, - c_name.as_ptr(), - null_mut(), - OGRwkbGeometryType::wkbUnknown, - null_mut(), - ) }; + let c_layer = unsafe { + gdal_sys::OGR_DS_CreateLayer( + self.c_dataset, + c_name.as_ptr(), + null_mut(), + OGRwkbGeometryType::wkbUnknown, + null_mut(), + ) + }; if c_layer.is_null() { Err(_last_null_pointer_err("OGR_DS_CreateLayer"))?; }; @@ -112,25 +119,21 @@ impl Dataset { None => null_mut(), }; - let c_layer = unsafe { gdal_sys::OGR_DS_CreateLayer( - self.c_dataset, - c_name.as_ptr(), - c_srs, - ty, - null_mut(), - ) }; + let c_layer = unsafe { + gdal_sys::OGR_DS_CreateLayer(self.c_dataset, c_name.as_ptr(), c_srs, ty, null_mut()) + }; if c_layer.is_null() { Err(_last_null_pointer_err("OGR_DS_CreateLayer"))?; }; self._child_layer(c_layer); Ok(self.layers.last_mut().unwrap()) // TODO: is this safe? - } } - impl Drop for Dataset { fn drop(&mut self) { - unsafe { gdal_sys::OGR_DS_Destroy(self.c_dataset); } + unsafe { + gdal_sys::OGR_DS_Destroy(self.c_dataset); + } } } diff --git a/src/vector/defn.rs b/src/vector/defn.rs index dbd2a1be..9abe4b34 100644 --- a/src/vector/defn.rs +++ b/src/vector/defn.rs @@ -1,10 +1,12 @@ +use crate::spatial_ref::SpatialRef; +use crate::utils::{_last_null_pointer_err, _string}; +use crate::vector::layer::Layer; +use gdal_sys::{ + self, OGRFeatureDefnH, OGRFieldDefnH, OGRFieldType, OGRGeomFieldDefnH, OGRwkbGeometryType, +}; use libc::c_int; -use utils::{_last_null_pointer_err, _string}; -use vector::layer::Layer; -use spatial_ref::SpatialRef; -use gdal_sys::{self, OGRFeatureDefnH, OGRFieldDefnH, OGRFieldType, OGRwkbGeometryType, OGRGeomFieldDefnH}; -use errors::*; +use crate::errors::*; /// Layer definition /// @@ -18,16 +20,18 @@ impl Defn { Defn { c_defn } } - pub unsafe fn c_defn(&self) -> OGRFeatureDefnH { self.c_defn } + pub unsafe fn c_defn(&self) -> OGRFeatureDefnH { + self.c_defn + } /// Iterate over the field schema of this layer. pub fn fields(&self) -> FieldIterator { let total = unsafe { gdal_sys::OGR_FD_GetFieldCount(self.c_defn) } as isize; - FieldIterator{ + FieldIterator { defn: self, c_feature_defn: self.c_defn, next_id: 0, - total + total, } } @@ -38,14 +42,14 @@ impl Defn { defn: self, c_feature_defn: self.c_defn, next_id: 0, - total + total, } } pub fn from_layer(lyr: &Layer) -> Defn { - let c_defn = unsafe { gdal_sys::OGR_L_GetLayerDefn(lyr.c_layer())}; - Defn { c_defn } - } + let c_defn = unsafe { gdal_sys::OGR_L_GetLayerDefn(lyr.c_layer()) }; + Defn { c_defn } + } } pub struct FieldIterator<'a> { @@ -63,12 +67,11 @@ impl<'a> Iterator for FieldIterator<'a> { if self.next_id == self.total { return None; } - let field = Field{ + let field = Field { _defn: self.defn, - c_field_defn: unsafe { gdal_sys::OGR_FD_GetFieldDefn( - self.c_feature_defn, - self.next_id as c_int - ) } + c_field_defn: unsafe { + gdal_sys::OGR_FD_GetFieldDefn(self.c_feature_defn, self.next_id as c_int) + }, }; self.next_id += 1; Some(field) @@ -115,12 +118,11 @@ impl<'a> Iterator for GeomFieldIterator<'a> { if self.next_id == self.total { return None; } - let field = GeomField{ + let field = GeomField { _defn: self.defn, - c_field_defn: unsafe { gdal_sys::OGR_FD_GetGeomFieldDefn( - self.c_feature_defn, - self.next_id as c_int - ) } + c_field_defn: unsafe { + gdal_sys::OGR_FD_GetGeomFieldDefn(self.c_feature_defn, self.next_id as c_int) + }, }; self.next_id += 1; Some(field) diff --git a/src/vector/driver.rs b/src/vector/driver.rs index 0d3f5ddb..2615b429 100644 --- a/src/vector/driver.rs +++ b/src/vector/driver.rs @@ -1,15 +1,14 @@ +use crate::utils::_last_null_pointer_err; +use crate::vector::Dataset; +use gdal_sys::{self, OGRSFDriverH}; use std::ffi::CString; -use std::ptr::null_mut; -use std::sync::{Once, ONCE_INIT}; use std::path::Path; -use vector::{Dataset}; -use gdal_sys::{self, OGRSFDriverH}; -use utils::{_last_null_pointer_err}; - -use errors::*; +use std::ptr::null_mut; +use std::sync::Once; +use crate::errors::*; -static START: Once = ONCE_INIT; +static START: Once = Once::new(); pub fn _register_drivers() { unsafe { @@ -28,25 +27,23 @@ impl Driver { _register_drivers(); let c_name = CString::new(name)?; let c_driver = unsafe { gdal_sys::OGRGetDriverByName(c_name.as_ptr()) }; - if c_driver.is_null() { + if c_driver.is_null() { Err(_last_null_pointer_err("OGRGetDriverByName"))? } else { - Ok(Driver{c_driver}) + Ok(Driver { c_driver }) } } pub fn create(&self, path: &Path) -> Result { let filename = path.to_string_lossy(); let c_filename = CString::new(filename.as_ref())?; - let c_dataset = unsafe { gdal_sys::OGR_Dr_CreateDataSource( - self.c_driver, - c_filename.as_ptr(), - null_mut(), - ) }; + let c_dataset = unsafe { + gdal_sys::OGR_Dr_CreateDataSource(self.c_driver, c_filename.as_ptr(), null_mut()) + }; if c_dataset.is_null() { Err(_last_null_pointer_err("OGR_Dr_CreateDataSource"))? } else { - Ok( unsafe { Dataset::_with_c_dataset(c_dataset) } ) + Ok(unsafe { Dataset::_with_c_dataset(c_dataset) }) } } } diff --git a/src/vector/feature.rs b/src/vector/feature.rs index 798fb3c1..ee09fb34 100644 --- a/src/vector/feature.rs +++ b/src/vector/feature.rs @@ -1,15 +1,15 @@ -use std::ffi::CString; -use libc::{c_double, c_int}; -use vector::Defn; -use utils::{_string, _last_null_pointer_err}; +use crate::utils::{_last_null_pointer_err, _string}; +use crate::vector::geometry::Geometry; +use crate::vector::layer::Layer; +use crate::vector::Defn; use gdal_sys::{self, OGRErr, OGRFeatureH, OGRFieldType}; -use vector::geometry::Geometry; -use vector::layer::Layer; +use libc::{c_double, c_int}; +use std::ffi::CString; #[cfg(feature = "datetime")] -use chrono::{Date, FixedOffset, DateTime, TimeZone, Datelike, Timelike}; +use chrono::{Date, DateTime, Datelike, FixedOffset, TimeZone, Timelike}; -use errors::*; +use crate::errors::*; /// OGR Feature pub struct Feature<'a> { @@ -25,10 +25,10 @@ impl<'a> Feature<'a> { Err(_last_null_pointer_err("OGR_F_Create"))?; }; Ok(Feature { - _defn: defn, - c_feature, - geometry: Feature::_lazy_feature_geometries(defn), - }) + _defn: defn, + c_feature, + geometry: Feature::_lazy_feature_geometries(defn), + }) } pub unsafe fn _with_c_feature(defn: &'a Defn, c_feature: OGRFeatureH) -> Feature { @@ -40,8 +40,11 @@ impl<'a> Feature<'a> { } pub fn _lazy_feature_geometries(defn: &'a Defn) -> Vec { - let geom_field_count = unsafe { gdal_sys::OGR_FD_GetGeomFieldCount(defn.c_defn()) } as isize; - (0..geom_field_count).map(|_| unsafe { Geometry::lazy_feature_geometry() }).collect() + let geom_field_count = + unsafe { gdal_sys::OGR_FD_GetGeomFieldCount(defn.c_defn()) } as isize; + (0..geom_field_count) + .map(|_| unsafe { Geometry::lazy_feature_geometry() }) + .collect() } /// Get the value of a named field. If the field exists, it returns a @@ -51,7 +54,10 @@ impl<'a> Feature<'a> { let c_name = CString::new(name)?; let field_id = unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_name.as_ptr()) }; if field_id == -1 { - Err(ErrorKind::InvalidFieldName{field_name: name.to_string(), method_name: "OGR_F_GetFieldIndex"})?; + Err(ErrorKind::InvalidFieldName { + field_name: name.to_string(), + method_name: "OGR_F_GetFieldIndex", + })?; } let field_defn = unsafe { gdal_sys::OGR_F_GetFieldDefnRef(self.c_feature, field_id) }; let field_type = unsafe { gdal_sys::OGR_Fld_GetType(field_defn) }; @@ -59,24 +65,27 @@ impl<'a> Feature<'a> { OGRFieldType::OFTString => { let rv = unsafe { gdal_sys::OGR_F_GetFieldAsString(self.c_feature, field_id) }; Ok(FieldValue::StringValue(_string(rv))) - }, + } OGRFieldType::OFTReal => { let rv = unsafe { gdal_sys::OGR_F_GetFieldAsDouble(self.c_feature, field_id) }; Ok(FieldValue::RealValue(rv as f64)) - }, + } OGRFieldType::OFTInteger => { let rv = unsafe { gdal_sys::OGR_F_GetFieldAsInteger(self.c_feature, field_id) }; Ok(FieldValue::IntegerValue(rv as i32)) - }, + } #[cfg(feature = "datetime")] - OGRFieldType::OFTDateTime => { - Ok(FieldValue::DateTimeValue(self.get_field_datetime(field_id)?)) - }, + OGRFieldType::OFTDateTime => Ok(FieldValue::DateTimeValue( + self.get_field_datetime(field_id)?, + )), #[cfg(feature = "datetime")] - OGRFieldType::OFTDate => { - Ok(FieldValue::DateValue(self.get_field_datetime(field_id)?.date())) - }, - _ => Err(ErrorKind::UnhandledFieldType{field_type, method_name: "OGR_Fld_GetType"})? + OGRFieldType::OFTDate => Ok(FieldValue::DateValue( + self.get_field_datetime(field_id)?.date(), + )), + _ => Err(ErrorKind::UnhandledFieldType { + field_type, + method_name: "OGR_Fld_GetType", + })?, } } @@ -92,12 +101,22 @@ impl<'a> Feature<'a> { let success = unsafe { gdal_sys::OGR_F_GetFieldAsDateTime( - self.c_feature, field_id, - &mut year, &mut month, &mut day, &mut hour, &mut minute, &mut second, &mut tzflag + self.c_feature, + field_id, + &mut year, + &mut month, + &mut day, + &mut hour, + &mut minute, + &mut second, + &mut tzflag, ) }; if success == 0 { - Err(ErrorKind::OgrError { err: OGRErr::OGRERR_FAILURE, method_name: "OGR_F_GetFieldAsDateTime" })?; + Err(ErrorKind::OgrError { + err: OGRErr::OGRERR_FAILURE, + method_name: "OGR_F_GetFieldAsDateTime", + })?; } // from https://github.com/OSGeo/gdal/blob/33a8a0edc764253b582e194d330eec3b83072863/gdal/ogr/ogrutils.cpp#L1309 @@ -123,9 +142,13 @@ impl<'a> Feature<'a> { pub fn geometry_by_name(&self, field_name: &str) -> Result<&Geometry> { let c_str_field_name = CString::new(field_name)?; - let idx = unsafe { gdal_sys::OGR_F_GetGeomFieldIndex(self.c_feature, c_str_field_name.as_ptr())}; + let idx = + unsafe { gdal_sys::OGR_F_GetGeomFieldIndex(self.c_feature, c_str_field_name.as_ptr()) }; if idx == -1 { - Err(ErrorKind::InvalidFieldName{field_name: field_name.to_string(), method_name: "geometry_by_name"})? + Err(ErrorKind::InvalidFieldName { + field_name: field_name.to_string(), + method_name: "geometry_by_name", + })? } else { self.geometry_by_index(idx as usize) } @@ -133,9 +156,12 @@ impl<'a> Feature<'a> { pub fn geometry_by_index(&self, idx: usize) -> Result<&Geometry> { if idx >= self.geometry.len() { - Err(ErrorKind::InvalidFieldIndex{index: idx, method_name: "geometry_by_name"})?; + Err(ErrorKind::InvalidFieldIndex { + index: idx, + method_name: "geometry_by_name", + })?; } - if ! self.geometry[idx].has_gdal_ptr() { + if !self.geometry[idx].has_gdal_ptr() { let c_geom = unsafe { gdal_sys::OGR_F_GetGeomFieldRef(self.c_feature, idx as i32) }; if c_geom.is_null() { Err(_last_null_pointer_err("OGR_F_GetGeomFieldRef"))?; @@ -148,7 +174,10 @@ impl<'a> Feature<'a> { pub fn create(&self, lyr: &Layer) -> Result<()> { let rv = unsafe { gdal_sys::OGR_L_CreateFeature(lyr.c_layer(), self.c_feature) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_L_CreateFeature"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_L_CreateFeature", + })?; } Ok(()) } @@ -156,9 +185,13 @@ impl<'a> Feature<'a> { pub fn set_field_string(&self, field_name: &str, value: &str) -> Result<()> { let c_str_field_name = CString::new(field_name)?; let c_str_value = CString::new(value)?; - let idx = unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr())}; + let idx = + unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr()) }; if idx == -1 { - Err(ErrorKind::InvalidFieldName{field_name: field_name.to_string(), method_name: "OGR_F_GetFieldIndex"})?; + Err(ErrorKind::InvalidFieldName { + field_name: field_name.to_string(), + method_name: "OGR_F_GetFieldIndex", + })?; } unsafe { gdal_sys::OGR_F_SetFieldString(self.c_feature, idx, c_str_value.as_ptr()) }; Ok(()) @@ -166,9 +199,13 @@ impl<'a> Feature<'a> { pub fn set_field_double(&self, field_name: &str, value: f64) -> Result<()> { let c_str_field_name = CString::new(field_name)?; - let idx = unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr())}; + let idx = + unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr()) }; if idx == -1 { - Err(ErrorKind::InvalidFieldName{field_name: field_name.to_string(), method_name: "OGR_F_GetFieldIndex"})?; + Err(ErrorKind::InvalidFieldName { + field_name: field_name.to_string(), + method_name: "OGR_F_GetFieldIndex", + })?; } unsafe { gdal_sys::OGR_F_SetFieldDouble(self.c_feature, idx, value as c_double) }; Ok(()) @@ -176,9 +213,13 @@ impl<'a> Feature<'a> { pub fn set_field_integer(&self, field_name: &str, value: i32) -> Result<()> { let c_str_field_name = CString::new(field_name)?; - let idx = unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr())}; + let idx = + unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr()) }; if idx == -1 { - Err(ErrorKind::InvalidFieldName{field_name: field_name.to_string(), method_name: "OGR_F_GetFieldIndex"})?; + Err(ErrorKind::InvalidFieldName { + field_name: field_name.to_string(), + method_name: "OGR_F_GetFieldIndex", + })?; } unsafe { gdal_sys::OGR_F_SetFieldInteger(self.c_feature, idx, value as c_int) }; Ok(()) @@ -187,15 +228,19 @@ impl<'a> Feature<'a> { #[cfg(feature = "datetime")] pub fn set_field_datetime(&self, field_name: &str, value: DateTime) -> Result<()> { let c_str_field_name = CString::new(field_name)?; - let idx = unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr())}; + let idx = + unsafe { gdal_sys::OGR_F_GetFieldIndex(self.c_feature, c_str_field_name.as_ptr()) }; if idx == -1 { - Err(ErrorKind::InvalidFieldName{field_name: field_name.to_string(), method_name: "OGR_F_GetFieldIndex"})?; + Err(ErrorKind::InvalidFieldName { + field_name: field_name.to_string(), + method_name: "OGR_F_GetFieldIndex", + })?; } let year = value.year() as c_int; let month = value.month() as c_int; let day = value.day() as c_int; - let hour= value.hour() as c_int; + let hour = value.hour() as c_int; let minute = value.minute() as c_int; let second = value.second() as c_int; let tzflag: c_int = if value.offset().local_minus_utc() == 0 { @@ -204,38 +249,56 @@ impl<'a> Feature<'a> { 100 + (value.offset().local_minus_utc() / (15 * 60)) }; - unsafe { gdal_sys::OGR_F_SetFieldDateTime(self.c_feature, idx, year, month, day, hour, minute, second, tzflag) }; + unsafe { + gdal_sys::OGR_F_SetFieldDateTime( + self.c_feature, + idx, + year, + month, + day, + hour, + minute, + second, + tzflag, + ) + }; Ok(()) } - pub fn set_field(&self, field_name: &str, value: &FieldValue) -> Result<()> { - match *value { - FieldValue::RealValue(value) => self.set_field_double(field_name, value), - FieldValue::StringValue(ref value) => self.set_field_string(field_name, value.as_str()), - FieldValue::IntegerValue(value) => self.set_field_integer(field_name, value), + pub fn set_field(&self, field_name: &str, value: &FieldValue) -> Result<()> { + match *value { + FieldValue::RealValue(value) => self.set_field_double(field_name, value), + FieldValue::StringValue(ref value) => self.set_field_string(field_name, value.as_str()), + FieldValue::IntegerValue(value) => self.set_field_integer(field_name, value), - #[cfg(feature = "datetime")] - FieldValue::DateTimeValue(value) => self.set_field_datetime(field_name, value), + #[cfg(feature = "datetime")] + FieldValue::DateTimeValue(value) => self.set_field_datetime(field_name, value), - #[cfg(feature = "datetime")] - FieldValue::DateValue(value) => self.set_field_datetime(field_name, value.and_hms(0, 0, 0)), - } - } + #[cfg(feature = "datetime")] + FieldValue::DateValue(value) => { + self.set_field_datetime(field_name, value.and_hms(0, 0, 0)) + } + } + } pub fn set_geometry(&mut self, geom: Geometry) -> Result<()> { let rv = unsafe { gdal_sys::OGR_F_SetGeometry(self.c_feature, geom.c_geometry()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_G_SetGeometry"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_SetGeometry", + })?; } self.geometry[0] = geom; Ok(()) } } - impl<'a> Drop for Feature<'a> { fn drop(&mut self) { - unsafe { gdal_sys::OGR_F_Destroy(self.c_feature); } + unsafe { + gdal_sys::OGR_F_Destroy(self.c_feature); + } } } @@ -247,18 +310,16 @@ pub enum FieldValue { #[cfg(feature = "datetime")] DateValue(Date), - #[cfg(feature = "datetime")] DateTimeValue(DateTime), } - impl FieldValue { /// Interpret the value as `String`. Panics if the value is something else. pub fn into_string(self) -> Option { match self { FieldValue::StringValue(rv) => Some(rv), - _ => None + _ => None, } } @@ -266,7 +327,7 @@ impl FieldValue { pub fn into_real(self) -> Option { match self { FieldValue::RealValue(rv) => Some(rv), - _ => None + _ => None, } } @@ -274,7 +335,7 @@ impl FieldValue { pub fn into_int(self) -> Option { match self { FieldValue::IntegerValue(rv) => Some(rv), - _ => None + _ => None, } } @@ -284,7 +345,7 @@ impl FieldValue { match self { FieldValue::DateValue(rv) => Some(rv), FieldValue::DateTimeValue(rv) => Some(rv.date()), - _ => None + _ => None, } } @@ -293,7 +354,7 @@ impl FieldValue { pub fn into_datetime(self) -> Option> { match self { FieldValue::DateTimeValue(rv) => Some(rv), - _ => None + _ => None, } } } diff --git a/src/vector/gdal_to_geo.rs b/src/vector/gdal_to_geo.rs index 6955e1b2..934a4939 100644 --- a/src/vector/gdal_to_geo.rs +++ b/src/vector/gdal_to_geo.rs @@ -1,6 +1,6 @@ +use crate::vector::Geometry; use gdal_sys::{self, OGRwkbGeometryType}; use geo_types; -use vector::Geometry; impl From for geo_types::Geometry { fn from(geo: Geometry) -> geo_types::Geometry { @@ -31,7 +31,8 @@ impl From for geo_types::Geometry { geo_types::Geometry::MultiPoint(geo_types::MultiPoint(coords)) } OGRwkbGeometryType::wkbLineString => { - let coords = geo.get_point_vec() + let coords = geo + .get_point_vec() .iter() .map(|&(x, y, _)| geo_types::Coordinate { x, y }) .collect(); diff --git a/src/vector/geo_to_gdal.rs b/src/vector/geo_to_gdal.rs index 3f02b5ab..97e44220 100644 --- a/src/vector/geo_to_gdal.rs +++ b/src/vector/geo_to_gdal.rs @@ -1,19 +1,31 @@ -use vector::{Geometry, ToGdal}; +use crate::errors::*; +use crate::vector::{Geometry, ToGdal}; +use gdal_sys::OGRwkbGeometryType; use geo_types; -use gdal_sys::{OGRwkbGeometryType}; -use errors::*; use num_traits::Float; -impl ToGdal for geo_types::Point where T: Float { +impl ToGdal for geo_types::Point +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbPoint)?; let &geo_types::Point(coordinate) = self; - geom.set_point_2d(0, (coordinate.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, coordinate.y.to_f64().ok_or(ErrorKind::CastToF64Error)?)); + geom.set_point_2d( + 0, + ( + coordinate.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, + coordinate.y.to_f64().ok_or(ErrorKind::CastToF64Error)?, + ), + ); Ok(geom) } } -impl ToGdal for geo_types::MultiPoint where T: Float { +impl ToGdal for geo_types::MultiPoint +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbMultiPoint)?; let &geo_types::MultiPoint(ref point_list) = self; @@ -24,31 +36,64 @@ impl ToGdal for geo_types::MultiPoint where T: Float { } } -fn geometry_with_points(wkb_type: OGRwkbGeometryType::Type, points: &geo_types::LineString) -> Result where T: Float { +fn geometry_with_points( + wkb_type: OGRwkbGeometryType::Type, + points: &geo_types::LineString, +) -> Result +where + T: Float, +{ let mut geom = Geometry::empty(wkb_type)?; let &geo_types::LineString(ref linestring) = points; for (i, &coordinate) in linestring.iter().enumerate() { - geom.set_point_2d(i, (coordinate.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, coordinate.y.to_f64().ok_or(ErrorKind::CastToF64Error)?)); + geom.set_point_2d( + i, + ( + coordinate.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, + coordinate.y.to_f64().ok_or(ErrorKind::CastToF64Error)?, + ), + ); } Ok(geom) } -impl ToGdal for geo_types::Line where T: Float { +impl ToGdal for geo_types::Line +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbLineString)?; - geom.set_point_2d(0, (self.start.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, self.start.y.to_f64().ok_or(ErrorKind::CastToF64Error)?)); - geom.set_point_2d(1, (self.end.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, self.end.y.to_f64().ok_or(ErrorKind::CastToF64Error)?)); + geom.set_point_2d( + 0, + ( + self.start.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, + self.start.y.to_f64().ok_or(ErrorKind::CastToF64Error)?, + ), + ); + geom.set_point_2d( + 1, + ( + self.end.x.to_f64().ok_or(ErrorKind::CastToF64Error)?, + self.end.y.to_f64().ok_or(ErrorKind::CastToF64Error)?, + ), + ); Ok(geom) } } -impl ToGdal for geo_types::LineString where T: Float { +impl ToGdal for geo_types::LineString +where + T: Float, +{ fn to_gdal(&self) -> Result { geometry_with_points(OGRwkbGeometryType::wkbLineString, self) } } -impl ToGdal for geo_types::MultiLineString where T: Float { +impl ToGdal for geo_types::MultiLineString +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbMultiLineString)?; let &geo_types::MultiLineString(ref point_list) = self; @@ -59,20 +104,32 @@ impl ToGdal for geo_types::MultiLineString where T: Float { } } -impl ToGdal for geo_types::Polygon where T: Float { +impl ToGdal for geo_types::Polygon +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbPolygon)?; let exterior = self.exterior(); let interiors = self.interiors(); - geom.add_geometry(geometry_with_points(OGRwkbGeometryType::wkbLinearRing, exterior)?)?; + geom.add_geometry(geometry_with_points( + OGRwkbGeometryType::wkbLinearRing, + exterior, + )?)?; for ring in interiors.iter() { - geom.add_geometry(geometry_with_points(OGRwkbGeometryType::wkbLinearRing, ring)?)?; + geom.add_geometry(geometry_with_points( + OGRwkbGeometryType::wkbLinearRing, + ring, + )?)?; } Ok(geom) } } -impl ToGdal for geo_types::MultiPolygon where T: Float { +impl ToGdal for geo_types::MultiPolygon +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbMultiPolygon)?; let &geo_types::MultiPolygon(ref polygon_list) = self; @@ -83,7 +140,10 @@ impl ToGdal for geo_types::MultiPolygon where T: Float { } } -impl ToGdal for geo_types::GeometryCollection where T: Float { +impl ToGdal for geo_types::GeometryCollection +where + T: Float, +{ fn to_gdal(&self) -> Result { let mut geom = Geometry::empty(OGRwkbGeometryType::wkbGeometryCollection)?; let &geo_types::GeometryCollection(ref item_list) = self; @@ -94,7 +154,10 @@ impl ToGdal for geo_types::GeometryCollection where T: Float { } } -impl ToGdal for geo_types::Geometry where T: Float { +impl ToGdal for geo_types::Geometry +where + T: Float, +{ fn to_gdal(&self) -> Result { match *self { geo_types::Geometry::Point(ref c) => c.to_gdal(), diff --git a/src/vector/geometry.rs b/src/vector/geometry.rs index a946ec3a..a03b4105 100644 --- a/src/vector/geometry.rs +++ b/src/vector/geometry.rs @@ -1,12 +1,12 @@ -use std::ptr::null_mut; -use libc::{c_int, c_double, c_void}; -use std::ffi::CString; -use std::cell::RefCell; -use utils::{_string, _last_null_pointer_err}; +use crate::spatial_ref::{CoordTransform, SpatialRef}; +use crate::utils::{_last_null_pointer_err, _string}; use gdal_sys::{self, OGRErr, OGRGeometryH, OGRwkbGeometryType}; -use spatial_ref::{SpatialRef, CoordTransform}; +use libc::{c_double, c_int, c_void}; +use std::cell::RefCell; +use std::ffi::CString; +use std::ptr::null_mut; -use errors::*; +use crate::errors::*; /// OGR Geometry pub struct Geometry { @@ -27,7 +27,10 @@ impl Geometry { // which is good, because that's when c_geometry (which is managed // by the GDAL feature) becomes invalid. Because `self.owned` is // `true`, we don't call `OGR_G_DestroyGeometry`. - Geometry{c_geometry_ref: RefCell::new(None), owned: false} + Geometry { + c_geometry_ref: RefCell::new(None), + owned: false, + } } pub fn has_gdal_ptr(&self) -> bool { @@ -35,13 +38,13 @@ impl Geometry { } pub unsafe fn set_c_geometry(&self, c_geometry: OGRGeometryH) { - assert!(! self.has_gdal_ptr()); + assert!(!self.has_gdal_ptr()); assert_eq!(self.owned, false); *(self.c_geometry_ref.borrow_mut()) = Some(c_geometry); } unsafe fn with_c_geometry(c_geom: OGRGeometryH, owned: bool) -> Geometry { - Geometry{ + Geometry { c_geometry_ref: RefCell::new(Some(c_geom)), owned, } @@ -67,7 +70,10 @@ impl Geometry { let mut c_geom = null_mut(); let rv = unsafe { gdal_sys::OGR_G_CreateFromWkt(&mut c_wkt_ptr, null_mut(), &mut c_geom) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_G_CreateFromWkt"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_CreateFromWkt", + })?; } Ok(unsafe { Geometry::with_c_geometry(c_geom, true) }) } @@ -76,11 +82,7 @@ impl Geometry { pub fn bbox(w: f64, s: f64, e: f64, n: f64) -> Result { Geometry::from_wkt(&format!( "POLYGON (({} {}, {} {}, {} {}, {} {}, {} {}))", - w, n, - e, n, - e, s, - w, s, - w, n, + w, n, e, n, e, s, w, s, w, n, )) } @@ -100,7 +102,10 @@ impl Geometry { let mut c_wkt = null_mut(); let rv = unsafe { gdal_sys::OGR_G_ExportToWkt(self.c_geometry(), &mut c_wkt) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_G_ExportToWkt"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_ExportToWkt", + })?; } let wkt = _string(c_wkt); unsafe { gdal_sys::OGRFree(c_wkt as *mut c_void) }; @@ -119,12 +124,9 @@ impl Geometry { pub fn set_point_2d(&mut self, i: usize, p: (f64, f64)) { let (x, y) = p; - unsafe { gdal_sys::OGR_G_SetPoint_2D( - self.c_geometry(), - i as c_int, - x as c_double, - y as c_double, - ) }; + unsafe { + gdal_sys::OGR_G_SetPoint_2D(self.c_geometry(), i as c_int, x as c_double, y as c_double) + }; } pub fn get_point(&self, i: i32) -> (f64, f64, f64) { @@ -136,7 +138,7 @@ impl Geometry { } pub fn get_point_vec(&self) -> Vec<(f64, f64, f64)> { - let length = unsafe{ gdal_sys::OGR_G_GetPointCount(self.c_geometry()) }; + let length = unsafe { gdal_sys::OGR_G_GetPointCount(self.c_geometry()) }; (0..length).map(|i| self.get_point(i)).collect() } @@ -168,24 +170,25 @@ impl Geometry { pub fn add_geometry(&mut self, mut sub: Geometry) -> Result<()> { assert!(sub.owned); sub.owned = false; - let rv = unsafe { gdal_sys::OGR_G_AddGeometryDirectly( - self.c_geometry(), - sub.c_geometry(), - ) }; + let rv = + unsafe { gdal_sys::OGR_G_AddGeometryDirectly(self.c_geometry(), sub.c_geometry()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{ err: rv, method_name: "OGR_G_AddGeometryDirectly"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_AddGeometryDirectly", + })?; } Ok(()) } // Transform the geometry inplace (when we own the Geometry) pub fn transform_inplace(&self, htransform: &CoordTransform) -> Result<()> { - let rv = unsafe { gdal_sys::OGR_G_Transform( - self.c_geometry(), - htransform.to_c_hct() - ) }; + let rv = unsafe { gdal_sys::OGR_G_Transform(self.c_geometry(), htransform.to_c_hct()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_G_Transform"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_Transform", + })?; } Ok(()) } @@ -195,18 +198,21 @@ impl Geometry { let new_c_geom = unsafe { gdal_sys::OGR_G_Clone(self.c_geometry()) }; let rv = unsafe { gdal_sys::OGR_G_Transform(new_c_geom, htransform.to_c_hct()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err:rv, method_name: "OGR_G_Transform"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_Transform", + })?; } - Ok(unsafe { Geometry::with_c_geometry(new_c_geom, true) } ) + Ok(unsafe { Geometry::with_c_geometry(new_c_geom, true) }) } pub fn transform_to_inplace(&self, spatial_ref: &SpatialRef) -> Result<()> { - let rv = unsafe { gdal_sys::OGR_G_TransformTo( - self.c_geometry(), - spatial_ref.to_c_hsrs() - ) }; + let rv = unsafe { gdal_sys::OGR_G_TransformTo(self.c_geometry(), spatial_ref.to_c_hsrs()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_G_TransformTo"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_TransformTo", + })?; } Ok(()) } @@ -215,9 +221,12 @@ impl Geometry { let new_c_geom = unsafe { gdal_sys::OGR_G_Clone(self.c_geometry()) }; let rv = unsafe { gdal_sys::OGR_G_TransformTo(new_c_geom, spatial_ref.to_c_hsrs()) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_G_TransformTo"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_G_TransformTo", + })?; } - Ok(unsafe { Geometry::with_c_geometry(new_c_geom, true) } ) + Ok(unsafe { Geometry::with_c_geometry(new_c_geom, true) }) } pub fn area(&self) -> f64 { @@ -237,13 +246,15 @@ impl Geometry { } else { match SpatialRef::from_c_obj(c_spatial_ref) { Ok(sr) => Some(sr), - Err(_) => None + Err(_) => None, } } } pub fn set_spatial_reference(&mut self, spatial_ref: SpatialRef) { - unsafe { gdal_sys::OGR_G_AssignSpatialReference(self.c_geometry(), spatial_ref.to_c_hsrs()) }; + unsafe { + gdal_sys::OGR_G_AssignSpatialReference(self.c_geometry(), spatial_ref.to_c_hsrs()) + }; } } @@ -260,7 +271,7 @@ impl Clone for Geometry { fn clone(&self) -> Geometry { // assert!(self.has_gdal_ptr()); let c_geometry = self.c_geometry_ref.borrow(); - let new_c_geom = unsafe { gdal_sys::OGR_G_Clone(c_geometry.unwrap())}; + let new_c_geom = unsafe { gdal_sys::OGR_G_Clone(c_geometry.unwrap()) }; unsafe { Geometry::with_c_geometry(new_c_geom, true) } } } @@ -268,7 +279,7 @@ impl Clone for Geometry { #[cfg(test)] mod tests { use super::Geometry; - use spatial_ref::SpatialRef; + use crate::spatial_ref::SpatialRef; #[test] pub fn test_area() { diff --git a/src/vector/layer.rs b/src/vector/layer.rs index 0266f45e..94a8822d 100644 --- a/src/vector/layer.rs +++ b/src/vector/layer.rs @@ -1,15 +1,17 @@ -use std::ptr::null_mut; -use std::ffi::CString; +use crate::gdal_major_object::MajorObject; +use crate::metadata::Metadata; +use crate::spatial_ref::SpatialRef; +use crate::utils::{_last_null_pointer_err, _string}; +use crate::vector::defn::Defn; +use crate::vector::{Feature, FieldValue, Geometry}; +use gdal_sys::{ + self, GDALMajorObjectH, OGREnvelope, OGRErr, OGRFieldDefnH, OGRFieldType, OGRLayerH, +}; use libc::c_int; -use vector::{Feature, Geometry, FieldValue}; -use vector::defn::Defn; -use gdal_major_object::MajorObject; -use metadata::Metadata; -use gdal_sys::{self, OGRErr, OGREnvelope, OGRFieldDefnH, OGRFieldType, OGRLayerH, GDALMajorObjectH}; -use utils::{_last_null_pointer_err, _string}; -use spatial_ref::SpatialRef; +use std::ffi::CString; +use std::ptr::null_mut; -use errors::*; +use crate::errors::*; /// Layer in a vector dataset /// @@ -36,12 +38,11 @@ impl MajorObject for Layer { impl Metadata for Layer {} - impl Layer { pub unsafe fn _with_c_layer(c_layer: OGRLayerH) -> Layer { let c_defn = gdal_sys::OGR_L_GetLayerDefn(c_layer); let defn = Defn::_with_c_defn(c_defn); - Layer{c_layer, defn} + Layer { c_layer, defn } } pub unsafe fn c_layer(&self) -> OGRLayerH { @@ -83,17 +84,27 @@ impl Layer { let c_geometry = unsafe { geometry.into_c_geometry() }; let rv = unsafe { gdal_sys::OGR_F_SetGeometryDirectly(c_feature, c_geometry) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_F_SetGeometryDirectly"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_F_SetGeometryDirectly", + })?; } let rv = unsafe { gdal_sys::OGR_L_CreateFeature(self.c_layer, c_feature) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_L_CreateFeature"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_L_CreateFeature", + })?; } Ok(()) } - pub fn create_feature_fields(&mut self, geometry: Geometry, - field_names: &[&str], values: &[FieldValue]) -> Result<()> { + pub fn create_feature_fields( + &mut self, + geometry: Geometry, + field_names: &[&str], + values: &[FieldValue], + ) -> Result<()> { let mut ft = Feature::new(&self.defn)?; ft.set_geometry(geometry)?; for (fd, val) in field_names.iter().zip(values.iter()) { @@ -104,11 +115,19 @@ impl Layer { } pub fn get_extent(&self, force: bool) -> Result { - let mut envelope = OGREnvelope { MinX: 0.0, MaxX: 0.0, MinY: 0.0, MaxY: 0.0 }; + let mut envelope = OGREnvelope { + MinX: 0.0, + MaxX: 0.0, + MinY: 0.0, + MaxY: 0.0, + }; let force = if force { 1 } else { 0 }; let rv = unsafe { gdal_sys::OGR_L_GetExtent(self.c_layer, &mut envelope, force) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_L_GetExtent"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_L_GetExtent", + })?; } Ok(envelope) } @@ -172,15 +191,18 @@ impl FieldDefn { Ok(FieldDefn { c_obj }) } pub fn set_width(&self, width: i32) { - unsafe {gdal_sys:: OGR_Fld_SetWidth(self.c_obj, width as c_int) }; + unsafe { gdal_sys::OGR_Fld_SetWidth(self.c_obj, width as c_int) }; } pub fn set_precision(&self, precision: i32) { - unsafe {gdal_sys:: OGR_Fld_SetPrecision(self.c_obj, precision as c_int) }; + unsafe { gdal_sys::OGR_Fld_SetPrecision(self.c_obj, precision as c_int) }; } pub fn add_to_layer(&self, layer: &Layer) -> Result<()> { let rv = unsafe { gdal_sys::OGR_L_CreateField(layer.c_layer(), self.c_obj, 1) }; if rv != OGRErr::OGRERR_NONE { - Err(ErrorKind::OgrError{err: rv, method_name: "OGR_L_CreateFeature"})?; + Err(ErrorKind::OgrError { + err: rv, + method_name: "OGR_L_CreateFeature", + })?; } Ok(()) } diff --git a/src/vector/mod.rs b/src/vector/mod.rs index 3dd9877e..6f117444 100644 --- a/src/vector/mod.rs +++ b/src/vector/mod.rs @@ -15,30 +15,29 @@ //! } //! ``` - -pub use vector::driver::Driver; -pub use vector::dataset::Dataset; -pub use vector::layer::{Layer, FeatureIterator, FieldDefn}; -pub use vector::defn::{Defn, FieldIterator, Field}; -pub use vector::feature::{Feature, FieldValue}; -pub use vector::geometry::Geometry; +pub use crate::vector::dataset::Dataset; +pub use crate::vector::defn::{Defn, Field, FieldIterator}; +pub use crate::vector::driver::Driver; +pub use crate::vector::feature::{Feature, FieldValue}; +pub use crate::vector::geometry::Geometry; +pub use crate::vector::layer::{FeatureIterator, FieldDefn, Layer}; pub use gdal_sys::{OGRFieldType, OGRwkbGeometryType}; -use errors::{Result}; +use crate::errors::Result; /// Convert object to a GDAL geometry. pub trait ToGdal { fn to_gdal(&self) -> Result; } -mod driver; mod dataset; -mod layer; mod defn; +mod driver; mod feature; -mod geometry; mod gdal_to_geo; mod geo_to_gdal; +mod geometry; +mod layer; #[cfg(test)] mod tests; diff --git a/src/vector/tests/convert_geo.rs b/src/vector/tests/convert_geo.rs index f96ea1aa..c04a663d 100644 --- a/src/vector/tests/convert_geo.rs +++ b/src/vector/tests/convert_geo.rs @@ -1,5 +1,5 @@ +use crate::vector::{Geometry, ToGdal}; use geo_types; -use vector::{Geometry, ToGdal}; #[test] fn test_import_export_point() { diff --git a/src/vector/tests/mod.rs b/src/vector/tests/mod.rs index b69fa4c5..c9228f2e 100644 --- a/src/vector/tests/mod.rs +++ b/src/vector/tests/mod.rs @@ -1,20 +1,29 @@ +use super::{ + Dataset, Driver, Feature, FeatureIterator, FieldValue, Geometry, OGRFieldType, + OGRwkbGeometryType, +}; +use crate::assert_almost_eq; +use crate::spatial_ref::SpatialRef; use std::path::Path; -use super::{Driver, Dataset, Feature, FeatureIterator, FieldValue, Geometry, OGRFieldType, OGRwkbGeometryType}; -use spatial_ref::SpatialRef; -use assert_almost_eq; mod convert_geo; macro_rules! fixture { - ($name:expr) => ( + ($name:expr) => { Path::new(file!()) - .parent().unwrap() - .parent().unwrap() - .parent().unwrap() - .parent().unwrap() - .join("fixtures").as_path() - .join($name).as_path() - ) + .parent() + .unwrap() + .parent() + .unwrap() + .parent() + .unwrap() + .parent() + .unwrap() + .join("fixtures") + .as_path() + .join($name) + .as_path() + }; } #[test] @@ -43,18 +52,22 @@ fn test_layer_spatial_reference() { assert_eq!(srs.auth_code().unwrap(), 4326); } -fn with_features(name: &str, f: F) where F: Fn(FeatureIterator) { +fn with_features(name: &str, f: F) +where + F: Fn(FeatureIterator), +{ let mut ds = Dataset::open(fixture!(name)).unwrap(); let layer = ds.layer(0).unwrap(); f(layer.features()); } - -fn with_first_feature(name: &str, f: F) where F: Fn(Feature) { +fn with_first_feature(name: &str, f: F) +where + F: Fn(Feature), +{ with_features(name, |mut features| f(features.next().unwrap())); } - #[test] fn test_iterate_features() { with_features("roads.geojson", |features| { @@ -62,41 +75,36 @@ fn test_iterate_features() { }); } - #[test] fn test_string_field() { with_features("roads.geojson", |mut features| { let feature = features.next().unwrap(); - assert_eq!(feature.field("highway") - .unwrap() - .into_string(), - Some("footway".to_string())); assert_eq!( - features.filter(|field| { - let highway = field.field("highway") - .unwrap() - .into_string(); - highway == Some("residential".to_string()) }) + feature.field("highway").unwrap().into_string(), + Some("footway".to_string()) + ); + assert_eq!( + features + .filter(|field| { + let highway = field.field("highway").unwrap().into_string(); + highway == Some("residential".to_string()) + }) .count(), - 2); + 2 + ); }); } - #[test] fn test_float_field() { with_first_feature("roads.geojson", |feature| { assert_almost_eq( - feature.field("sort_key") - .unwrap() - .into_real() - .unwrap(), - -9.0 + feature.field("sort_key").unwrap().into_real().unwrap(), + -9.0, ); }); } - #[test] fn test_missing_field() { with_first_feature("roads.geojson", |feature| { @@ -104,14 +112,20 @@ fn test_missing_field() { }); } - #[test] fn test_geom_accessors() { with_first_feature("roads.geojson", |feature| { let geom = feature.geometry(); assert_eq!(geom.geometry_type(), OGRwkbGeometryType::wkbLineString); let coords = geom.get_point_vec(); - assert_eq!(coords, [(26.1019276, 44.4302748, 0.0), (26.1019382, 44.4303191, 0.0), (26.1020002, 44.4304202, 0.0)]); + assert_eq!( + coords, + [ + (26.1019276, 44.4302748, 0.0), + (26.1019382, 44.4303191, 0.0), + (26.1020002, 44.4304202, 0.0) + ] + ); assert_eq!(geom.geometry_count(), 0); let geom = feature.geometry_by_index(0).unwrap(); @@ -125,35 +139,33 @@ fn test_geom_accessors() { }); } - #[test] fn test_wkt() { with_first_feature("roads.geojson", |feature| { let wkt = feature.geometry().wkt().unwrap(); - let wkt_ok = format!("{}{}", - "LINESTRING (26.1019276 44.4302748,", - "26.1019382 44.4303191,26.1020002 44.4304202)" - ); + let wkt_ok = format!( + "{}{}", + "LINESTRING (26.1019276 44.4302748,", "26.1019382 44.4303191,26.1020002 44.4304202)" + ); assert_eq!(wkt, wkt_ok); }); } - #[test] fn test_json() { with_first_feature("roads.geojson", |feature| { let json = feature.geometry().json(); - let json_ok = format!("{}{}{}{}", + let json_ok = format!( + "{}{}{}{}", "{ \"type\": \"LineString\", \"coordinates\": [ ", "[ 26.1019276, 44.4302748 ], ", "[ 26.1019382, 44.4303191 ], ", "[ 26.1020002, 44.4304202 ] ] }" - ); + ); assert_eq!(json.unwrap(), json_ok); }); } - #[test] fn test_schema() { let mut ds = Dataset::open(fixture!("roads.geojson")).unwrap(); @@ -161,19 +173,23 @@ fn test_schema() { // The layer name is "roads" in GDAL 2.2 assert!(layer.name() == "OGRGeoJSON" || layer.name() == "roads"); let name_list = layer - .defn().fields() + .defn() + .fields() .map(|f| (f.name(), f.field_type())) .collect::>(); - let ok_names_types = vec!( + let ok_names_types = vec![ ("id", OGRFieldType::OFTString), ("kind", OGRFieldType::OFTString), - ("sort_key", OGRFieldType::OFTReal), + ("sort_key", OGRFieldType::OFTReal), ("is_link", OGRFieldType::OFTString), ("is_tunnel", OGRFieldType::OFTString), ("is_bridge", OGRFieldType::OFTString), ("railway", OGRFieldType::OFTString), - ("highway", OGRFieldType::OFTString)) - .iter().map(|s| (s.0.to_string(), s.1)).collect::>(); + ("highway", OGRFieldType::OFTString), + ] + .iter() + .map(|s| (s.0.to_string(), s.1)) + .collect::>(); assert_eq!(name_list, ok_names_types); } @@ -182,12 +198,14 @@ fn test_geom_fields() { let mut ds = Dataset::open(fixture!("roads.geojson")).unwrap(); let layer = ds.layer(0).unwrap(); let name_list = layer - .defn().geom_fields() + .defn() + .geom_fields() .map(|f| (f.name(), f.field_type())) .collect::>(); - let ok_names_types = vec!( - ("", OGRwkbGeometryType::wkbLineString)) - .iter().map(|s| (s.0.to_string(), s.1.clone())).collect::>(); + let ok_names_types = vec![("", OGRwkbGeometryType::wkbLineString)] + .iter() + .map(|s| (s.0.to_string(), s.1.clone())) + .collect::>(); assert_eq!(name_list, ok_names_types); let geom_field = layer.defn().geom_fields().next().unwrap(); @@ -231,7 +249,15 @@ fn test_spatial_filter() { fn test_convex_hull() { let star = "POLYGON ((0 1,3 1,1 3,1.5 0.0,2 3,0 1))"; let hull = "POLYGON ((1.5 0.0,0 1,1 3,2 3,3 1,1.5 0.0))"; - assert_eq!(Geometry::from_wkt(star).unwrap().convex_hull().unwrap().wkt().unwrap(), hull); + assert_eq!( + Geometry::from_wkt(star) + .unwrap() + .convex_hull() + .unwrap() + .wkt() + .unwrap(), + hull + ); } #[test] @@ -242,11 +268,24 @@ fn test_write_features() { let driver = Driver::get("GeoJSON").unwrap(); let mut ds = driver.create(fixture!("output.geojson")).unwrap(); let layer = ds.create_layer().unwrap(); - layer.create_defn_fields(&[("Name", OGRFieldType::OFTString), ("Value", OGRFieldType::OFTReal), ("Int_value", OGRFieldType::OFTInteger)]).unwrap(); - layer.create_feature_fields( - Geometry::from_wkt("POINT (1 2)").unwrap(), &["Name", "Value", "Int_value"], - &[FieldValue::StringValue("Feature 1".to_string()), FieldValue::RealValue(45.78), FieldValue::IntegerValue(1)] - ).unwrap(); + layer + .create_defn_fields(&[ + ("Name", OGRFieldType::OFTString), + ("Value", OGRFieldType::OFTReal), + ("Int_value", OGRFieldType::OFTInteger), + ]) + .unwrap(); + layer + .create_feature_fields( + Geometry::from_wkt("POINT (1 2)").unwrap(), + &["Name", "Value", "Int_value"], + &[ + FieldValue::StringValue("Feature 1".to_string()), + FieldValue::RealValue(45.78), + FieldValue::IntegerValue(1), + ], + ) + .unwrap(); // dataset is closed here } @@ -255,7 +294,10 @@ fn test_write_features() { let layer = ds.layer(0).unwrap(); let ft = layer.features().next().unwrap(); assert_eq!(ft.geometry().wkt().unwrap(), "POINT (1 2)"); - assert_eq!(ft.field("Name").unwrap().into_string(), Some("Feature 1".to_string())); + assert_eq!( + ft.field("Name").unwrap().into_string(), + Some("Feature 1".to_string()) + ); assert_eq!(ft.field("Value").unwrap().into_real(), Some(45.78)); assert_eq!(ft.field("Int_value").unwrap().into_int(), Some(1)); } diff --git a/src/version.rs b/src/version.rs index dcf51e29..83b73ed6 100644 --- a/src/version.rs +++ b/src/version.rs @@ -1,6 +1,6 @@ -use std::ffi::CString; -use utils::_string; +use crate::utils::_string; use gdal_sys; +use std::ffi::CString; pub fn version_info(key: &str) -> String { let c_key = CString::new(key.as_bytes()).unwrap(); From 1201df3cbd0dba5a327e82b4042f5f4f5a06f195 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20Dr=C3=B6nner?= Date: Wed, 17 Jun 2020 09:51:04 +0200 Subject: [PATCH 2/6] remove extern crate --- examples/metadata.rs | 2 -- examples/rasterband.rs | 2 -- examples/read_write_ogr.rs | 2 -- examples/read_write_ogr_datetime.rs | 4 ---- examples/spatial_reference.rs | 2 -- examples/write_ogr.rs | 2 -- gdal-sys/build.rs | 4 ++-- src/lib.rs | 6 ------ 8 files changed, 2 insertions(+), 22 deletions(-) diff --git a/examples/metadata.rs b/examples/metadata.rs index 3816daa6..a1915c41 100644 --- a/examples/metadata.rs +++ b/examples/metadata.rs @@ -1,5 +1,3 @@ -extern crate gdal; - fn main() { use gdal::metadata::Metadata; use gdal::raster::dataset::Dataset; diff --git a/examples/rasterband.rs b/examples/rasterband.rs index ddba86c0..b0cf3812 100644 --- a/examples/rasterband.rs +++ b/examples/rasterband.rs @@ -1,5 +1,3 @@ -extern crate gdal; - use gdal::metadata::Metadata; use gdal::raster::{Dataset, RasterBand}; use std::path::Path; diff --git a/examples/read_write_ogr.rs b/examples/read_write_ogr.rs index a3b963b0..27d748f5 100644 --- a/examples/read_write_ogr.rs +++ b/examples/read_write_ogr.rs @@ -1,5 +1,3 @@ -extern crate gdal; - use gdal::errors::Error; use gdal::spatial_ref::{CoordTransform, SpatialRef}; use gdal::vector::*; diff --git a/examples/read_write_ogr_datetime.rs b/examples/read_write_ogr_datetime.rs index de6112f0..57833658 100644 --- a/examples/read_write_ogr_datetime.rs +++ b/examples/read_write_ogr_datetime.rs @@ -1,7 +1,3 @@ -#[cfg(feature = "datetime")] -extern crate chrono; -extern crate gdal; - #[cfg(feature = "datetime")] use chrono::Duration; use gdal::errors::Error; diff --git a/examples/spatial_reference.rs b/examples/spatial_reference.rs index 26ed80a7..1f06f41e 100644 --- a/examples/spatial_reference.rs +++ b/examples/spatial_reference.rs @@ -1,5 +1,3 @@ -extern crate gdal; - use gdal::spatial_ref::{CoordTransform, SpatialRef}; use gdal::vector::Geometry; diff --git a/examples/write_ogr.rs b/examples/write_ogr.rs index fa43a5d5..28e2fabc 100644 --- a/examples/write_ogr.rs +++ b/examples/write_ogr.rs @@ -1,5 +1,3 @@ -extern crate gdal; - use gdal::errors::Error; use gdal::vector::{Defn, Driver, Feature, FieldDefn, FieldValue, Geometry, OGRFieldType}; use std::fs; diff --git a/gdal-sys/build.rs b/gdal-sys/build.rs index 92b91438..b810f700 100644 --- a/gdal-sys/build.rs +++ b/gdal-sys/build.rs @@ -1,6 +1,6 @@ #[cfg(feature = "bindgen")] -extern crate bindgen; -extern crate pkg_config; +use bindgen; +use pkg_config; use pkg_config::Config; use std::env; diff --git a/src/lib.rs b/src/lib.rs index 012c47ee..a3a1cca3 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -20,12 +20,6 @@ #![crate_name = "gdal"] #![crate_type = "lib"] -#[cfg(feature = "ndarray")] -extern crate ndarray; - -#[cfg(feature = "datetime")] -extern crate chrono; - pub use version::version_info; pub mod config; From c67c200d879cd5c60f8c7abcb80ca0380d6fa599 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20Dr=C3=B6nner?= Date: Wed, 17 Jun 2020 10:00:53 +0200 Subject: [PATCH 3/6] fix example --- examples/read_write_ogr_datetime.rs | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/examples/read_write_ogr_datetime.rs b/examples/read_write_ogr_datetime.rs index 57833658..32422899 100644 --- a/examples/read_write_ogr_datetime.rs +++ b/examples/read_write_ogr_datetime.rs @@ -1,6 +1,9 @@ #[cfg(feature = "datetime")] use chrono::Duration; use gdal::errors::Error; +use gdal::vector::*; +use std::path::Path; +use std::ops::Add; #[cfg(feature = "datetime")] fn run() -> Result<(), Error> { @@ -10,7 +13,7 @@ fn run() -> Result<(), Error> { let layer_a = dataset_a.layer(0)?; // Create a new dataset: - let _ = fs::remove_file("/tmp/later.geojson"); + let _ = std::fs::remove_file("/tmp/later.geojson"); let drv = Driver::get("GeoJSON")?; let mut ds = drv.create(Path::new("/tmp/later.geojson"))?; let lyr = ds.create_layer()?; From 75eb5048960f16c1fd8398be8e2df00476b2228f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20Dr=C3=B6nner?= Date: Wed, 17 Jun 2020 10:02:20 +0200 Subject: [PATCH 4/6] add gdal 3.0 bindings --- Cargo.toml | 6 +- gdal-sys/Cargo.toml | 1 + gdal-sys/build.rs | 2 + gdal-sys/prebuilt-bindings/gdal_3.0.rs | 11004 +++++++++++++++++++++++ 4 files changed, 11011 insertions(+), 2 deletions(-) create mode 100644 gdal-sys/prebuilt-bindings/gdal_3.0.rs diff --git a/Cargo.toml b/Cargo.toml index 4432a42e..93fc4e48 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -14,6 +14,8 @@ edition = "2018" [features] bindgen = ["gdal-sys/bindgen"] gdal_2_2 = ["gdal-sys/min_gdal_version_2_2"] +gdal_2_4 = ["gdal-sys/min_gdal_version_2_4"] +gdal_3_0 = ["gdal-sys/min_gdal_version_3_0"] array = ["ndarray"] datetime = ["chrono"] @@ -22,8 +24,8 @@ failure = "0.1" failure_derive = "0.1" libc = "0.2" geo-types = "0.4" -# gdal-sys = { path = "gdal-sys", version = "0.2"} -gdal-sys = "0.2" +gdal-sys = { path = "gdal-sys", version = "0.2"} +#gdal-sys = "0.2" num-traits = "0.2" ndarray = {version = "0.12.1", optional = true } chrono = { version = "0.4", optional = true } diff --git a/gdal-sys/Cargo.toml b/gdal-sys/Cargo.toml index 294d2257..8131698f 100644 --- a/gdal-sys/Cargo.toml +++ b/gdal-sys/Cargo.toml @@ -15,6 +15,7 @@ min_gdal_version_2_1 = [] min_gdal_version_2_2 = [] min_gdal_version_2_3 = [] min_gdal_version_2_4 = [] +min_gdal_version_3_0 = [] [dependencies] libc = "0.2" diff --git a/gdal-sys/build.rs b/gdal-sys/build.rs index b810f700..e66ed83d 100644 --- a/gdal-sys/build.rs +++ b/gdal-sys/build.rs @@ -186,6 +186,8 @@ fn main() { "prebuilt-bindings/gdal_2.3.rs", #[cfg(feature = "min_gdal_version_2_4")] "prebuilt-bindings/gdal_2.4.rs", + #[cfg(feature = "min_gdal_version_3_0")] + "prebuilt-bindings/gdal_3.0.rs", ]; std::fs::copy(&prebuilt_paths[prebuilt_paths.len() - 1], &out_path) .expect("Can't copy bindings to output directory"); diff --git a/gdal-sys/prebuilt-bindings/gdal_3.0.rs b/gdal-sys/prebuilt-bindings/gdal_3.0.rs new file mode 100644 index 00000000..4803f972 --- /dev/null +++ b/gdal-sys/prebuilt-bindings/gdal_3.0.rs @@ -0,0 +1,11004 @@ +/* automatically generated by rust-bindgen */ + +pub type size_t = libc::c_ulong; +pub type va_list = __builtin_va_list; +pub type __dev_t = libc::c_ulong; +pub type __uid_t = libc::c_uint; +pub type __gid_t = libc::c_uint; +pub type __ino_t = libc::c_ulong; +pub type __mode_t = libc::c_uint; +pub type __nlink_t = libc::c_ulong; +pub type __off_t = libc::c_long; +pub type __off64_t = libc::c_long; +pub type __time_t = libc::c_long; +pub type __blksize_t = libc::c_long; +pub type __blkcnt_t = libc::c_long; +pub type __syscall_slong_t = libc::c_long; +pub type FILE = _IO_FILE; +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct _IO_marker { + _unused: [u8; 0], +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct _IO_codecvt { + _unused: [u8; 0], +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct _IO_wide_data { + _unused: [u8; 0], +} +pub type _IO_lock_t = libc::c_void; +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct _IO_FILE { + pub _flags: libc::c_int, + pub _IO_read_ptr: *mut libc::c_char, + pub _IO_read_end: *mut libc::c_char, + pub _IO_read_base: *mut libc::c_char, + pub _IO_write_base: *mut libc::c_char, + pub _IO_write_ptr: *mut libc::c_char, + pub _IO_write_end: *mut libc::c_char, + pub _IO_buf_base: *mut libc::c_char, + pub _IO_buf_end: *mut libc::c_char, + pub _IO_save_base: *mut libc::c_char, + pub _IO_backup_base: *mut libc::c_char, + pub _IO_save_end: *mut libc::c_char, + pub _markers: *mut _IO_marker, + pub _chain: *mut _IO_FILE, + pub _fileno: libc::c_int, + pub _flags2: libc::c_int, + pub _old_offset: __off_t, + pub _cur_column: libc::c_ushort, + pub _vtable_offset: libc::c_schar, + pub _shortbuf: [libc::c_char; 1usize], + pub _lock: *mut _IO_lock_t, + pub _offset: __off64_t, + pub _codecvt: *mut _IO_codecvt, + pub _wide_data: *mut _IO_wide_data, + pub _freeres_list: *mut _IO_FILE, + pub _freeres_buf: *mut libc::c_void, + pub __pad5: size_t, + pub _mode: libc::c_int, + pub _unused2: [libc::c_char; 20usize], +} +#[test] +fn bindgen_test_layout__IO_FILE() { + assert_eq!( + ::std::mem::size_of::<_IO_FILE>(), + 216usize, + concat!("Size of: ", stringify!(_IO_FILE)) + ); + assert_eq!( + ::std::mem::align_of::<_IO_FILE>(), + 8usize, + concat!("Alignment of ", stringify!(_IO_FILE)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._flags as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_flags) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_read_ptr as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_read_ptr) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_read_end as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_read_end) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_read_base as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_read_base) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_write_base as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_write_base) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_write_ptr as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_write_ptr) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_write_end as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_write_end) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_buf_base as *const _ as usize }, + 56usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_buf_base) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_buf_end as *const _ as usize }, + 64usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_buf_end) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_save_base as *const _ as usize }, + 72usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_save_base) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_backup_base as *const _ as usize }, + 80usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_backup_base) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._IO_save_end as *const _ as usize }, + 88usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_IO_save_end) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._markers as *const _ as usize }, + 96usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_markers) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._chain as *const _ as usize }, + 104usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_chain) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._fileno as *const _ as usize }, + 112usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_fileno) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._flags2 as *const _ as usize }, + 116usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_flags2) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._old_offset as *const _ as usize }, + 120usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_old_offset) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._cur_column as *const _ as usize }, + 128usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_cur_column) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._vtable_offset as *const _ as usize }, + 130usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_vtable_offset) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._shortbuf as *const _ as usize }, + 131usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_shortbuf) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._lock as *const _ as usize }, + 136usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_lock) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._offset as *const _ as usize }, + 144usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_offset) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._codecvt as *const _ as usize }, + 152usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_codecvt) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._wide_data as *const _ as usize }, + 160usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_wide_data) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._freeres_list as *const _ as usize }, + 168usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_freeres_list) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._freeres_buf as *const _ as usize }, + 176usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_freeres_buf) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>())).__pad5 as *const _ as usize }, + 184usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(__pad5) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._mode as *const _ as usize }, + 192usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_mode) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<_IO_FILE>()))._unused2 as *const _ as usize }, + 196usize, + concat!( + "Offset of field: ", + stringify!(_IO_FILE), + "::", + stringify!(_unused2) + ) + ); +} +pub type time_t = __time_t; +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct timespec { + pub tv_sec: __time_t, + pub tv_nsec: __syscall_slong_t, +} +#[test] +fn bindgen_test_layout_timespec() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(timespec)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(timespec)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tv_sec as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(timespec), + "::", + stringify!(tv_sec) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tv_nsec as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(timespec), + "::", + stringify!(tv_nsec) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct tm { + pub tm_sec: libc::c_int, + pub tm_min: libc::c_int, + pub tm_hour: libc::c_int, + pub tm_mday: libc::c_int, + pub tm_mon: libc::c_int, + pub tm_year: libc::c_int, + pub tm_wday: libc::c_int, + pub tm_yday: libc::c_int, + pub tm_isdst: libc::c_int, + pub tm_gmtoff: libc::c_long, + pub tm_zone: *const libc::c_char, +} +#[test] +fn bindgen_test_layout_tm() { + assert_eq!( + ::std::mem::size_of::(), + 56usize, + concat!("Size of: ", stringify!(tm)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(tm)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_sec as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_sec) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_min as *const _ as usize }, + 4usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_min) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_hour as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_hour) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_mday as *const _ as usize }, + 12usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_mday) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_mon as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_mon) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_year as *const _ as usize }, + 20usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_year) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_wday as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_wday) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_yday as *const _ as usize }, + 28usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_yday) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_isdst as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_isdst) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_gmtoff as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_gmtoff) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).tm_zone as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(tm), + "::", + stringify!(tm_zone) + ) + ); +} +#[doc = " Int32 type"] +pub type GInt32 = libc::c_int; +#[doc = " Unsigned int32 type"] +pub type GUInt32 = libc::c_uint; +#[doc = " Int16 type"] +pub type GInt16 = libc::c_short; +#[doc = " Unsigned byte type"] +pub type GByte = libc::c_uchar; +#[doc = " Large signed integer type (generally 64-bit integer type)."] +#[doc = " Use GInt64 when exactly 64 bit is needed"] +pub type GIntBig = libc::c_longlong; +#[doc = " Large unsigned integer type (generally 64-bit unsigned integer type)."] +#[doc = " Use GUInt64 when exactly 64 bit is needed"] +pub type GUIntBig = libc::c_ulonglong; +#[doc = " Integer type large enough to hold the difference between 2 addresses"] +pub type GPtrDiff_t = GIntBig; +#[doc = " Type of a constant null-terminated list of nul terminated strings."] +#[doc = " Seen as char** from C and const char* const* from C++"] +pub type CSLConstList = *mut *mut libc::c_char; +pub type GDALProgressFunc = ::std::option::Option< + unsafe extern "C" fn( + dfComplete: f64, + pszMessage: *const libc::c_char, + pProgressArg: *mut libc::c_void, + ) -> libc::c_int, +>; +extern "C" { + pub fn GDALDummyProgress( + arg1: f64, + arg2: *const libc::c_char, + arg3: *mut libc::c_void, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALTermProgress( + arg1: f64, + arg2: *const libc::c_char, + arg3: *mut libc::c_void, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALScaledProgress( + arg1: f64, + arg2: *const libc::c_char, + arg3: *mut libc::c_void, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateScaledProgress( + arg1: f64, + arg2: f64, + arg3: GDALProgressFunc, + arg4: *mut libc::c_void, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALDestroyScaledProgress(arg1: *mut libc::c_void); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct stat { + pub st_dev: __dev_t, + pub st_ino: __ino_t, + pub st_nlink: __nlink_t, + pub st_mode: __mode_t, + pub st_uid: __uid_t, + pub st_gid: __gid_t, + pub __pad0: libc::c_int, + pub st_rdev: __dev_t, + pub st_size: __off_t, + pub st_blksize: __blksize_t, + pub st_blocks: __blkcnt_t, + pub st_atim: timespec, + pub st_mtim: timespec, + pub st_ctim: timespec, + pub __glibc_reserved: [__syscall_slong_t; 3usize], +} +#[test] +fn bindgen_test_layout_stat() { + assert_eq!( + ::std::mem::size_of::(), + 144usize, + concat!("Size of: ", stringify!(stat)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(stat)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_dev as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_dev) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_ino as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_ino) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_nlink as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_nlink) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_mode as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_mode) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_uid as *const _ as usize }, + 28usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_uid) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_gid as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_gid) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).__pad0 as *const _ as usize }, + 36usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(__pad0) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_rdev as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_rdev) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_size as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_size) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_blksize as *const _ as usize }, + 56usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_blksize) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_blocks as *const _ as usize }, + 64usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_blocks) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_atim as *const _ as usize }, + 72usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_atim) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_mtim as *const _ as usize }, + 88usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_mtim) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).st_ctim as *const _ as usize }, + 104usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(st_ctim) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).__glibc_reserved as *const _ as usize }, + 120usize, + concat!( + "Offset of field: ", + stringify!(stat), + "::", + stringify!(__glibc_reserved) + ) + ); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn VSIFOpen(arg1: *const libc::c_char, arg2: *const libc::c_char) -> *mut FILE; +} +extern "C" { + pub fn VSIFClose(arg1: *mut FILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFSeek(arg1: *mut FILE, arg2: libc::c_long, arg3: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn VSIFTell(arg1: *mut FILE) -> libc::c_long; +} +extern "C" { + pub fn VSIRewind(arg1: *mut FILE); +} +extern "C" { + pub fn VSIFFlush(arg1: *mut FILE); +} +extern "C" { + pub fn VSIFRead(arg1: *mut libc::c_void, arg2: size_t, arg3: size_t, arg4: *mut FILE) + -> size_t; +} +extern "C" { + pub fn VSIFWrite( + arg1: *const libc::c_void, + arg2: size_t, + arg3: size_t, + arg4: *mut FILE, + ) -> size_t; +} +extern "C" { + pub fn VSIFGets( + arg1: *mut libc::c_char, + arg2: libc::c_int, + arg3: *mut FILE, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn VSIFPuts(arg1: *const libc::c_char, arg2: *mut FILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFPrintf(arg1: *mut FILE, arg2: *const libc::c_char, ...) -> libc::c_int; +} +extern "C" { + pub fn VSIFGetc(arg1: *mut FILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFPutc(arg1: libc::c_int, arg2: *mut FILE) -> libc::c_int; +} +extern "C" { + pub fn VSIUngetc(arg1: libc::c_int, arg2: *mut FILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFEof(arg1: *mut FILE) -> libc::c_int; +} +#[doc = " @cond Doxygen_Suppress"] +pub type VSIStatBuf = stat; +extern "C" { + pub fn VSIStat(arg1: *const libc::c_char, arg2: *mut VSIStatBuf) -> libc::c_int; +} +#[doc = " Type for a file offset"] +pub type vsi_l_offset = GUIntBig; +#[doc = " Opaque type for a FILE that implements the VSIVirtualHandle API"] +pub type VSILFILE = FILE; +extern "C" { + pub fn VSIFOpenL(arg1: *const libc::c_char, arg2: *const libc::c_char) -> *mut VSILFILE; +} +extern "C" { + pub fn VSIFOpenExL( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + arg3: libc::c_int, + ) -> *mut VSILFILE; +} +extern "C" { + pub fn VSIFCloseL(arg1: *mut VSILFILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFSeekL(arg1: *mut VSILFILE, arg2: vsi_l_offset, arg3: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn VSIFTellL(arg1: *mut VSILFILE) -> vsi_l_offset; +} +extern "C" { + pub fn VSIRewindL(arg1: *mut VSILFILE); +} +extern "C" { + pub fn VSIFReadL( + arg1: *mut libc::c_void, + arg2: size_t, + arg3: size_t, + arg4: *mut VSILFILE, + ) -> size_t; +} +extern "C" { + pub fn VSIFReadMultiRangeL( + nRanges: libc::c_int, + ppData: *mut *mut libc::c_void, + panOffsets: *const vsi_l_offset, + panSizes: *const size_t, + arg1: *mut VSILFILE, + ) -> libc::c_int; +} +extern "C" { + pub fn VSIFWriteL( + arg1: *const libc::c_void, + arg2: size_t, + arg3: size_t, + arg4: *mut VSILFILE, + ) -> size_t; +} +extern "C" { + pub fn VSIFEofL(arg1: *mut VSILFILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFTruncateL(arg1: *mut VSILFILE, arg2: vsi_l_offset) -> libc::c_int; +} +extern "C" { + pub fn VSIFFlushL(arg1: *mut VSILFILE) -> libc::c_int; +} +extern "C" { + pub fn VSIFPrintfL(arg1: *mut VSILFILE, arg2: *const libc::c_char, ...) -> libc::c_int; +} +extern "C" { + pub fn VSIFPutcL(arg1: libc::c_int, arg2: *mut VSILFILE) -> libc::c_int; +} +pub mod VSIRangeStatus { + #[doc = " Range status"] + pub type Type = u32; + #[doc = "< Unknown"] + pub const VSI_RANGE_STATUS_UNKNOWN: Type = 0; + #[doc = "< Data present"] + pub const VSI_RANGE_STATUS_DATA: Type = 1; + #[doc = "< Hole"] + pub const VSI_RANGE_STATUS_HOLE: Type = 2; +} +extern "C" { + pub fn VSIFGetRangeStatusL( + fp: *mut VSILFILE, + nStart: vsi_l_offset, + nLength: vsi_l_offset, + ) -> VSIRangeStatus::Type; +} +extern "C" { + pub fn VSIIngestFile( + fp: *mut VSILFILE, + pszFilename: *const libc::c_char, + ppabyRet: *mut *mut GByte, + pnSize: *mut vsi_l_offset, + nMaxSize: GIntBig, + ) -> libc::c_int; +} +extern "C" { + pub fn VSIOverwriteFile( + fpTarget: *mut VSILFILE, + pszSourceFilename: *const libc::c_char, + ) -> libc::c_int; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct stat64 { + _unused: [u8; 0], +} +#[doc = " Type for VSIStatL()"] +pub type VSIStatBufL = stat64; +extern "C" { + pub fn VSIStatL(arg1: *const libc::c_char, arg2: *mut VSIStatBufL) -> libc::c_int; +} +extern "C" { + pub fn VSIStatExL( + pszFilename: *const libc::c_char, + psStatBuf: *mut VSIStatBufL, + nFlags: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn VSIIsCaseSensitiveFS(pszFilename: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSISupportsSparseFiles(pszPath: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSIHasOptimizedReadMultiRange(pszPath: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSIGetActualURL(pszFilename: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn VSIGetSignedURL( + pszFilename: *const libc::c_char, + papszOptions: CSLConstList, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn VSIGetFileSystemOptions(pszFilename: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn VSIGetFileSystemsPrefixes() -> *mut *mut libc::c_char; +} +extern "C" { + pub fn VSIFGetNativeFileDescriptorL(arg1: *mut VSILFILE) -> *mut libc::c_void; +} +extern "C" { + pub fn VSICalloc(arg1: size_t, arg2: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn VSIMalloc(arg1: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn VSIFree(arg1: *mut libc::c_void); +} +extern "C" { + pub fn VSIRealloc(arg1: *mut libc::c_void, arg2: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn VSIStrdup(arg1: *const libc::c_char) -> *mut libc::c_char; +} +extern "C" { + pub fn VSIMallocAligned(nAlignment: size_t, nSize: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn VSIMallocAlignedAuto(nSize: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn VSIFreeAligned(ptr: *mut libc::c_void); +} +extern "C" { + pub fn VSIMallocAlignedAutoVerbose( + nSize: size_t, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = "VSIMalloc2 allocates (nSize1 * nSize2) bytes."] + #[doc = "In case of overflow of the multiplication, or if memory allocation fails, a"] + #[doc = "NULL pointer is returned and a CE_Failure error is raised with CPLError()."] + #[doc = "If nSize1 == 0 || nSize2 == 0, a NULL pointer will also be returned."] + #[doc = "CPLFree() or VSIFree() can be used to free memory allocated by this function."] + pub fn VSIMalloc2(nSize1: size_t, nSize2: size_t) -> *mut libc::c_void; +} +extern "C" { + #[doc = "VSIMalloc3 allocates (nSize1 * nSize2 * nSize3) bytes."] + #[doc = "In case of overflow of the multiplication, or if memory allocation fails, a"] + #[doc = "NULL pointer is returned and a CE_Failure error is raised with CPLError()."] + #[doc = "If nSize1 == 0 || nSize2 == 0 || nSize3 == 0, a NULL pointer will also be returned."] + #[doc = "CPLFree() or VSIFree() can be used to free memory allocated by this function."] + pub fn VSIMalloc3(nSize1: size_t, nSize2: size_t, nSize3: size_t) -> *mut libc::c_void; +} +extern "C" { + #[doc = " VSIMallocVerbose"] + pub fn VSIMallocVerbose( + nSize: size_t, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = " VSIMalloc2Verbose"] + pub fn VSIMalloc2Verbose( + nSize1: size_t, + nSize2: size_t, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = " VSIMalloc3Verbose"] + pub fn VSIMalloc3Verbose( + nSize1: size_t, + nSize2: size_t, + nSize3: size_t, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = " VSICallocVerbose"] + pub fn VSICallocVerbose( + nCount: size_t, + nSize: size_t, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = " VSIReallocVerbose"] + pub fn VSIReallocVerbose( + pOldPtr: *mut libc::c_void, + nNewSize: size_t, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = " VSIStrdupVerbose"] + pub fn VSIStrdupVerbose( + pszStr: *const libc::c_char, + pszFile: *const libc::c_char, + nLine: libc::c_int, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn CPLGetPhysicalRAM() -> GIntBig; +} +extern "C" { + pub fn CPLGetUsablePhysicalRAM() -> GIntBig; +} +extern "C" { + pub fn VSIReadDir(arg1: *const libc::c_char) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn VSIReadDirRecursive(pszPath: *const libc::c_char) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn VSIReadDirEx( + pszPath: *const libc::c_char, + nMaxFiles: libc::c_int, + ) -> *mut *mut libc::c_char; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct VSIDIR { + _unused: [u8; 0], +} +extern "C" { + pub fn VSIOpenDir( + pszPath: *const libc::c_char, + nRecurseDepth: libc::c_int, + papszOptions: *const *const libc::c_char, + ) -> *mut VSIDIR; +} +#[doc = " Directory entry."] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct VSIDIREntry { + #[doc = " Filename"] + pub pszName: *mut libc::c_char, + #[doc = " File mode. See VSI_ISREG() / VSI_ISDIR()"] + pub nMode: libc::c_int, + #[doc = " File size"] + pub nSize: vsi_l_offset, + #[doc = " Last modification time (seconds since 1970/01/01)"] + pub nMTime: GIntBig, + #[doc = " Whether nMode is known: 0 = unknown, 1 = known."] + pub bModeKnown: libc::c_char, + #[doc = " Whether nSize is known: 0 = unknown, 1 = known."] + pub bSizeKnown: libc::c_char, + #[doc = " Whether nMTime is known: 0 = unknown, 1 = known."] + pub bMTimeKnown: libc::c_char, + #[doc = " NULL-terminated list of extra properties."] + pub papszExtra: *mut *mut libc::c_char, +} +#[test] +fn bindgen_test_layout_VSIDIREntry() { + assert_eq!( + ::std::mem::size_of::(), + 48usize, + concat!("Size of: ", stringify!(VSIDIREntry)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(VSIDIREntry)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszName as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(pszName) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nMode as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(nMode) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nSize as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(nSize) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nMTime as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(nMTime) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).bModeKnown as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(bModeKnown) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).bSizeKnown as *const _ as usize }, + 33usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(bSizeKnown) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).bMTimeKnown as *const _ as usize }, + 34usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(bMTimeKnown) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).papszExtra as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(VSIDIREntry), + "::", + stringify!(papszExtra) + ) + ); +} +extern "C" { + pub fn VSIGetNextDirEntry(dir: *mut VSIDIR) -> *const VSIDIREntry; +} +extern "C" { + pub fn VSICloseDir(dir: *mut VSIDIR); +} +extern "C" { + pub fn VSIMkdir(pszPathname: *const libc::c_char, mode: libc::c_long) -> libc::c_int; +} +extern "C" { + pub fn VSIMkdirRecursive(pszPathname: *const libc::c_char, mode: libc::c_long) -> libc::c_int; +} +extern "C" { + pub fn VSIRmdir(pszDirname: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSIRmdirRecursive(pszDirname: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSIUnlink(pszFilename: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSIRename(oldpath: *const libc::c_char, newpath: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn VSISync( + pszSource: *const libc::c_char, + pszTarget: *const libc::c_char, + papszOptions: *const *const libc::c_char, + pProgressFunc: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ppapszOutputs: *mut *mut *mut libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn VSIStrerror(arg1: libc::c_int) -> *mut libc::c_char; +} +extern "C" { + pub fn VSIGetDiskFreeSpace(pszDirname: *const libc::c_char) -> GIntBig; +} +extern "C" { + pub fn VSIInstallMemFileHandler(); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn VSIInstallLargeFileHandler(); +} +extern "C" { + #[doc = " @endcond"] + pub fn VSIInstallSubFileHandler(); +} +extern "C" { + pub fn VSIInstallCurlFileHandler(); +} +extern "C" { + pub fn VSICurlClearCache(); +} +extern "C" { + pub fn VSICurlPartialClearCache(pszFilenamePrefix: *const libc::c_char); +} +extern "C" { + pub fn VSIInstallCurlStreamingFileHandler(); +} +extern "C" { + pub fn VSIInstallS3FileHandler(); +} +extern "C" { + pub fn VSIInstallS3StreamingFileHandler(); +} +extern "C" { + pub fn VSIInstallGSFileHandler(); +} +extern "C" { + pub fn VSIInstallGSStreamingFileHandler(); +} +extern "C" { + pub fn VSIInstallAzureFileHandler(); +} +extern "C" { + pub fn VSIInstallAzureStreamingFileHandler(); +} +extern "C" { + pub fn VSIInstallOSSFileHandler(); +} +extern "C" { + pub fn VSIInstallOSSStreamingFileHandler(); +} +extern "C" { + pub fn VSIInstallSwiftFileHandler(); +} +extern "C" { + pub fn VSIInstallSwiftStreamingFileHandler(); +} +extern "C" { + pub fn VSIInstallGZipFileHandler(); +} +extern "C" { + pub fn VSIInstallZipFileHandler(); +} +extern "C" { + pub fn VSIInstallStdinHandler(); +} +extern "C" { + pub fn VSIInstallHdfsHandler(); +} +extern "C" { + pub fn VSIInstallWebHdfsHandler(); +} +extern "C" { + pub fn VSIInstallStdoutHandler(); +} +extern "C" { + pub fn VSIInstallSparseFileHandler(); +} +extern "C" { + pub fn VSIInstallTarFileHandler(); +} +extern "C" { + pub fn VSIInstallCryptFileHandler(); +} +extern "C" { + pub fn VSISetCryptKey(pabyKey: *const GByte, nKeySize: libc::c_int); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn VSICleanupFileManager(); +} +extern "C" { + #[doc = " @endcond"] + pub fn VSIFileFromMemBuffer( + pszFilename: *const libc::c_char, + pabyData: *mut GByte, + nDataLength: vsi_l_offset, + bTakeOwnership: libc::c_int, + ) -> *mut VSILFILE; +} +extern "C" { + pub fn VSIGetMemFileBuffer( + pszFilename: *const libc::c_char, + pnDataLength: *mut vsi_l_offset, + bUnlinkAndSeize: libc::c_int, + ) -> *mut GByte; +} +#[doc = " Callback used by VSIStdoutSetRedirection()"] +pub type VSIWriteFunction = ::std::option::Option< + unsafe extern "C" fn( + ptr: *const libc::c_void, + size: size_t, + nmemb: size_t, + stream: *mut FILE, + ) -> size_t, +>; +extern "C" { + pub fn VSIStdoutSetRedirection(pFct: VSIWriteFunction, stream: *mut FILE); +} +#[doc = " Return information about a handle. Optional (driver dependent)"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginStatCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + pszFilename: *const libc::c_char, + pStatBuf: *mut VSIStatBufL, + nFlags: libc::c_int, + ) -> libc::c_int, +>; +#[doc = " Remove handle by name. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginUnlinkCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + pszFilename: *const libc::c_char, + ) -> libc::c_int, +>; +#[doc = " Rename handle. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginRenameCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + oldpath: *const libc::c_char, + newpath: *const libc::c_char, + ) -> libc::c_int, +>; +#[doc = " Create Directory. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginMkdirCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + pszDirname: *const libc::c_char, + nMode: libc::c_long, + ) -> libc::c_int, +>; +#[doc = " Delete Directory. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginRmdirCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + pszDirname: *const libc::c_char, + ) -> libc::c_int, +>; +#[doc = " List directory content. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginReadDirCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + pszDirname: *const libc::c_char, + nMaxFiles: libc::c_int, + ) -> *mut *mut libc::c_char, +>; +#[doc = " Open a handle. Mandatory. Returns an opaque pointer that will be used in subsequent file I/O calls."] +#[doc = " Should return null and/or set errno if the handle does not exist or the access mode is incorrect."] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginOpenCallback = ::std::option::Option< + unsafe extern "C" fn( + pUserData: *mut libc::c_void, + pszFilename: *const libc::c_char, + pszAccess: *const libc::c_char, + ) -> *mut libc::c_void, +>; +#[doc = " Return current position in handle. Mandatory"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginTellCallback = + ::std::option::Option vsi_l_offset>; +#[doc = " Seek to position in handle. Mandatory except for write only handles"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginSeekCallback = ::std::option::Option< + unsafe extern "C" fn( + pFile: *mut libc::c_void, + nOffset: vsi_l_offset, + nWhence: libc::c_int, + ) -> libc::c_int, +>; +#[doc = " Read data from current position, returns the number of blocks correctly read."] +#[doc = " Mandatory except for write only handles"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginReadCallback = ::std::option::Option< + unsafe extern "C" fn( + pFile: *mut libc::c_void, + pBuffer: *mut libc::c_void, + nSize: size_t, + nCount: size_t, + ) -> size_t, +>; +#[doc = " Read from multiple offsets. Optional, will be replaced by multiple calls to Read() if not provided"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginReadMultiRangeCallback = ::std::option::Option< + unsafe extern "C" fn( + pFile: *mut libc::c_void, + nRanges: libc::c_int, + ppData: *mut *mut libc::c_void, + panOffsets: *const vsi_l_offset, + panSizes: *const size_t, + ) -> libc::c_int, +>; +#[doc = " Get empty ranges. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginGetRangeStatusCallback = ::std::option::Option< + unsafe extern "C" fn( + pFile: *mut libc::c_void, + nOffset: vsi_l_offset, + nLength: vsi_l_offset, + ) -> VSIRangeStatus::Type, +>; +#[doc = " Has end of file been reached. Mandatory? for read handles."] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginEofCallback = + ::std::option::Option libc::c_int>; +#[doc = " Write bytes at current offset. Mandatory for writable handles"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginWriteCallback = ::std::option::Option< + unsafe extern "C" fn( + pFile: *mut libc::c_void, + pBuffer: *const libc::c_void, + nSize: size_t, + nCount: size_t, + ) -> size_t, +>; +#[doc = " Sync written bytes. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginFlushCallback = + ::std::option::Option libc::c_int>; +#[doc = " Truncate handle. Mandatory (driver dependent?) for write handles"] +pub type VSIFilesystemPluginTruncateCallback = ::std::option::Option< + unsafe extern "C" fn(pFile: *mut libc::c_void, nNewSize: vsi_l_offset) -> libc::c_int, +>; +#[doc = " Close file handle. Optional"] +#[doc = " @since GDAL 2.5"] +pub type VSIFilesystemPluginCloseCallback = + ::std::option::Option libc::c_int>; +#[doc = " struct containing callbacks to used by the handler."] +#[doc = " (rw), (r), (w) or () at the end indicate wether the given callback is mandatory"] +#[doc = " for reading and or writing handlers. A (?) indicates that the callback might"] +#[doc = " be mandatory for certain drivers only."] +#[doc = " @since GDAL 2.5"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct VSIFilesystemPluginCallbacksStruct { + #[doc = " Optional opaque pointer passed back to filemanager callbacks (e.g. open, stat, rmdir)"] + pub pUserData: *mut libc::c_void, + #[doc = "< stat handle by name (rw)"] + pub stat: VSIFilesystemPluginStatCallback, + #[doc = "< unlink handle by name ()"] + pub unlink: VSIFilesystemPluginUnlinkCallback, + #[doc = "< rename handle ()"] + pub rename: VSIFilesystemPluginRenameCallback, + #[doc = "< make directory ()"] + pub mkdir: VSIFilesystemPluginMkdirCallback, + #[doc = "< remove directory ()"] + pub rmdir: VSIFilesystemPluginRmdirCallback, + #[doc = "< list directory content (r?)"] + pub read_dir: VSIFilesystemPluginReadDirCallback, + #[doc = "< open handle by name (rw)"] + pub open: VSIFilesystemPluginOpenCallback, + #[doc = "< get current position of handle (rw)"] + pub tell: VSIFilesystemPluginTellCallback, + #[doc = "< set current position of handle (rw)"] + pub seek: VSIFilesystemPluginSeekCallback, + #[doc = "< read from current position (r)"] + pub read: VSIFilesystemPluginReadCallback, + #[doc = "< read multiple blocks ()"] + pub read_multi_range: VSIFilesystemPluginReadMultiRangeCallback, + #[doc = "< get range status ()"] + pub get_range_status: VSIFilesystemPluginGetRangeStatusCallback, + #[doc = "< has end of file been reached (r?)"] + pub eof: VSIFilesystemPluginEofCallback, + #[doc = "< write bytes to current position (w)"] + pub write: VSIFilesystemPluginWriteCallback, + #[doc = "< sync bytes (w)"] + pub flush: VSIFilesystemPluginFlushCallback, + #[doc = "< truncate handle (w?)"] + pub truncate: VSIFilesystemPluginTruncateCallback, + #[doc = "< close handle (rw)"] + pub close: VSIFilesystemPluginCloseCallback, +} +#[test] +fn bindgen_test_layout_VSIFilesystemPluginCallbacksStruct() { + assert_eq!( + ::std::mem::size_of::(), + 144usize, + concat!("Size of: ", stringify!(VSIFilesystemPluginCallbacksStruct)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!( + "Alignment of ", + stringify!(VSIFilesystemPluginCallbacksStruct) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pUserData as *const _ + as usize + }, + 0usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(pUserData) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).stat as *const _ as usize + }, + 8usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(stat) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).unlink as *const _ + as usize + }, + 16usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(unlink) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).rename as *const _ + as usize + }, + 24usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(rename) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).mkdir as *const _ + as usize + }, + 32usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(mkdir) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).rmdir as *const _ + as usize + }, + 40usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(rmdir) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).read_dir as *const _ + as usize + }, + 48usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(read_dir) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).open as *const _ as usize + }, + 56usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(open) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).tell as *const _ as usize + }, + 64usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(tell) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).seek as *const _ as usize + }, + 72usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(seek) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).read as *const _ as usize + }, + 80usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(read) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).read_multi_range + as *const _ as usize + }, + 88usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(read_multi_range) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).get_range_status + as *const _ as usize + }, + 96usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(get_range_status) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).eof as *const _ as usize + }, + 104usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(eof) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).write as *const _ + as usize + }, + 112usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(write) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).flush as *const _ + as usize + }, + 120usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(flush) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).truncate as *const _ + as usize + }, + 128usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(truncate) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).close as *const _ + as usize + }, + 136usize, + concat!( + "Offset of field: ", + stringify!(VSIFilesystemPluginCallbacksStruct), + "::", + stringify!(close) + ) + ); +} +extern "C" { + #[doc = " return a VSIFilesystemPluginCallbacksStruct to be populated at runtime with handler callbacks"] + #[doc = " @since GDAL 2.5"] + pub fn VSIAllocFilesystemPluginCallbacksStruct() -> *mut VSIFilesystemPluginCallbacksStruct; +} +extern "C" { + #[doc = " free resources allocated by VSIAllocFilesystemPluginCallbacksStruct"] + #[doc = " @since GDAL 2.5"] + pub fn VSIFreeFilesystemPluginCallbacksStruct(poCb: *mut VSIFilesystemPluginCallbacksStruct); +} +extern "C" { + #[doc = " register a handler on the given prefix. All IO on datasets opened with the filename /prefix/xxxxxx"] + #[doc = " will go through these callbacks."] + #[doc = " pszPrefix must begin and end with a '/'"] + #[doc = " @since GDAL 2.5"] + pub fn VSIInstallPluginHandler( + pszPrefix: *const libc::c_char, + poCb: *const VSIFilesystemPluginCallbacksStruct, + ) -> libc::c_int; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn VSITime(arg1: *mut libc::c_ulong) -> libc::c_ulong; +} +extern "C" { + pub fn VSICTime(arg1: libc::c_ulong) -> *const libc::c_char; +} +extern "C" { + pub fn VSIGMTime(pnTime: *const time_t, poBrokenTime: *mut tm) -> *mut tm; +} +extern "C" { + pub fn VSILocalTime(pnTime: *const time_t, poBrokenTime: *mut tm) -> *mut tm; +} +pub mod CPLErr { + #[doc = " Error category"] + pub type Type = u32; + pub const CE_None: Type = 0; + pub const CE_Debug: Type = 1; + pub const CE_Warning: Type = 2; + pub const CE_Failure: Type = 3; + pub const CE_Fatal: Type = 4; +} +#[doc = " Error number"] +pub type CPLErrorNum = libc::c_int; +extern "C" { + pub fn CPLError(eErrClass: CPLErr::Type, err_no: CPLErrorNum, fmt: *const libc::c_char, ...); +} +extern "C" { + pub fn CPLErrorV( + arg1: CPLErr::Type, + arg2: CPLErrorNum, + arg3: *const libc::c_char, + arg4: *mut __va_list_tag, + ); +} +extern "C" { + pub fn CPLEmergencyError(arg1: *const libc::c_char); +} +extern "C" { + pub fn CPLErrorReset(); +} +extern "C" { + pub fn CPLGetLastErrorNo() -> CPLErrorNum; +} +extern "C" { + pub fn CPLGetLastErrorType() -> CPLErr::Type; +} +extern "C" { + pub fn CPLGetLastErrorMsg() -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetErrorCounter() -> GUInt32; +} +extern "C" { + pub fn CPLGetErrorHandlerUserData() -> *mut libc::c_void; +} +extern "C" { + pub fn CPLErrorSetState( + eErrClass: CPLErr::Type, + err_no: CPLErrorNum, + pszMsg: *const libc::c_char, + ); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn CPLCleanupErrorMutex(); +} +#[doc = " Callback for a custom error handler"] +pub type CPLErrorHandler = ::std::option::Option< + unsafe extern "C" fn(arg1: CPLErr::Type, arg2: CPLErrorNum, arg3: *const libc::c_char), +>; +extern "C" { + pub fn CPLLoggingErrorHandler(arg1: CPLErr::Type, arg2: CPLErrorNum, arg3: *const libc::c_char); +} +extern "C" { + pub fn CPLDefaultErrorHandler(arg1: CPLErr::Type, arg2: CPLErrorNum, arg3: *const libc::c_char); +} +extern "C" { + pub fn CPLQuietErrorHandler(arg1: CPLErr::Type, arg2: CPLErrorNum, arg3: *const libc::c_char); +} +extern "C" { + pub fn CPLTurnFailureIntoWarning(bOn: libc::c_int); +} +extern "C" { + pub fn CPLSetErrorHandler(arg1: CPLErrorHandler) -> CPLErrorHandler; +} +extern "C" { + pub fn CPLSetErrorHandlerEx(arg1: CPLErrorHandler, arg2: *mut libc::c_void) -> CPLErrorHandler; +} +extern "C" { + pub fn CPLPushErrorHandler(arg1: CPLErrorHandler); +} +extern "C" { + pub fn CPLPushErrorHandlerEx(arg1: CPLErrorHandler, arg2: *mut libc::c_void); +} +extern "C" { + pub fn CPLSetCurrentErrorHandlerCatchDebug(bCatchDebug: libc::c_int); +} +extern "C" { + pub fn CPLPopErrorHandler(); +} +extern "C" { + pub fn CPLDebug(arg1: *const libc::c_char, arg2: *const libc::c_char, ...); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn CPLVerifyConfiguration(); +} +extern "C" { + #[doc = " @endcond"] + pub fn CPLGetConfigOption( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetThreadLocalConfigOption( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLSetConfigOption(arg1: *const libc::c_char, arg2: *const libc::c_char); +} +extern "C" { + pub fn CPLSetThreadLocalConfigOption( + pszKey: *const libc::c_char, + pszValue: *const libc::c_char, + ); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn CPLFreeConfig(); +} +extern "C" { + #[doc = " @endcond"] + pub fn CPLGetConfigOptions() -> *mut *mut libc::c_char; +} +extern "C" { + pub fn CPLSetConfigOptions(papszConfigOptions: *const *const libc::c_char); +} +extern "C" { + pub fn CPLGetThreadLocalConfigOptions() -> *mut *mut libc::c_char; +} +extern "C" { + pub fn CPLSetThreadLocalConfigOptions(papszConfigOptions: *const *const libc::c_char); +} +extern "C" { + pub fn CPLMalloc(arg1: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLCalloc(arg1: size_t, arg2: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLRealloc(arg1: *mut libc::c_void, arg2: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLStrdup(arg1: *const libc::c_char) -> *mut libc::c_char; +} +extern "C" { + pub fn CPLStrlwr(arg1: *mut libc::c_char) -> *mut libc::c_char; +} +extern "C" { + pub fn CPLFGets( + arg1: *mut libc::c_char, + arg2: libc::c_int, + arg3: *mut FILE, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn CPLReadLine(arg1: *mut FILE) -> *const libc::c_char; +} +extern "C" { + pub fn CPLReadLineL(arg1: *mut VSILFILE) -> *const libc::c_char; +} +extern "C" { + pub fn CPLReadLine2L( + arg1: *mut VSILFILE, + arg2: libc::c_int, + arg3: CSLConstList, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLReadLine3L( + arg1: *mut VSILFILE, + arg2: libc::c_int, + arg3: *mut libc::c_int, + arg4: CSLConstList, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLAtof(arg1: *const libc::c_char) -> f64; +} +extern "C" { + pub fn CPLAtofDelim(arg1: *const libc::c_char, arg2: libc::c_char) -> f64; +} +extern "C" { + pub fn CPLStrtod(arg1: *const libc::c_char, arg2: *mut *mut libc::c_char) -> f64; +} +extern "C" { + pub fn CPLStrtodDelim( + arg1: *const libc::c_char, + arg2: *mut *mut libc::c_char, + arg3: libc::c_char, + ) -> f64; +} +extern "C" { + pub fn CPLStrtof(arg1: *const libc::c_char, arg2: *mut *mut libc::c_char) -> f32; +} +extern "C" { + pub fn CPLStrtofDelim( + arg1: *const libc::c_char, + arg2: *mut *mut libc::c_char, + arg3: libc::c_char, + ) -> f32; +} +extern "C" { + pub fn CPLAtofM(arg1: *const libc::c_char) -> f64; +} +extern "C" { + pub fn CPLScanString( + arg1: *const libc::c_char, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn CPLScanDouble(arg1: *const libc::c_char, arg2: libc::c_int) -> f64; +} +extern "C" { + pub fn CPLScanLong(arg1: *const libc::c_char, arg2: libc::c_int) -> libc::c_long; +} +extern "C" { + pub fn CPLScanULong(arg1: *const libc::c_char, arg2: libc::c_int) -> libc::c_ulong; +} +extern "C" { + pub fn CPLScanUIntBig(arg1: *const libc::c_char, arg2: libc::c_int) -> GUIntBig; +} +extern "C" { + pub fn CPLAtoGIntBig(pszString: *const libc::c_char) -> GIntBig; +} +extern "C" { + pub fn CPLAtoGIntBigEx( + pszString: *const libc::c_char, + bWarn: libc::c_int, + pbOverflow: *mut libc::c_int, + ) -> GIntBig; +} +extern "C" { + pub fn CPLScanPointer(arg1: *const libc::c_char, arg2: libc::c_int) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLPrintString( + arg1: *mut libc::c_char, + arg2: *const libc::c_char, + arg3: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLPrintStringFill( + arg1: *mut libc::c_char, + arg2: *const libc::c_char, + arg3: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLPrintInt32(arg1: *mut libc::c_char, arg2: GInt32, arg3: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn CPLPrintUIntBig( + arg1: *mut libc::c_char, + arg2: GUIntBig, + arg3: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLPrintDouble( + arg1: *mut libc::c_char, + arg2: *const libc::c_char, + arg3: f64, + arg4: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLPrintTime( + arg1: *mut libc::c_char, + arg2: libc::c_int, + arg3: *const libc::c_char, + arg4: *const tm, + arg5: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLPrintPointer( + arg1: *mut libc::c_char, + arg2: *mut libc::c_void, + arg3: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLGetSymbol(arg1: *const libc::c_char, arg2: *const libc::c_char) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLGetExecPath(pszPathBuf: *mut libc::c_char, nMaxLength: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn CPLGetPath(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetDirname(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetFilename(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetBasename(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetExtension(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetCurrentDir() -> *mut libc::c_char; +} +extern "C" { + pub fn CPLFormFilename( + pszPath: *const libc::c_char, + pszBasename: *const libc::c_char, + pszExtension: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLFormCIFilename( + pszPath: *const libc::c_char, + pszBasename: *const libc::c_char, + pszExtension: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLResetExtension( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLProjectRelativeFilename( + pszProjectDir: *const libc::c_char, + pszSecondaryFilename: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLIsFilenameRelative(pszFilename: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn CPLExtractRelativePath( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + arg3: *mut libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLCleanTrailingSlash(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLCorrespondingPaths( + pszOldFilename: *const libc::c_char, + pszNewFilename: *const libc::c_char, + papszFileList: *mut *mut libc::c_char, + ) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn CPLCheckForFile( + pszFilename: *mut libc::c_char, + papszSiblingList: *mut *mut libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLGenerateTempFilename(pszStem: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLExpandTilde(pszFilename: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetHomeDir() -> *const libc::c_char; +} +#[doc = " Callback for CPLPushFileFinder"] +pub type CPLFileFinder = ::std::option::Option< + unsafe extern "C" fn( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + ) -> *const libc::c_char, +>; +extern "C" { + pub fn CPLFindFile( + pszClass: *const libc::c_char, + pszBasename: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLDefaultFindFile( + pszClass: *const libc::c_char, + pszBasename: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLPushFileFinder(pfnFinder: CPLFileFinder); +} +extern "C" { + pub fn CPLPopFileFinder() -> CPLFileFinder; +} +extern "C" { + pub fn CPLPushFinderLocation(arg1: *const libc::c_char); +} +extern "C" { + pub fn CPLPopFinderLocation(); +} +extern "C" { + pub fn CPLFinderClean(); +} +extern "C" { + pub fn CPLStat(arg1: *const libc::c_char, arg2: *mut VSIStatBuf) -> libc::c_int; +} +#[doc = " Information on a shared file"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct CPLSharedFileInfo { + #[doc = "< File pointer"] + pub fp: *mut FILE, + #[doc = "< Reference counter"] + pub nRefCount: libc::c_int, + #[doc = "< Whether fp must be interpreted as VSIFILE*"] + pub bLarge: libc::c_int, + #[doc = "< Filename"] + pub pszFilename: *mut libc::c_char, + #[doc = "< Access mode"] + pub pszAccess: *mut libc::c_char, +} +#[test] +fn bindgen_test_layout_CPLSharedFileInfo() { + assert_eq!( + ::std::mem::size_of::(), + 32usize, + concat!("Size of: ", stringify!(CPLSharedFileInfo)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(CPLSharedFileInfo)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).fp as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(CPLSharedFileInfo), + "::", + stringify!(fp) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nRefCount as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(CPLSharedFileInfo), + "::", + stringify!(nRefCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).bLarge as *const _ as usize }, + 12usize, + concat!( + "Offset of field: ", + stringify!(CPLSharedFileInfo), + "::", + stringify!(bLarge) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszFilename as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(CPLSharedFileInfo), + "::", + stringify!(pszFilename) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszAccess as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(CPLSharedFileInfo), + "::", + stringify!(pszAccess) + ) + ); +} +extern "C" { + pub fn CPLOpenShared( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + arg3: libc::c_int, + ) -> *mut FILE; +} +extern "C" { + pub fn CPLCloseShared(arg1: *mut FILE); +} +extern "C" { + pub fn CPLGetSharedList(arg1: *mut libc::c_int) -> *mut CPLSharedFileInfo; +} +extern "C" { + pub fn CPLDumpSharedList(arg1: *mut FILE); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn CPLCleanupSharedFileMutex(); +} +extern "C" { + #[doc = " @endcond"] + pub fn CPLDMSToDec(is: *const libc::c_char) -> f64; +} +extern "C" { + pub fn CPLDecToDMS( + dfAngle: f64, + pszAxis: *const libc::c_char, + nPrecision: libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLPackedDMSToDec(arg1: f64) -> f64; +} +extern "C" { + pub fn CPLDecToPackedDMS(dfDec: f64) -> f64; +} +extern "C" { + pub fn CPLStringToComplex(pszString: *const libc::c_char, pdfReal: *mut f64, pdfImag: *mut f64); +} +extern "C" { + pub fn CPLUnlinkTree(arg1: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn CPLCopyFile( + pszNewPath: *const libc::c_char, + pszOldPath: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLCopyTree( + pszNewPath: *const libc::c_char, + pszOldPath: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLMoveFile( + pszNewPath: *const libc::c_char, + pszOldPath: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLSymlink( + pszOldPath: *const libc::c_char, + pszNewPath: *const libc::c_char, + papszOptions: CSLConstList, + ) -> libc::c_int; +} +extern "C" { + #[doc = " @endcond"] + pub fn CPLCreateZip( + pszZipFilename: *const libc::c_char, + papszOptions: *mut *mut libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLCreateFileInZip( + hZip: *mut libc::c_void, + pszFilename: *const libc::c_char, + papszOptions: *mut *mut libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn CPLWriteFileInZip( + hZip: *mut libc::c_void, + pBuffer: *const libc::c_void, + nBufferSize: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn CPLCloseFileInZip(hZip: *mut libc::c_void) -> CPLErr::Type; +} +extern "C" { + pub fn CPLCloseZip(hZip: *mut libc::c_void) -> CPLErr::Type; +} +extern "C" { + pub fn CPLZLibDeflate( + ptr: *const libc::c_void, + nBytes: size_t, + nLevel: libc::c_int, + outptr: *mut libc::c_void, + nOutAvailableBytes: size_t, + pnOutBytes: *mut size_t, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLZLibInflate( + ptr: *const libc::c_void, + nBytes: size_t, + outptr: *mut libc::c_void, + nOutAvailableBytes: size_t, + pnOutBytes: *mut size_t, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLValidateXML( + pszXMLFilename: *const libc::c_char, + pszXSDFilename: *const libc::c_char, + papszOptions: CSLConstList, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLsetlocale(category: libc::c_int, locale: *const libc::c_char) -> *mut libc::c_char; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn CPLCleanupSetlocaleMutex(); +} +extern "C" { + #[doc = "CPLIsPowerOfTwo()"] + #[doc = "@param i - tested number"] + #[doc = "@return TRUE if i is power of two otherwise return FALSE"] + pub fn CPLIsPowerOfTwo(i: libc::c_uint) -> libc::c_int; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct CPLVirtualMem { + _unused: [u8; 0], +} +#[doc = " Callback triggered when a still unmapped page of virtual memory is accessed."] +#[doc = " The callback has the responsibility of filling the page with relevant values"] +#[doc = ""] +#[doc = " @param ctxt virtual memory handle."] +#[doc = " @param nOffset offset of the page in the memory mapping."] +#[doc = " @param pPageToFill address of the page to fill. Note that the address might"] +#[doc = " be a temporary location, and not at CPLVirtualMemGetAddr() + nOffset."] +#[doc = " @param nToFill number of bytes of the page."] +#[doc = " @param pUserData user data that was passed to CPLVirtualMemNew()."] +pub type CPLVirtualMemCachePageCbk = ::std::option::Option< + unsafe extern "C" fn( + ctxt: *mut CPLVirtualMem, + nOffset: size_t, + pPageToFill: *mut libc::c_void, + nToFill: size_t, + pUserData: *mut libc::c_void, + ), +>; +#[doc = " Callback triggered when a dirty mapped page is going to be freed."] +#[doc = " (saturation of cache, or termination of the virtual memory mapping)."] +#[doc = ""] +#[doc = " @param ctxt virtual memory handle."] +#[doc = " @param nOffset offset of the page in the memory mapping."] +#[doc = " @param pPageToBeEvicted address of the page that will be flushed. Note that the address might"] +#[doc = " be a temporary location, and not at CPLVirtualMemGetAddr() + nOffset."] +#[doc = " @param nToBeEvicted number of bytes of the page."] +#[doc = " @param pUserData user data that was passed to CPLVirtualMemNew()."] +pub type CPLVirtualMemUnCachePageCbk = ::std::option::Option< + unsafe extern "C" fn( + ctxt: *mut CPLVirtualMem, + nOffset: size_t, + pPageToBeEvicted: *const libc::c_void, + nToBeEvicted: size_t, + pUserData: *mut libc::c_void, + ), +>; +#[doc = " Callback triggered when a virtual memory mapping is destroyed."] +#[doc = " @param pUserData user data that was passed to CPLVirtualMemNew()."] +pub type CPLVirtualMemFreeUserData = + ::std::option::Option; +pub mod CPLVirtualMemAccessMode { + #[doc = " Access mode of a virtual memory mapping."] + pub type Type = u32; + #[doc = " The mapping is meant at being read-only, but writes will not be prevented."] + #[doc = "Note that any content written will be lost."] + pub const VIRTUALMEM_READONLY: Type = 0; + #[doc = " The mapping is meant at being read-only, and this will be enforced"] + #[doc = "through the operating system page protection mechanism."] + pub const VIRTUALMEM_READONLY_ENFORCED: Type = 1; + #[doc = " The mapping is meant at being read-write, and modified pages can be saved"] + #[doc = "thanks to the pfnUnCachePage callback"] + pub const VIRTUALMEM_READWRITE: Type = 2; +} +extern "C" { + #[doc = " Return the size of a page of virtual memory."] + #[doc = ""] + #[doc = " @return the page size."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLGetPageSize() -> size_t; +} +extern "C" { + #[doc = " Create a new virtual memory mapping."] + #[doc = ""] + #[doc = " This will reserve an area of virtual memory of size nSize, whose size"] + #[doc = " might be potentially much larger than the physical memory available. Initially,"] + #[doc = " no physical memory will be allocated. As soon as memory pages will be accessed,"] + #[doc = " they will be allocated transparently and filled with the pfnCachePage callback."] + #[doc = " When the allowed cache size is reached, the least recently used pages will"] + #[doc = " be unallocated."] + #[doc = ""] + #[doc = " On Linux AMD64 platforms, the maximum value for nSize is 128 TB."] + #[doc = " On Linux x86 platforms, the maximum value for nSize is 2 GB."] + #[doc = ""] + #[doc = " Only supported on Linux for now."] + #[doc = ""] + #[doc = " Note that on Linux, this function will install a SIGSEGV handler. The"] + #[doc = " original handler will be restored by CPLVirtualMemManagerTerminate()."] + #[doc = ""] + #[doc = " @param nSize size in bytes of the virtual memory mapping."] + #[doc = " @param nCacheSize size in bytes of the maximum memory that will be really"] + #[doc = " allocated (must ideally fit into RAM)."] + #[doc = " @param nPageSizeHint hint for the page size. Must be a multiple of the"] + #[doc = " system page size, returned by CPLGetPageSize()."] + #[doc = " Minimum value is generally 4096. Might be set to 0 to"] + #[doc = " let the function determine a default page size."] + #[doc = " @param bSingleThreadUsage set to TRUE if there will be no concurrent threads"] + #[doc = " that will access the virtual memory mapping. This can"] + #[doc = " optimize performance a bit."] + #[doc = " @param eAccessMode permission to use for the virtual memory mapping."] + #[doc = " @param pfnCachePage callback triggered when a still unmapped page of virtual"] + #[doc = " memory is accessed. The callback has the responsibility"] + #[doc = " of filling the page with relevant values."] + #[doc = " @param pfnUnCachePage callback triggered when a dirty mapped page is going to"] + #[doc = " be freed (saturation of cache, or termination of the"] + #[doc = " virtual memory mapping). Might be NULL."] + #[doc = " @param pfnFreeUserData callback that can be used to free pCbkUserData. Might be"] + #[doc = " NULL"] + #[doc = " @param pCbkUserData user data passed to pfnCachePage and pfnUnCachePage."] + #[doc = ""] + #[doc = " @return a virtual memory object that must be freed by CPLVirtualMemFree(),"] + #[doc = " or NULL in case of failure."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemNew( + nSize: size_t, + nCacheSize: size_t, + nPageSizeHint: size_t, + bSingleThreadUsage: libc::c_int, + eAccessMode: CPLVirtualMemAccessMode::Type, + pfnCachePage: CPLVirtualMemCachePageCbk, + pfnUnCachePage: CPLVirtualMemUnCachePageCbk, + pfnFreeUserData: CPLVirtualMemFreeUserData, + pCbkUserData: *mut libc::c_void, + ) -> *mut CPLVirtualMem; +} +extern "C" { + #[doc = " Return if virtual memory mapping of a file is available."] + #[doc = ""] + #[doc = " @return TRUE if virtual memory mapping of a file is available."] + #[doc = " @since GDAL 1.11"] + pub fn CPLIsVirtualMemFileMapAvailable() -> libc::c_int; +} +extern "C" { + #[doc = " Create a new virtual memory mapping from a file."] + #[doc = ""] + #[doc = " The file must be a \"real\" file recognized by the operating system, and not"] + #[doc = " a VSI extended virtual file."] + #[doc = ""] + #[doc = " In VIRTUALMEM_READWRITE mode, updates to the memory mapping will be written"] + #[doc = " in the file."] + #[doc = ""] + #[doc = " On Linux AMD64 platforms, the maximum value for nLength is 128 TB."] + #[doc = " On Linux x86 platforms, the maximum value for nLength is 2 GB."] + #[doc = ""] + #[doc = " Supported on Linux only in GDAL <= 2.0, and all POSIX systems supporting"] + #[doc = " mmap() in GDAL >= 2.1"] + #[doc = ""] + #[doc = " @param fp Virtual file handle."] + #[doc = " @param nOffset Offset in the file to start the mapping from."] + #[doc = " @param nLength Length of the portion of the file to map into memory."] + #[doc = " @param eAccessMode Permission to use for the virtual memory mapping. This must"] + #[doc = " be consistent with how the file has been opened."] + #[doc = " @param pfnFreeUserData callback that is called when the object is destroyed."] + #[doc = " @param pCbkUserData user data passed to pfnFreeUserData."] + #[doc = " @return a virtual memory object that must be freed by CPLVirtualMemFree(),"] + #[doc = " or NULL in case of failure."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemFileMapNew( + fp: *mut VSILFILE, + nOffset: vsi_l_offset, + nLength: vsi_l_offset, + eAccessMode: CPLVirtualMemAccessMode::Type, + pfnFreeUserData: CPLVirtualMemFreeUserData, + pCbkUserData: *mut libc::c_void, + ) -> *mut CPLVirtualMem; +} +extern "C" { + #[doc = " Create a new virtual memory mapping derived from an other virtual memory"] + #[doc = " mapping."] + #[doc = ""] + #[doc = " This may be useful in case of creating mapping for pixel interleaved data."] + #[doc = ""] + #[doc = " The new mapping takes a reference on the base mapping."] + #[doc = ""] + #[doc = " @param pVMemBase Base virtual memory mapping"] + #[doc = " @param nOffset Offset in the base virtual memory mapping from which to start"] + #[doc = " the new mapping."] + #[doc = " @param nSize Size of the base virtual memory mapping to expose in the"] + #[doc = " the new mapping."] + #[doc = " @param pfnFreeUserData callback that is called when the object is destroyed."] + #[doc = " @param pCbkUserData user data passed to pfnFreeUserData."] + #[doc = " @return a virtual memory object that must be freed by CPLVirtualMemFree(),"] + #[doc = " or NULL in case of failure."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemDerivedNew( + pVMemBase: *mut CPLVirtualMem, + nOffset: vsi_l_offset, + nSize: vsi_l_offset, + pfnFreeUserData: CPLVirtualMemFreeUserData, + pCbkUserData: *mut libc::c_void, + ) -> *mut CPLVirtualMem; +} +extern "C" { + #[doc = " Free a virtual memory mapping."] + #[doc = ""] + #[doc = " The pointer returned by CPLVirtualMemGetAddr() will no longer be valid."] + #[doc = " If the virtual memory mapping was created with read/write permissions and that"] + #[doc = " they are dirty (i.e. modified) pages, they will be flushed through the"] + #[doc = " pfnUnCachePage callback before being freed."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemFree(ctxt: *mut CPLVirtualMem); +} +extern "C" { + #[doc = " Return the pointer to the start of a virtual memory mapping."] + #[doc = ""] + #[doc = " The bytes in the range [p:p+CPLVirtualMemGetSize()-1] where p is the pointer"] + #[doc = " returned by this function will be valid, until CPLVirtualMemFree() is called."] + #[doc = ""] + #[doc = " Note that if a range of bytes used as an argument of a system call"] + #[doc = " (such as read() or write()) contains pages that have not been \"realized\", the"] + #[doc = " system call will fail with EFAULT. CPLVirtualMemPin() can be used to work"] + #[doc = " around this issue."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @return the pointer to the start of a virtual memory mapping."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemGetAddr(ctxt: *mut CPLVirtualMem) -> *mut libc::c_void; +} +extern "C" { + #[doc = " Return the size of the virtual memory mapping."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @return the size of the virtual memory mapping."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemGetSize(ctxt: *mut CPLVirtualMem) -> size_t; +} +extern "C" { + #[doc = " Return if the virtual memory mapping is a direct file mapping."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @return TRUE if the virtual memory mapping is a direct file mapping."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemIsFileMapping(ctxt: *mut CPLVirtualMem) -> libc::c_int; +} +extern "C" { + #[doc = " Return the access mode of the virtual memory mapping."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @return the access mode of the virtual memory mapping."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemGetAccessMode(ctxt: *mut CPLVirtualMem) -> CPLVirtualMemAccessMode::Type; +} +extern "C" { + #[doc = " Return the page size associated to a virtual memory mapping."] + #[doc = ""] + #[doc = " The value returned will be at least CPLGetPageSize(), but potentially"] + #[doc = " larger."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @return the page size"] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemGetPageSize(ctxt: *mut CPLVirtualMem) -> size_t; +} +extern "C" { + #[doc = " Return TRUE if this memory mapping can be accessed safely from concurrent"] + #[doc = " threads."] + #[doc = ""] + #[doc = " The situation that can cause problems is when several threads try to access"] + #[doc = " a page of the mapping that is not yet mapped."] + #[doc = ""] + #[doc = " The return value of this function depends on whether bSingleThreadUsage has"] + #[doc = " been set of not in CPLVirtualMemNew() and/or the implementation."] + #[doc = ""] + #[doc = " On Linux, this will always return TRUE if bSingleThreadUsage = FALSE."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @return TRUE if this memory mapping can be accessed safely from concurrent"] + #[doc = " threads."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemIsAccessThreadSafe(ctxt: *mut CPLVirtualMem) -> libc::c_int; +} +extern "C" { + #[doc = " Declare that a thread will access a virtual memory mapping."] + #[doc = ""] + #[doc = " This function must be called by a thread that wants to access the"] + #[doc = " content of a virtual memory mapping, except if the virtual memory mapping has"] + #[doc = " been created with bSingleThreadUsage = TRUE."] + #[doc = ""] + #[doc = " This function must be paired with CPLVirtualMemUnDeclareThread()."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemDeclareThread(ctxt: *mut CPLVirtualMem); +} +extern "C" { + #[doc = " Declare that a thread will stop accessing a virtual memory mapping."] + #[doc = ""] + #[doc = " This function must be called by a thread that will no longer access the"] + #[doc = " content of a virtual memory mapping, except if the virtual memory mapping has"] + #[doc = " been created with bSingleThreadUsage = TRUE."] + #[doc = ""] + #[doc = " This function must be paired with CPLVirtualMemDeclareThread()."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemUnDeclareThread(ctxt: *mut CPLVirtualMem); +} +extern "C" { + #[doc = " Make sure that a region of virtual memory will be realized."] + #[doc = ""] + #[doc = " Calling this function is not required, but might be useful when debugging"] + #[doc = " a process with tools like gdb or valgrind that do not naturally like"] + #[doc = " segmentation fault signals."] + #[doc = ""] + #[doc = " It is also needed when wanting to provide part of virtual memory mapping"] + #[doc = " to a system call such as read() or write(). If read() or write() is called"] + #[doc = " on a memory region not yet realized, the call will fail with EFAULT."] + #[doc = ""] + #[doc = " @param ctxt context returned by CPLVirtualMemNew()."] + #[doc = " @param pAddr the memory region to pin."] + #[doc = " @param nSize the size of the memory region."] + #[doc = " @param bWriteOp set to TRUE if the memory are will be accessed in write mode."] + #[doc = ""] + #[doc = " @since GDAL 1.11"] + pub fn CPLVirtualMemPin( + ctxt: *mut CPLVirtualMem, + pAddr: *mut libc::c_void, + nSize: size_t, + bWriteOp: libc::c_int, + ); +} +extern "C" { + #[doc = " Cleanup any resource and handlers related to virtual memory."] + #[doc = ""] + #[doc = " This function must be called after the last CPLVirtualMem object has"] + #[doc = " been freed."] + #[doc = ""] + #[doc = " @since GDAL 2.0"] + pub fn CPLVirtualMemManagerTerminate(); +} +pub mod CPLXMLNodeType { + #[doc = " XML node type"] + pub type Type = u32; + #[doc = " Node is an element"] + pub const CXT_Element: Type = 0; + #[doc = " Node is a raw text value"] + pub const CXT_Text: Type = 1; + #[doc = " Node is attribute"] + pub const CXT_Attribute: Type = 2; + #[doc = " Node is an XML comment."] + pub const CXT_Comment: Type = 3; + #[doc = " Node is a special literal"] + pub const CXT_Literal: Type = 4; +} +#[doc = " Document node structure."] +#[doc = ""] +#[doc = " This C structure is used to hold a single text fragment representing a"] +#[doc = " component of the document when parsed. It should be allocated with the"] +#[doc = " appropriate CPL function, and freed with CPLDestroyXMLNode(). The structure"] +#[doc = " contents should not normally be altered by application code, but may be"] +#[doc = " freely examined by application code."] +#[doc = ""] +#[doc = " Using the psChild and psNext pointers, a hierarchical tree structure"] +#[doc = " for a document can be represented as a tree of CPLXMLNode structures."] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct CPLXMLNode { + #[doc = " \\brief Node type"] + #[doc = ""] + #[doc = " One of CXT_Element, CXT_Text, CXT_Attribute, CXT_Comment,"] + #[doc = " or CXT_Literal."] + pub eType: CPLXMLNodeType::Type, + #[doc = " \\brief Node value"] + #[doc = ""] + #[doc = " For CXT_Element this is the name of the element, without the angle"] + #[doc = " brackets. Note there is a single CXT_Element even when the document"] + #[doc = " contains a start and end element tag. The node represents the pair."] + #[doc = " All text or other elements between the start and end tag will appear"] + #[doc = " as children nodes of this CXT_Element node."] + #[doc = ""] + #[doc = " For CXT_Attribute the pszValue is the attribute name. The value of"] + #[doc = " the attribute will be a CXT_Text child."] + #[doc = ""] + #[doc = " For CXT_Text this is the text itself (value of an attribute, or a"] + #[doc = " text fragment between an element start and end tags."] + #[doc = ""] + #[doc = " For CXT_Literal it is all the literal text. Currently this is just"] + #[doc = " used for !DOCTYPE lines, and the value would be the entire line."] + #[doc = ""] + #[doc = " For CXT_Comment the value is all the literal text within the comment,"] + #[doc = " but not including the comment start/end indicators (\"<--\" and \"-->\")."] + pub pszValue: *mut libc::c_char, + #[doc = " \\brief Next sibling."] + #[doc = ""] + #[doc = " Pointer to next sibling, that is the next node appearing after this"] + #[doc = " one that has the same parent as this node. NULL if this node is the"] + #[doc = " last child of the parent element."] + pub psNext: *mut CPLXMLNode, + #[doc = " \\brief Child node."] + #[doc = ""] + #[doc = " Pointer to first child node, if any. Only CXT_Element and CXT_Attribute"] + #[doc = " nodes should have children. For CXT_Attribute it should be a single"] + #[doc = " CXT_Text value node, while CXT_Element can have any kind of child."] + #[doc = " The full list of children for a node are identified by walking the"] + #[doc = " psNext's starting with the psChild node."] + pub psChild: *mut CPLXMLNode, +} +#[test] +fn bindgen_test_layout_CPLXMLNode() { + assert_eq!( + ::std::mem::size_of::(), + 32usize, + concat!("Size of: ", stringify!(CPLXMLNode)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(CPLXMLNode)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).eType as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(CPLXMLNode), + "::", + stringify!(eType) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszValue as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(CPLXMLNode), + "::", + stringify!(pszValue) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).psNext as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(CPLXMLNode), + "::", + stringify!(psNext) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).psChild as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(CPLXMLNode), + "::", + stringify!(psChild) + ) + ); +} +extern "C" { + pub fn CPLParseXMLString(arg1: *const libc::c_char) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLDestroyXMLNode(arg1: *mut CPLXMLNode); +} +extern "C" { + pub fn CPLGetXMLNode(poRoot: *mut CPLXMLNode, pszPath: *const libc::c_char) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLSearchXMLNode( + poRoot: *mut CPLXMLNode, + pszTarget: *const libc::c_char, + ) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLGetXMLValue( + poRoot: *const CPLXMLNode, + pszPath: *const libc::c_char, + pszDefault: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn CPLCreateXMLNode( + poParent: *mut CPLXMLNode, + eType: CPLXMLNodeType::Type, + pszText: *const libc::c_char, + ) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLSerializeXMLTree(psNode: *const CPLXMLNode) -> *mut libc::c_char; +} +extern "C" { + pub fn CPLAddXMLChild(psParent: *mut CPLXMLNode, psChild: *mut CPLXMLNode); +} +extern "C" { + pub fn CPLRemoveXMLChild(psParent: *mut CPLXMLNode, psChild: *mut CPLXMLNode) -> libc::c_int; +} +extern "C" { + pub fn CPLAddXMLSibling(psOlderSibling: *mut CPLXMLNode, psNewSibling: *mut CPLXMLNode); +} +extern "C" { + pub fn CPLCreateXMLElementAndValue( + psParent: *mut CPLXMLNode, + pszName: *const libc::c_char, + pszValue: *const libc::c_char, + ) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLAddXMLAttributeAndValue( + psParent: *mut CPLXMLNode, + pszName: *const libc::c_char, + pszValue: *const libc::c_char, + ); +} +extern "C" { + pub fn CPLCloneXMLTree(psTree: *const CPLXMLNode) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLSetXMLValue( + psRoot: *mut CPLXMLNode, + pszPath: *const libc::c_char, + pszValue: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLStripXMLNamespace( + psRoot: *mut CPLXMLNode, + pszNameSpace: *const libc::c_char, + bRecurse: libc::c_int, + ); +} +extern "C" { + pub fn CPLCleanXMLElementName(arg1: *mut libc::c_char); +} +extern "C" { + pub fn CPLParseXMLFile(pszFilename: *const libc::c_char) -> *mut CPLXMLNode; +} +extern "C" { + pub fn CPLSerializeXMLTreeToFile( + psTree: *const CPLXMLNode, + pszFilename: *const libc::c_char, + ) -> libc::c_int; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGREnvelope { + pub MinX: f64, + pub MaxX: f64, + pub MinY: f64, + pub MaxY: f64, +} +#[test] +fn bindgen_test_layout_OGREnvelope() { + assert_eq!( + ::std::mem::size_of::(), + 32usize, + concat!("Size of: ", stringify!(OGREnvelope)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGREnvelope)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MinX as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope), + "::", + stringify!(MinX) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MaxX as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope), + "::", + stringify!(MaxX) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MinY as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope), + "::", + stringify!(MinY) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MaxY as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope), + "::", + stringify!(MaxY) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGREnvelope3D { + pub MinX: f64, + pub MaxX: f64, + pub MinY: f64, + pub MaxY: f64, + pub MinZ: f64, + pub MaxZ: f64, +} +#[test] +fn bindgen_test_layout_OGREnvelope3D() { + assert_eq!( + ::std::mem::size_of::(), + 48usize, + concat!("Size of: ", stringify!(OGREnvelope3D)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGREnvelope3D)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MinX as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope3D), + "::", + stringify!(MinX) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MaxX as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope3D), + "::", + stringify!(MaxX) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MinY as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope3D), + "::", + stringify!(MinY) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MaxY as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope3D), + "::", + stringify!(MaxY) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MinZ as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope3D), + "::", + stringify!(MinZ) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).MaxZ as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(OGREnvelope3D), + "::", + stringify!(MaxZ) + ) + ); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGRMalloc(arg1: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn OGRCalloc(arg1: size_t, arg2: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn OGRRealloc(arg1: *mut libc::c_void, arg2: size_t) -> *mut libc::c_void; +} +extern "C" { + pub fn OGRStrdup(arg1: *const libc::c_char) -> *mut libc::c_char; +} +extern "C" { + pub fn OGRFree(arg1: *mut libc::c_void); +} +pub mod OGRwkbGeometryType { + #[doc = " List of well known binary geometry types. These are used within the BLOBs"] + #[doc = " but are also returned from OGRGeometry::getGeometryType() to identify the"] + #[doc = " type of a geometry object."] + pub type Type = u32; + #[doc = "< unknown type, non-standard"] + pub const wkbUnknown: Type = 0; + #[doc = "< 0-dimensional geometric object, standard WKB"] + pub const wkbPoint: Type = 1; + #[doc = "< 1-dimensional geometric object with linear"] + #[doc = " interpolation between Points, standard WKB"] + pub const wkbLineString: Type = 2; + #[doc = "< planar 2-dimensional geometric object defined"] + #[doc = " by 1 exterior boundary and 0 or more interior"] + #[doc = " boundaries, standard WKB"] + pub const wkbPolygon: Type = 3; + #[doc = "< GeometryCollection of Points, standard WKB"] + pub const wkbMultiPoint: Type = 4; + #[doc = "< GeometryCollection of LineStrings, standard WKB"] + pub const wkbMultiLineString: Type = 5; + #[doc = "< GeometryCollection of Polygons, standard WKB"] + pub const wkbMultiPolygon: Type = 6; + #[doc = "< geometric object that is a collection of 1"] + #[doc = "or more geometric objects, standard WKB"] + pub const wkbGeometryCollection: Type = 7; + #[doc = "< one or more circular arc segments connected end to end,"] + #[doc = " ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbCircularString: Type = 8; + #[doc = "< sequence of contiguous curves, ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbCompoundCurve: Type = 9; + #[doc = "< planar surface, defined by 1 exterior boundary"] + #[doc = " and zero or more interior boundaries, that are curves."] + #[doc = " ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbCurvePolygon: Type = 10; + #[doc = "< GeometryCollection of Curves, ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbMultiCurve: Type = 11; + #[doc = "< GeometryCollection of Surfaces, ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbMultiSurface: Type = 12; + #[doc = "< Curve (abstract type). ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCurve: Type = 13; + #[doc = "< Surface (abstract type). ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbSurface: Type = 14; + #[doc = "< a contiguous collection of polygons, which share common boundary segments,"] + #[doc = " ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbPolyhedralSurface: Type = 15; + #[doc = "< a PolyhedralSurface consisting only of Triangle patches"] + #[doc = " ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTIN: Type = 16; + #[doc = "< a Triangle. ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTriangle: Type = 17; + #[doc = "< non-standard, for pure attribute records"] + pub const wkbNone: Type = 100; + #[doc = "< non-standard, just for createGeometry()"] + pub const wkbLinearRing: Type = 101; + #[doc = "< wkbCircularString with Z component. ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbCircularStringZ: Type = 1008; + #[doc = "< wkbCompoundCurve with Z component. ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbCompoundCurveZ: Type = 1009; + #[doc = "< wkbCurvePolygon with Z component. ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbCurvePolygonZ: Type = 1010; + #[doc = "< wkbMultiCurve with Z component. ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbMultiCurveZ: Type = 1011; + #[doc = "< wkbMultiSurface with Z component. ISO SQL/MM Part 3. GDAL >= 2.0"] + pub const wkbMultiSurfaceZ: Type = 1012; + #[doc = "< wkbCurve with Z component. ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCurveZ: Type = 1013; + #[doc = "< wkbSurface with Z component. ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbSurfaceZ: Type = 1014; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbPolyhedralSurfaceZ: Type = 1015; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTINZ: Type = 1016; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTriangleZ: Type = 1017; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbPointM: Type = 2001; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbLineStringM: Type = 2002; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbPolygonM: Type = 2003; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiPointM: Type = 2004; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiLineStringM: Type = 2005; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiPolygonM: Type = 2006; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbGeometryCollectionM: Type = 2007; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCircularStringM: Type = 2008; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCompoundCurveM: Type = 2009; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCurvePolygonM: Type = 2010; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiCurveM: Type = 2011; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiSurfaceM: Type = 2012; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCurveM: Type = 2013; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbSurfaceM: Type = 2014; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbPolyhedralSurfaceM: Type = 2015; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTINM: Type = 2016; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTriangleM: Type = 2017; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbPointZM: Type = 3001; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbLineStringZM: Type = 3002; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbPolygonZM: Type = 3003; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiPointZM: Type = 3004; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiLineStringZM: Type = 3005; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiPolygonZM: Type = 3006; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbGeometryCollectionZM: Type = 3007; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCircularStringZM: Type = 3008; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCompoundCurveZM: Type = 3009; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCurvePolygonZM: Type = 3010; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiCurveZM: Type = 3011; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbMultiSurfaceZM: Type = 3012; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbCurveZM: Type = 3013; + #[doc = "< ISO SQL/MM Part 3. GDAL >= 2.1"] + pub const wkbSurfaceZM: Type = 3014; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbPolyhedralSurfaceZM: Type = 3015; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTINZM: Type = 3016; + #[doc = "< ISO SQL/MM Part 3. Reserved in GDAL >= 2.1 but not yet implemented"] + pub const wkbTriangleZM: Type = 3017; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbPoint25D: Type = 2147483649; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbLineString25D: Type = 2147483650; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbPolygon25D: Type = 2147483651; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbMultiPoint25D: Type = 2147483652; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbMultiLineString25D: Type = 2147483653; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbMultiPolygon25D: Type = 2147483654; + #[doc = "< 2.5D extension as per 99-402"] + pub const wkbGeometryCollection25D: Type = 2147483655; +} +extern "C" { + pub fn OGRGeometryTypeToName(eType: OGRwkbGeometryType::Type) -> *const libc::c_char; +} +extern "C" { + pub fn OGRMergeGeometryTypes( + eMain: OGRwkbGeometryType::Type, + eExtra: OGRwkbGeometryType::Type, + ) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGRMergeGeometryTypesEx( + eMain: OGRwkbGeometryType::Type, + eExtra: OGRwkbGeometryType::Type, + bAllowPromotingToCurves: libc::c_int, + ) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_Flatten(eType: OGRwkbGeometryType::Type) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_SetZ(eType: OGRwkbGeometryType::Type) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_SetM(eType: OGRwkbGeometryType::Type) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_SetModifier( + eType: OGRwkbGeometryType::Type, + bSetZ: libc::c_int, + bSetM: libc::c_int, + ) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_HasZ(eType: OGRwkbGeometryType::Type) -> libc::c_int; +} +extern "C" { + pub fn OGR_GT_HasM(eType: OGRwkbGeometryType::Type) -> libc::c_int; +} +extern "C" { + pub fn OGR_GT_IsSubClassOf( + eType: OGRwkbGeometryType::Type, + eSuperType: OGRwkbGeometryType::Type, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_GT_IsCurve(arg1: OGRwkbGeometryType::Type) -> libc::c_int; +} +extern "C" { + pub fn OGR_GT_IsSurface(arg1: OGRwkbGeometryType::Type) -> libc::c_int; +} +extern "C" { + pub fn OGR_GT_IsNonLinear(arg1: OGRwkbGeometryType::Type) -> libc::c_int; +} +extern "C" { + pub fn OGR_GT_GetCollection(eType: OGRwkbGeometryType::Type) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_GetCurve(eType: OGRwkbGeometryType::Type) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GT_GetLinear(eType: OGRwkbGeometryType::Type) -> OGRwkbGeometryType::Type; +} +pub mod OGRwkbByteOrder { + #[doc = " Enumeration to describe byte order"] + pub type Type = u32; + #[doc = "< MSB/Sun/Motoroloa: Most Significant Byte First"] + pub const wkbXDR: Type = 0; + #[doc = "< LSB/Intel/Vax: Least Significant Byte First"] + pub const wkbNDR: Type = 1; +} +pub mod OGRFieldType { + #[doc = " List of feature field types. This list is likely to be extended in the"] + #[doc = " future ... avoid coding applications based on the assumption that all"] + #[doc = " field types can be known."] + pub type Type = u32; + #[doc = " Simple 32bit integer"] + pub const OFTInteger: Type = 0; + #[doc = " List of 32bit integers"] + pub const OFTIntegerList: Type = 1; + #[doc = " Double Precision floating point"] + pub const OFTReal: Type = 2; + #[doc = " List of doubles"] + pub const OFTRealList: Type = 3; + #[doc = " String of ASCII chars"] + pub const OFTString: Type = 4; + #[doc = " Array of strings"] + pub const OFTStringList: Type = 5; + #[doc = " deprecated"] + pub const OFTWideString: Type = 6; + #[doc = " deprecated"] + pub const OFTWideStringList: Type = 7; + #[doc = " Raw Binary data"] + pub const OFTBinary: Type = 8; + #[doc = " Date"] + pub const OFTDate: Type = 9; + #[doc = " Time"] + pub const OFTTime: Type = 10; + #[doc = " Date and Time"] + pub const OFTDateTime: Type = 11; + #[doc = " Single 64bit integer"] + pub const OFTInteger64: Type = 12; + #[doc = " List of 64bit integers"] + pub const OFTInteger64List: Type = 13; + #[doc = " List of 64bit integers"] + pub const OFTMaxType: Type = 13; +} +pub mod OGRFieldSubType { + #[doc = " List of field subtypes. A subtype represents a hint, a restriction of the"] + #[doc = " main type, that is not strictly necessary to consult."] + #[doc = " This list is likely to be extended in the"] + #[doc = " future ... avoid coding applications based on the assumption that all"] + #[doc = " field types can be known."] + #[doc = " Most subtypes only make sense for a restricted set of main types."] + #[doc = " @since GDAL 2.0"] + pub type Type = u32; + #[doc = " No subtype. This is the default value"] + pub const OFSTNone: Type = 0; + #[doc = " Boolean integer. Only valid for OFTInteger and OFTIntegerList."] + pub const OFSTBoolean: Type = 1; + #[doc = " Signed 16-bit integer. Only valid for OFTInteger and OFTIntegerList."] + pub const OFSTInt16: Type = 2; + #[doc = " Single precision (32 bit) floating point. Only valid for OFTReal and OFTRealList."] + pub const OFSTFloat32: Type = 3; + #[doc = " JSON content. Only valid for OFTString."] + #[doc = " @since GDAL 2.4"] + pub const OFSTJSON: Type = 4; + #[doc = " JSON content. Only valid for OFTString."] + #[doc = " @since GDAL 2.4"] + pub const OFSTMaxSubType: Type = 4; +} +pub mod OGRJustification { + #[doc = " Display justification for field values."] + pub type Type = u32; + pub const OJUndefined: Type = 0; + pub const OJLeft: Type = 1; + pub const OJRight: Type = 2; +} +#[doc = " OGRFeature field attribute value union."] +#[repr(C)] +#[derive(Copy, Clone)] +pub union OGRField { + #[doc = " @cond Doxygen_Suppress"] + pub Integer: libc::c_int, + pub Integer64: GIntBig, + pub Real: f64, + pub String: *mut libc::c_char, + pub IntegerList: OGRField__bindgen_ty_1, + pub Integer64List: OGRField__bindgen_ty_2, + pub RealList: OGRField__bindgen_ty_3, + pub StringList: OGRField__bindgen_ty_4, + pub Binary: OGRField__bindgen_ty_5, + pub Set: OGRField__bindgen_ty_6, + pub Date: OGRField__bindgen_ty_7, + _bindgen_union_align: [u64; 2usize], +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_1 { + pub nCount: libc::c_int, + pub paList: *mut libc::c_int, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_1() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_1)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_1)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nCount as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_1), + "::", + stringify!(nCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).paList as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_1), + "::", + stringify!(paList) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_2 { + pub nCount: libc::c_int, + pub paList: *mut GIntBig, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_2() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_2)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_2)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nCount as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_2), + "::", + stringify!(nCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).paList as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_2), + "::", + stringify!(paList) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_3 { + pub nCount: libc::c_int, + pub paList: *mut f64, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_3() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_3)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_3)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nCount as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_3), + "::", + stringify!(nCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).paList as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_3), + "::", + stringify!(paList) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_4 { + pub nCount: libc::c_int, + pub paList: *mut *mut libc::c_char, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_4() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_4)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_4)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nCount as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_4), + "::", + stringify!(nCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).paList as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_4), + "::", + stringify!(paList) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_5 { + pub nCount: libc::c_int, + pub paData: *mut GByte, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_5() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_5)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_5)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nCount as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_5), + "::", + stringify!(nCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).paData as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_5), + "::", + stringify!(paData) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_6 { + pub nMarker1: libc::c_int, + pub nMarker2: libc::c_int, + pub nMarker3: libc::c_int, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_6() { + assert_eq!( + ::std::mem::size_of::(), + 12usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_6)) + ); + assert_eq!( + ::std::mem::align_of::(), + 4usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_6)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nMarker1 as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_6), + "::", + stringify!(nMarker1) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nMarker2 as *const _ as usize }, + 4usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_6), + "::", + stringify!(nMarker2) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nMarker3 as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_6), + "::", + stringify!(nMarker3) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRField__bindgen_ty_7 { + pub Year: GInt16, + pub Month: GByte, + pub Day: GByte, + pub Hour: GByte, + pub Minute: GByte, + pub TZFlag: GByte, + pub Reserved: GByte, + pub Second: f32, +} +#[test] +fn bindgen_test_layout_OGRField__bindgen_ty_7() { + assert_eq!( + ::std::mem::size_of::(), + 12usize, + concat!("Size of: ", stringify!(OGRField__bindgen_ty_7)) + ); + assert_eq!( + ::std::mem::align_of::(), + 4usize, + concat!("Alignment of ", stringify!(OGRField__bindgen_ty_7)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Year as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Year) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Month as *const _ as usize }, + 2usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Month) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Day as *const _ as usize }, + 3usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Day) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Hour as *const _ as usize }, + 4usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Hour) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Minute as *const _ as usize }, + 5usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Minute) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).TZFlag as *const _ as usize }, + 6usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(TZFlag) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Reserved as *const _ as usize }, + 7usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Reserved) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Second as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OGRField__bindgen_ty_7), + "::", + stringify!(Second) + ) + ); +} +#[test] +fn bindgen_test_layout_OGRField() { + assert_eq!( + ::std::mem::size_of::(), + 16usize, + concat!("Size of: ", stringify!(OGRField)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OGRField)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Integer as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Integer) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Integer64 as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Integer64) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Real as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Real) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).String as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(String) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).IntegerList as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(IntegerList) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Integer64List as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Integer64List) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).RealList as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(RealList) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).StringList as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(StringList) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Binary as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Binary) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Set as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Set) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).Date as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OGRField), + "::", + stringify!(Date) + ) + ); +} +extern "C" { + pub fn OGRParseDate( + pszInput: *const libc::c_char, + psOutput: *mut OGRField, + nOptions: libc::c_int, + ) -> libc::c_int; +} +pub mod ogr_style_tool_class_id { + #[doc = " OGRStyleTool derived class types (returned by GetType())."] + pub type Type = u32; + #[doc = "< None"] + pub const OGRSTCNone: Type = 0; + #[doc = "< Pen"] + pub const OGRSTCPen: Type = 1; + #[doc = "< Brush"] + pub const OGRSTCBrush: Type = 2; + #[doc = "< Symbol"] + pub const OGRSTCSymbol: Type = 3; + #[doc = "< Label"] + pub const OGRSTCLabel: Type = 4; + #[doc = "< Vector"] + pub const OGRSTCVector: Type = 5; +} +#[doc = " OGRStyleTool derived class types (returned by GetType())."] +pub use self::ogr_style_tool_class_id::Type as OGRSTClassId; +pub mod ogr_style_tool_units_id { + #[doc = " List of units supported by OGRStyleTools."] + pub type Type = u32; + #[doc = "< Ground unit"] + pub const OGRSTUGround: Type = 0; + #[doc = "< Pixel"] + pub const OGRSTUPixel: Type = 1; + #[doc = "< Points"] + pub const OGRSTUPoints: Type = 2; + #[doc = "< Millimeter"] + pub const OGRSTUMM: Type = 3; + #[doc = "< Centimeter"] + pub const OGRSTUCM: Type = 4; + #[doc = "< Inch"] + pub const OGRSTUInches: Type = 5; +} +#[doc = " List of units supported by OGRStyleTools."] +pub use self::ogr_style_tool_units_id::Type as OGRSTUnitId; +extern "C" { + pub fn GDALVersionInfo(arg1: *const libc::c_char) -> *const libc::c_char; +} +extern "C" { + #[doc = " Return TRUE if GDAL library version at runtime matches nVersionMajor.nVersionMinor."] + #[doc = ""] + #[doc = "The purpose of this method is to ensure that calling code will run with the GDAL"] + #[doc = "version it is compiled for. It is primarily indented for external plugins."] + #[doc = ""] + #[doc = "@param nVersionMajor Major version to be tested against"] + #[doc = "@param nVersionMinor Minor version to be tested against"] + #[doc = "@param pszCallingComponentName If not NULL, in case of version mismatch, the method"] + #[doc = "will issue a failure mentioning the name of"] + #[doc = "the calling component."] + pub fn GDALCheckVersion( + nVersionMajor: libc::c_int, + nVersionMinor: libc::c_int, + pszCallingComponentName: *const libc::c_char, + ) -> libc::c_int; +} +#[doc = " Opaque type for a geometry"] +pub type OGRGeometryH = *mut libc::c_void; +#[doc = " Opaque type for a spatial reference system"] +pub type OGRSpatialReferenceH = *mut libc::c_void; +#[doc = " Opaque type for a coordinate transformation object"] +pub type OGRCoordinateTransformationH = *mut libc::c_void; +extern "C" { + pub fn OGR_G_CreateFromWkb( + arg1: *const libc::c_void, + arg2: OGRSpatialReferenceH, + arg3: *mut OGRGeometryH, + arg4: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_CreateFromWkt( + arg1: *mut *mut libc::c_char, + arg2: OGRSpatialReferenceH, + arg3: *mut OGRGeometryH, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_CreateFromFgf( + arg1: *const libc::c_void, + arg2: OGRSpatialReferenceH, + arg3: *mut OGRGeometryH, + arg4: libc::c_int, + arg5: *mut libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_DestroyGeometry(arg1: OGRGeometryH); +} +extern "C" { + pub fn OGR_G_CreateGeometry(arg1: OGRwkbGeometryType::Type) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ApproximateArcAngles( + dfCenterX: f64, + dfCenterY: f64, + dfZ: f64, + dfPrimaryRadius: f64, + dfSecondaryAxis: f64, + dfRotation: f64, + dfStartAngle: f64, + dfEndAngle: f64, + dfMaxAngleStepSizeDegrees: f64, + ) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ForceToPolygon(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ForceToLineString(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ForceToMultiPolygon(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ForceToMultiPoint(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ForceToMultiLineString(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ForceTo( + hGeom: OGRGeometryH, + eTargetType: OGRwkbGeometryType::Type, + papszOptions: *mut *mut libc::c_char, + ) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_GetDimension(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_GetCoordinateDimension(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_CoordinateDimension(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_SetCoordinateDimension(arg1: OGRGeometryH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_G_Is3D(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_IsMeasured(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Set3D(arg1: OGRGeometryH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_G_SetMeasured(arg1: OGRGeometryH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_G_Clone(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_GetEnvelope(arg1: OGRGeometryH, arg2: *mut OGREnvelope); +} +extern "C" { + pub fn OGR_G_GetEnvelope3D(arg1: OGRGeometryH, arg2: *mut OGREnvelope3D); +} +extern "C" { + pub fn OGR_G_ImportFromWkb( + arg1: OGRGeometryH, + arg2: *const libc::c_void, + arg3: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_ExportToWkb( + arg1: OGRGeometryH, + arg2: OGRwkbByteOrder::Type, + arg3: *mut libc::c_uchar, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_ExportToIsoWkb( + arg1: OGRGeometryH, + arg2: OGRwkbByteOrder::Type, + arg3: *mut libc::c_uchar, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_WkbSize(hGeom: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_ImportFromWkt(arg1: OGRGeometryH, arg2: *mut *mut libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_ExportToWkt(arg1: OGRGeometryH, arg2: *mut *mut libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_ExportToIsoWkt(arg1: OGRGeometryH, arg2: *mut *mut libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_GetGeometryType(arg1: OGRGeometryH) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_G_GetGeometryName(arg1: OGRGeometryH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_G_DumpReadable(arg1: OGRGeometryH, arg2: *mut FILE, arg3: *const libc::c_char); +} +extern "C" { + pub fn OGR_G_FlattenTo2D(arg1: OGRGeometryH); +} +extern "C" { + pub fn OGR_G_CloseRings(arg1: OGRGeometryH); +} +extern "C" { + pub fn OGR_G_CreateFromGML(arg1: *const libc::c_char) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ExportToGML(arg1: OGRGeometryH) -> *mut libc::c_char; +} +extern "C" { + pub fn OGR_G_ExportToGMLEx( + arg1: OGRGeometryH, + papszOptions: *mut *mut libc::c_char, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn OGR_G_CreateFromGMLTree(arg1: *const CPLXMLNode) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ExportToGMLTree(arg1: OGRGeometryH) -> *mut CPLXMLNode; +} +extern "C" { + pub fn OGR_G_ExportEnvelopeToGMLTree(arg1: OGRGeometryH) -> *mut CPLXMLNode; +} +extern "C" { + pub fn OGR_G_ExportToKML( + arg1: OGRGeometryH, + pszAltitudeMode: *const libc::c_char, + ) -> *mut libc::c_char; +} +extern "C" { + pub fn OGR_G_ExportToJson(arg1: OGRGeometryH) -> *mut libc::c_char; +} +extern "C" { + pub fn OGR_G_ExportToJsonEx( + arg1: OGRGeometryH, + papszOptions: *mut *mut libc::c_char, + ) -> *mut libc::c_char; +} +extern "C" { + #[doc = " Create a OGR geometry from a GeoJSON geometry object"] + pub fn OGR_G_CreateGeometryFromJson(arg1: *const libc::c_char) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_AssignSpatialReference(arg1: OGRGeometryH, arg2: OGRSpatialReferenceH); +} +extern "C" { + pub fn OGR_G_GetSpatialReference(arg1: OGRGeometryH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OGR_G_Transform(arg1: OGRGeometryH, arg2: OGRCoordinateTransformationH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_TransformTo(arg1: OGRGeometryH, arg2: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_Simplify(hThis: OGRGeometryH, tolerance: f64) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_SimplifyPreserveTopology(hThis: OGRGeometryH, tolerance: f64) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_DelaunayTriangulation( + hThis: OGRGeometryH, + dfTolerance: f64, + bOnlyEdges: libc::c_int, + ) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Segmentize(hGeom: OGRGeometryH, dfMaxLength: f64); +} +extern "C" { + pub fn OGR_G_Intersects(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Equals(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Disjoint(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Touches(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Crosses(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Within(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Contains(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Overlaps(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Boundary(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_ConvexHull(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Buffer(arg1: OGRGeometryH, arg2: f64, arg3: libc::c_int) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Intersection(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Union(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_UnionCascaded(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_PointOnSurface(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Difference(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_SymDifference(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Distance(arg1: OGRGeometryH, arg2: OGRGeometryH) -> f64; +} +extern "C" { + pub fn OGR_G_Distance3D(arg1: OGRGeometryH, arg2: OGRGeometryH) -> f64; +} +extern "C" { + pub fn OGR_G_Length(arg1: OGRGeometryH) -> f64; +} +extern "C" { + pub fn OGR_G_Area(arg1: OGRGeometryH) -> f64; +} +extern "C" { + pub fn OGR_G_Centroid(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Value(arg1: OGRGeometryH, dfDistance: f64) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_Empty(arg1: OGRGeometryH); +} +extern "C" { + pub fn OGR_G_IsEmpty(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_IsValid(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_MakeValid(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_IsSimple(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_IsRing(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Polygonize(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGR_G_Intersect(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_Equal(arg1: OGRGeometryH, arg2: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_SymmetricDifference(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_GetArea(arg1: OGRGeometryH) -> f64; +} +extern "C" { + pub fn OGR_G_GetBoundary(arg1: OGRGeometryH) -> OGRGeometryH; +} +extern "C" { + #[doc = " @endcond"] + pub fn OGR_G_GetPointCount(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_GetPoints( + hGeom: OGRGeometryH, + pabyX: *mut libc::c_void, + nXStride: libc::c_int, + pabyY: *mut libc::c_void, + nYStride: libc::c_int, + pabyZ: *mut libc::c_void, + nZStride: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_GetPointsZM( + hGeom: OGRGeometryH, + pabyX: *mut libc::c_void, + nXStride: libc::c_int, + pabyY: *mut libc::c_void, + nYStride: libc::c_int, + pabyZ: *mut libc::c_void, + nZStride: libc::c_int, + pabyM: *mut libc::c_void, + nMStride: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_GetX(arg1: OGRGeometryH, arg2: libc::c_int) -> f64; +} +extern "C" { + pub fn OGR_G_GetY(arg1: OGRGeometryH, arg2: libc::c_int) -> f64; +} +extern "C" { + pub fn OGR_G_GetZ(arg1: OGRGeometryH, arg2: libc::c_int) -> f64; +} +extern "C" { + pub fn OGR_G_GetM(arg1: OGRGeometryH, arg2: libc::c_int) -> f64; +} +extern "C" { + pub fn OGR_G_GetPoint( + arg1: OGRGeometryH, + iPoint: libc::c_int, + arg2: *mut f64, + arg3: *mut f64, + arg4: *mut f64, + ); +} +extern "C" { + pub fn OGR_G_GetPointZM( + arg1: OGRGeometryH, + iPoint: libc::c_int, + arg2: *mut f64, + arg3: *mut f64, + arg4: *mut f64, + arg5: *mut f64, + ); +} +extern "C" { + pub fn OGR_G_SetPointCount(hGeom: OGRGeometryH, nNewPointCount: libc::c_int); +} +extern "C" { + pub fn OGR_G_SetPoint(arg1: OGRGeometryH, iPoint: libc::c_int, arg2: f64, arg3: f64, arg4: f64); +} +extern "C" { + pub fn OGR_G_SetPoint_2D(arg1: OGRGeometryH, iPoint: libc::c_int, arg2: f64, arg3: f64); +} +extern "C" { + pub fn OGR_G_SetPointM( + arg1: OGRGeometryH, + iPoint: libc::c_int, + arg2: f64, + arg3: f64, + arg4: f64, + ); +} +extern "C" { + pub fn OGR_G_SetPointZM( + arg1: OGRGeometryH, + iPoint: libc::c_int, + arg2: f64, + arg3: f64, + arg4: f64, + arg5: f64, + ); +} +extern "C" { + pub fn OGR_G_AddPoint(arg1: OGRGeometryH, arg2: f64, arg3: f64, arg4: f64); +} +extern "C" { + pub fn OGR_G_AddPoint_2D(arg1: OGRGeometryH, arg2: f64, arg3: f64); +} +extern "C" { + pub fn OGR_G_AddPointM(arg1: OGRGeometryH, arg2: f64, arg3: f64, arg4: f64); +} +extern "C" { + pub fn OGR_G_AddPointZM(arg1: OGRGeometryH, arg2: f64, arg3: f64, arg4: f64, arg5: f64); +} +extern "C" { + pub fn OGR_G_SetPoints( + hGeom: OGRGeometryH, + nPointsIn: libc::c_int, + pabyX: *const libc::c_void, + nXStride: libc::c_int, + pabyY: *const libc::c_void, + nYStride: libc::c_int, + pabyZ: *const libc::c_void, + nZStride: libc::c_int, + ); +} +extern "C" { + pub fn OGR_G_SetPointsZM( + hGeom: OGRGeometryH, + nPointsIn: libc::c_int, + pabyX: *const libc::c_void, + nXStride: libc::c_int, + pabyY: *const libc::c_void, + nYStride: libc::c_int, + pabyZ: *const libc::c_void, + nZStride: libc::c_int, + pabyM: *const libc::c_void, + nMStride: libc::c_int, + ); +} +extern "C" { + pub fn OGR_G_SwapXY(hGeom: OGRGeometryH); +} +extern "C" { + pub fn OGR_G_GetGeometryCount(arg1: OGRGeometryH) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_GetGeometryRef(arg1: OGRGeometryH, arg2: libc::c_int) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_AddGeometry(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_AddGeometryDirectly(arg1: OGRGeometryH, arg2: OGRGeometryH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_RemoveGeometry( + arg1: OGRGeometryH, + arg2: libc::c_int, + arg3: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_G_HasCurveGeometry( + arg1: OGRGeometryH, + bLookForNonLinear: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_G_GetLinearGeometry( + hGeom: OGRGeometryH, + dfMaxAngleStepSizeDegrees: f64, + papszOptions: *mut *mut libc::c_char, + ) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_G_GetCurveGeometry( + hGeom: OGRGeometryH, + papszOptions: *mut *mut libc::c_char, + ) -> OGRGeometryH; +} +extern "C" { + pub fn OGRBuildPolygonFromEdges( + hLinesAsCollection: OGRGeometryH, + bBestEffort: libc::c_int, + bAutoClose: libc::c_int, + dfTolerance: f64, + peErr: *mut OGRErr::Type, + ) -> OGRGeometryH; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGRSetGenerate_DB2_V72_BYTE_ORDER( + bGenerate_DB2_V72_BYTE_ORDER: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGRGetGenerate_DB2_V72_BYTE_ORDER() -> libc::c_int; +} +extern "C" { + #[doc = " @endcond"] + pub fn OGRSetNonLinearGeometriesEnabledFlag(bFlag: libc::c_int); +} +extern "C" { + pub fn OGRGetNonLinearGeometriesEnabledFlag() -> libc::c_int; +} +#[doc = " Opaque type for a field definition (OGRFieldDefn)"] +pub type OGRFieldDefnH = *mut libc::c_void; +#[doc = " Opaque type for a feature definition (OGRFeatureDefn)"] +pub type OGRFeatureDefnH = *mut libc::c_void; +#[doc = " Opaque type for a feature (OGRFeature)"] +pub type OGRFeatureH = *mut libc::c_void; +#[doc = " Opaque type for a style table (OGRStyleTable)"] +pub type OGRStyleTableH = *mut libc::c_void; +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRGeomFieldDefnHS { + _unused: [u8; 0], +} +#[doc = " Opaque type for a geometry field definition (OGRGeomFieldDefn)"] +pub type OGRGeomFieldDefnH = *mut OGRGeomFieldDefnHS; +extern "C" { + pub fn OGR_Fld_Create(arg1: *const libc::c_char, arg2: OGRFieldType::Type) -> OGRFieldDefnH; +} +extern "C" { + pub fn OGR_Fld_Destroy(arg1: OGRFieldDefnH); +} +extern "C" { + pub fn OGR_Fld_SetName(arg1: OGRFieldDefnH, arg2: *const libc::c_char); +} +extern "C" { + pub fn OGR_Fld_GetNameRef(arg1: OGRFieldDefnH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_Fld_GetType(arg1: OGRFieldDefnH) -> OGRFieldType::Type; +} +extern "C" { + pub fn OGR_Fld_SetType(arg1: OGRFieldDefnH, arg2: OGRFieldType::Type); +} +extern "C" { + pub fn OGR_Fld_GetSubType(arg1: OGRFieldDefnH) -> OGRFieldSubType::Type; +} +extern "C" { + pub fn OGR_Fld_SetSubType(arg1: OGRFieldDefnH, arg2: OGRFieldSubType::Type); +} +extern "C" { + pub fn OGR_Fld_GetJustify(arg1: OGRFieldDefnH) -> OGRJustification::Type; +} +extern "C" { + pub fn OGR_Fld_SetJustify(arg1: OGRFieldDefnH, arg2: OGRJustification::Type); +} +extern "C" { + pub fn OGR_Fld_GetWidth(arg1: OGRFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_Fld_SetWidth(arg1: OGRFieldDefnH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_Fld_GetPrecision(arg1: OGRFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_Fld_SetPrecision(arg1: OGRFieldDefnH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_Fld_Set( + arg1: OGRFieldDefnH, + arg2: *const libc::c_char, + arg3: OGRFieldType::Type, + arg4: libc::c_int, + arg5: libc::c_int, + arg6: OGRJustification::Type, + ); +} +extern "C" { + pub fn OGR_Fld_IsIgnored(hDefn: OGRFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_Fld_SetIgnored(hDefn: OGRFieldDefnH, arg1: libc::c_int); +} +extern "C" { + pub fn OGR_Fld_IsNullable(hDefn: OGRFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_Fld_SetNullable(hDefn: OGRFieldDefnH, arg1: libc::c_int); +} +extern "C" { + pub fn OGR_Fld_GetDefault(hDefn: OGRFieldDefnH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_Fld_SetDefault(hDefn: OGRFieldDefnH, arg1: *const libc::c_char); +} +extern "C" { + pub fn OGR_Fld_IsDefaultDriverSpecific(hDefn: OGRFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_GetFieldTypeName(arg1: OGRFieldType::Type) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_GetFieldSubTypeName(arg1: OGRFieldSubType::Type) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_AreTypeSubTypeCompatible( + eType: OGRFieldType::Type, + eSubType: OGRFieldSubType::Type, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_GFld_Create( + arg1: *const libc::c_char, + arg2: OGRwkbGeometryType::Type, + ) -> OGRGeomFieldDefnH; +} +extern "C" { + pub fn OGR_GFld_Destroy(arg1: OGRGeomFieldDefnH); +} +extern "C" { + pub fn OGR_GFld_SetName(arg1: OGRGeomFieldDefnH, arg2: *const libc::c_char); +} +extern "C" { + pub fn OGR_GFld_GetNameRef(arg1: OGRGeomFieldDefnH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_GFld_GetType(arg1: OGRGeomFieldDefnH) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_GFld_SetType(arg1: OGRGeomFieldDefnH, arg2: OGRwkbGeometryType::Type); +} +extern "C" { + pub fn OGR_GFld_GetSpatialRef(arg1: OGRGeomFieldDefnH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OGR_GFld_SetSpatialRef(arg1: OGRGeomFieldDefnH, hSRS: OGRSpatialReferenceH); +} +extern "C" { + pub fn OGR_GFld_IsNullable(hDefn: OGRGeomFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_GFld_SetNullable(hDefn: OGRGeomFieldDefnH, arg1: libc::c_int); +} +extern "C" { + pub fn OGR_GFld_IsIgnored(hDefn: OGRGeomFieldDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_GFld_SetIgnored(hDefn: OGRGeomFieldDefnH, arg1: libc::c_int); +} +extern "C" { + pub fn OGR_FD_Create(arg1: *const libc::c_char) -> OGRFeatureDefnH; +} +extern "C" { + pub fn OGR_FD_Destroy(arg1: OGRFeatureDefnH); +} +extern "C" { + pub fn OGR_FD_Release(arg1: OGRFeatureDefnH); +} +extern "C" { + pub fn OGR_FD_GetName(arg1: OGRFeatureDefnH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_FD_GetFieldCount(arg1: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_GetFieldDefn(arg1: OGRFeatureDefnH, arg2: libc::c_int) -> OGRFieldDefnH; +} +extern "C" { + pub fn OGR_FD_GetFieldIndex(arg1: OGRFeatureDefnH, arg2: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_AddFieldDefn(arg1: OGRFeatureDefnH, arg2: OGRFieldDefnH); +} +extern "C" { + pub fn OGR_FD_DeleteFieldDefn(hDefn: OGRFeatureDefnH, iField: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_FD_ReorderFieldDefns( + hDefn: OGRFeatureDefnH, + panMap: *mut libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_FD_GetGeomType(arg1: OGRFeatureDefnH) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_FD_SetGeomType(arg1: OGRFeatureDefnH, arg2: OGRwkbGeometryType::Type); +} +extern "C" { + pub fn OGR_FD_IsGeometryIgnored(arg1: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_SetGeometryIgnored(arg1: OGRFeatureDefnH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_FD_IsStyleIgnored(arg1: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_SetStyleIgnored(arg1: OGRFeatureDefnH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_FD_Reference(arg1: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_Dereference(arg1: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_GetReferenceCount(arg1: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_GetGeomFieldCount(hFDefn: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_GetGeomFieldDefn(hFDefn: OGRFeatureDefnH, i: libc::c_int) -> OGRGeomFieldDefnH; +} +extern "C" { + pub fn OGR_FD_GetGeomFieldIndex( + hFDefn: OGRFeatureDefnH, + pszName: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_FD_AddGeomFieldDefn(hFDefn: OGRFeatureDefnH, hGFldDefn: OGRGeomFieldDefnH); +} +extern "C" { + pub fn OGR_FD_DeleteGeomFieldDefn( + hFDefn: OGRFeatureDefnH, + iGeomField: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_FD_IsSame(hFDefn: OGRFeatureDefnH, hOtherFDefn: OGRFeatureDefnH) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_Create(arg1: OGRFeatureDefnH) -> OGRFeatureH; +} +extern "C" { + pub fn OGR_F_Destroy(arg1: OGRFeatureH); +} +extern "C" { + pub fn OGR_F_GetDefnRef(arg1: OGRFeatureH) -> OGRFeatureDefnH; +} +extern "C" { + pub fn OGR_F_SetGeometryDirectly(arg1: OGRFeatureH, arg2: OGRGeometryH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_SetGeometry(arg1: OGRFeatureH, arg2: OGRGeometryH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_GetGeometryRef(arg1: OGRFeatureH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_F_StealGeometry(arg1: OGRFeatureH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_F_Clone(arg1: OGRFeatureH) -> OGRFeatureH; +} +extern "C" { + pub fn OGR_F_Equal(arg1: OGRFeatureH, arg2: OGRFeatureH) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_GetFieldCount(arg1: OGRFeatureH) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_GetFieldDefnRef(arg1: OGRFeatureH, arg2: libc::c_int) -> OGRFieldDefnH; +} +extern "C" { + pub fn OGR_F_GetFieldIndex(arg1: OGRFeatureH, arg2: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_IsFieldSet(arg1: OGRFeatureH, arg2: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_UnsetField(arg1: OGRFeatureH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_F_IsFieldNull(arg1: OGRFeatureH, arg2: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_IsFieldSetAndNotNull(arg1: OGRFeatureH, arg2: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_SetFieldNull(arg1: OGRFeatureH, arg2: libc::c_int); +} +extern "C" { + pub fn OGR_F_GetRawFieldRef(arg1: OGRFeatureH, arg2: libc::c_int) -> *mut OGRField; +} +extern "C" { + pub fn OGR_RawField_IsUnset(arg1: *const OGRField) -> libc::c_int; +} +extern "C" { + pub fn OGR_RawField_IsNull(arg1: *const OGRField) -> libc::c_int; +} +extern "C" { + pub fn OGR_RawField_SetUnset(arg1: *mut OGRField); +} +extern "C" { + pub fn OGR_RawField_SetNull(arg1: *mut OGRField); +} +extern "C" { + pub fn OGR_F_GetFieldAsInteger(arg1: OGRFeatureH, arg2: libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_GetFieldAsInteger64(arg1: OGRFeatureH, arg2: libc::c_int) -> GIntBig; +} +extern "C" { + pub fn OGR_F_GetFieldAsDouble(arg1: OGRFeatureH, arg2: libc::c_int) -> f64; +} +extern "C" { + pub fn OGR_F_GetFieldAsString(arg1: OGRFeatureH, arg2: libc::c_int) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_F_GetFieldAsIntegerList( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: *mut libc::c_int, + ) -> *const libc::c_int; +} +extern "C" { + pub fn OGR_F_GetFieldAsInteger64List( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: *mut libc::c_int, + ) -> *const GIntBig; +} +extern "C" { + pub fn OGR_F_GetFieldAsDoubleList( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: *mut libc::c_int, + ) -> *const f64; +} +extern "C" { + pub fn OGR_F_GetFieldAsStringList( + arg1: OGRFeatureH, + arg2: libc::c_int, + ) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn OGR_F_GetFieldAsBinary( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: *mut libc::c_int, + ) -> *mut GByte; +} +extern "C" { + pub fn OGR_F_GetFieldAsDateTime( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: *mut libc::c_int, + arg4: *mut libc::c_int, + arg5: *mut libc::c_int, + arg6: *mut libc::c_int, + arg7: *mut libc::c_int, + arg8: *mut libc::c_int, + arg9: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_GetFieldAsDateTimeEx( + hFeat: OGRFeatureH, + iField: libc::c_int, + pnYear: *mut libc::c_int, + pnMonth: *mut libc::c_int, + pnDay: *mut libc::c_int, + pnHour: *mut libc::c_int, + pnMinute: *mut libc::c_int, + pfSecond: *mut f32, + pnTZFlag: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_SetFieldInteger(arg1: OGRFeatureH, arg2: libc::c_int, arg3: libc::c_int); +} +extern "C" { + pub fn OGR_F_SetFieldInteger64(arg1: OGRFeatureH, arg2: libc::c_int, arg3: GIntBig); +} +extern "C" { + pub fn OGR_F_SetFieldDouble(arg1: OGRFeatureH, arg2: libc::c_int, arg3: f64); +} +extern "C" { + pub fn OGR_F_SetFieldString(arg1: OGRFeatureH, arg2: libc::c_int, arg3: *const libc::c_char); +} +extern "C" { + pub fn OGR_F_SetFieldIntegerList( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *const libc::c_int, + ); +} +extern "C" { + pub fn OGR_F_SetFieldInteger64List( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *const GIntBig, + ); +} +extern "C" { + pub fn OGR_F_SetFieldDoubleList( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *const f64, + ); +} +extern "C" { + pub fn OGR_F_SetFieldStringList(arg1: OGRFeatureH, arg2: libc::c_int, arg3: CSLConstList); +} +extern "C" { + pub fn OGR_F_SetFieldRaw(arg1: OGRFeatureH, arg2: libc::c_int, arg3: *mut OGRField); +} +extern "C" { + pub fn OGR_F_SetFieldBinary( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *const libc::c_void, + ); +} +extern "C" { + pub fn OGR_F_SetFieldDateTime( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: libc::c_int, + arg6: libc::c_int, + arg7: libc::c_int, + arg8: libc::c_int, + arg9: libc::c_int, + ); +} +extern "C" { + pub fn OGR_F_SetFieldDateTimeEx( + arg1: OGRFeatureH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: libc::c_int, + arg6: libc::c_int, + arg7: libc::c_int, + arg8: f32, + arg9: libc::c_int, + ); +} +extern "C" { + pub fn OGR_F_GetGeomFieldCount(hFeat: OGRFeatureH) -> libc::c_int; +} +extern "C" { + pub fn OGR_F_GetGeomFieldDefnRef(hFeat: OGRFeatureH, iField: libc::c_int) -> OGRGeomFieldDefnH; +} +extern "C" { + pub fn OGR_F_GetGeomFieldIndex(hFeat: OGRFeatureH, pszName: *const libc::c_char) + -> libc::c_int; +} +extern "C" { + pub fn OGR_F_GetGeomFieldRef(hFeat: OGRFeatureH, iField: libc::c_int) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_F_SetGeomFieldDirectly( + hFeat: OGRFeatureH, + iField: libc::c_int, + hGeom: OGRGeometryH, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_SetGeomField( + hFeat: OGRFeatureH, + iField: libc::c_int, + hGeom: OGRGeometryH, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_GetFID(arg1: OGRFeatureH) -> GIntBig; +} +extern "C" { + pub fn OGR_F_SetFID(arg1: OGRFeatureH, arg2: GIntBig) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_DumpReadable(arg1: OGRFeatureH, arg2: *mut FILE); +} +extern "C" { + pub fn OGR_F_SetFrom(arg1: OGRFeatureH, arg2: OGRFeatureH, arg3: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_SetFromWithMap( + arg1: OGRFeatureH, + arg2: OGRFeatureH, + arg3: libc::c_int, + arg4: *const libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_F_GetStyleString(arg1: OGRFeatureH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_F_SetStyleString(arg1: OGRFeatureH, arg2: *const libc::c_char); +} +extern "C" { + pub fn OGR_F_SetStyleStringDirectly(arg1: OGRFeatureH, arg2: *mut libc::c_char); +} +extern "C" { + #[doc = " Return style table"] + pub fn OGR_F_GetStyleTable(arg1: OGRFeatureH) -> OGRStyleTableH; +} +extern "C" { + #[doc = " Set style table and take ownership"] + pub fn OGR_F_SetStyleTableDirectly(arg1: OGRFeatureH, arg2: OGRStyleTableH); +} +extern "C" { + #[doc = " Set style table"] + pub fn OGR_F_SetStyleTable(arg1: OGRFeatureH, arg2: OGRStyleTableH); +} +extern "C" { + pub fn OGR_F_GetNativeData(arg1: OGRFeatureH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_F_SetNativeData(arg1: OGRFeatureH, arg2: *const libc::c_char); +} +extern "C" { + pub fn OGR_F_GetNativeMediaType(arg1: OGRFeatureH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_F_SetNativeMediaType(arg1: OGRFeatureH, arg2: *const libc::c_char); +} +extern "C" { + pub fn OGR_F_FillUnsetWithDefault( + hFeat: OGRFeatureH, + bNotNullableOnly: libc::c_int, + papszOptions: *mut *mut libc::c_char, + ); +} +extern "C" { + pub fn OGR_F_Validate( + arg1: OGRFeatureH, + nValidateFlags: libc::c_int, + bEmitError: libc::c_int, + ) -> libc::c_int; +} +#[doc = " Opaque type for a layer (OGRLayer)"] +pub type OGRLayerH = *mut libc::c_void; +#[doc = " Opaque type for a OGR datasource (OGRDataSource)"] +pub type OGRDataSourceH = *mut libc::c_void; +#[doc = " Opaque type for a OGR driver (OGRSFDriver)"] +pub type OGRSFDriverH = *mut libc::c_void; +extern "C" { + pub fn OGR_L_GetName(arg1: OGRLayerH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_L_GetGeomType(arg1: OGRLayerH) -> OGRwkbGeometryType::Type; +} +extern "C" { + pub fn OGR_L_GetSpatialFilter(arg1: OGRLayerH) -> OGRGeometryH; +} +extern "C" { + pub fn OGR_L_SetSpatialFilter(arg1: OGRLayerH, arg2: OGRGeometryH); +} +extern "C" { + pub fn OGR_L_SetSpatialFilterRect(arg1: OGRLayerH, arg2: f64, arg3: f64, arg4: f64, arg5: f64); +} +extern "C" { + pub fn OGR_L_SetSpatialFilterEx(arg1: OGRLayerH, iGeomField: libc::c_int, hGeom: OGRGeometryH); +} +extern "C" { + pub fn OGR_L_SetSpatialFilterRectEx( + arg1: OGRLayerH, + iGeomField: libc::c_int, + dfMinX: f64, + dfMinY: f64, + dfMaxX: f64, + dfMaxY: f64, + ); +} +extern "C" { + pub fn OGR_L_SetAttributeFilter(arg1: OGRLayerH, arg2: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_ResetReading(arg1: OGRLayerH); +} +extern "C" { + pub fn OGR_L_GetNextFeature(arg1: OGRLayerH) -> OGRFeatureH; +} +extern "C" { + pub fn OGR_L_SetNextByIndex(arg1: OGRLayerH, arg2: GIntBig) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_GetFeature(arg1: OGRLayerH, arg2: GIntBig) -> OGRFeatureH; +} +extern "C" { + pub fn OGR_L_SetFeature(arg1: OGRLayerH, arg2: OGRFeatureH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_CreateFeature(arg1: OGRLayerH, arg2: OGRFeatureH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_DeleteFeature(arg1: OGRLayerH, arg2: GIntBig) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_GetLayerDefn(arg1: OGRLayerH) -> OGRFeatureDefnH; +} +extern "C" { + pub fn OGR_L_GetSpatialRef(arg1: OGRLayerH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OGR_L_FindFieldIndex( + arg1: OGRLayerH, + arg2: *const libc::c_char, + bExactMatch: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_L_GetFeatureCount(arg1: OGRLayerH, arg2: libc::c_int) -> GIntBig; +} +extern "C" { + pub fn OGR_L_GetExtent( + arg1: OGRLayerH, + arg2: *mut OGREnvelope, + arg3: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_GetExtentEx( + arg1: OGRLayerH, + iGeomField: libc::c_int, + psExtent: *mut OGREnvelope, + bForce: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_TestCapability(arg1: OGRLayerH, arg2: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn OGR_L_CreateField( + arg1: OGRLayerH, + arg2: OGRFieldDefnH, + arg3: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_CreateGeomField( + hLayer: OGRLayerH, + hFieldDefn: OGRGeomFieldDefnH, + bForce: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_DeleteField(arg1: OGRLayerH, iField: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_ReorderFields(arg1: OGRLayerH, panMap: *mut libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_ReorderField( + arg1: OGRLayerH, + iOldFieldPos: libc::c_int, + iNewFieldPos: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_AlterFieldDefn( + arg1: OGRLayerH, + iField: libc::c_int, + hNewFieldDefn: OGRFieldDefnH, + nFlags: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_StartTransaction(arg1: OGRLayerH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_CommitTransaction(arg1: OGRLayerH) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_RollbackTransaction(arg1: OGRLayerH) -> OGRErr::Type; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGR_L_Reference(arg1: OGRLayerH) -> libc::c_int; +} +extern "C" { + pub fn OGR_L_Dereference(arg1: OGRLayerH) -> libc::c_int; +} +extern "C" { + pub fn OGR_L_GetRefCount(arg1: OGRLayerH) -> libc::c_int; +} +extern "C" { + #[doc = " @endcond"] + pub fn OGR_L_SyncToDisk(arg1: OGRLayerH) -> OGRErr::Type; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGR_L_GetFeaturesRead(arg1: OGRLayerH) -> GIntBig; +} +extern "C" { + #[doc = " @endcond"] + pub fn OGR_L_GetFIDColumn(arg1: OGRLayerH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_L_GetGeometryColumn(arg1: OGRLayerH) -> *const libc::c_char; +} +extern "C" { + #[doc = " Get style table"] + pub fn OGR_L_GetStyleTable(arg1: OGRLayerH) -> OGRStyleTableH; +} +extern "C" { + #[doc = " Set style table (and take ownership)"] + pub fn OGR_L_SetStyleTableDirectly(arg1: OGRLayerH, arg2: OGRStyleTableH); +} +extern "C" { + #[doc = " Set style table"] + pub fn OGR_L_SetStyleTable(arg1: OGRLayerH, arg2: OGRStyleTableH); +} +extern "C" { + pub fn OGR_L_SetIgnoredFields(arg1: OGRLayerH, arg2: *mut *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_Intersection( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_Union( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_SymDifference( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_Identity( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_Update( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_Clip( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_L_Erase( + arg1: OGRLayerH, + arg2: OGRLayerH, + arg3: OGRLayerH, + arg4: *mut *mut libc::c_char, + arg5: GDALProgressFunc, + arg6: *mut libc::c_void, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_DS_Destroy(arg1: OGRDataSourceH); +} +extern "C" { + pub fn OGR_DS_GetName(arg1: OGRDataSourceH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_DS_GetLayerCount(arg1: OGRDataSourceH) -> libc::c_int; +} +extern "C" { + pub fn OGR_DS_GetLayer(arg1: OGRDataSourceH, arg2: libc::c_int) -> OGRLayerH; +} +extern "C" { + pub fn OGR_DS_GetLayerByName(arg1: OGRDataSourceH, arg2: *const libc::c_char) -> OGRLayerH; +} +extern "C" { + pub fn OGR_DS_DeleteLayer(arg1: OGRDataSourceH, arg2: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OGR_DS_GetDriver(arg1: OGRDataSourceH) -> OGRSFDriverH; +} +extern "C" { + pub fn OGR_DS_CreateLayer( + arg1: OGRDataSourceH, + arg2: *const libc::c_char, + arg3: OGRSpatialReferenceH, + arg4: OGRwkbGeometryType::Type, + arg5: *mut *mut libc::c_char, + ) -> OGRLayerH; +} +extern "C" { + pub fn OGR_DS_CopyLayer( + arg1: OGRDataSourceH, + arg2: OGRLayerH, + arg3: *const libc::c_char, + arg4: *mut *mut libc::c_char, + ) -> OGRLayerH; +} +extern "C" { + pub fn OGR_DS_TestCapability(arg1: OGRDataSourceH, arg2: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn OGR_DS_ExecuteSQL( + arg1: OGRDataSourceH, + arg2: *const libc::c_char, + arg3: OGRGeometryH, + arg4: *const libc::c_char, + ) -> OGRLayerH; +} +extern "C" { + pub fn OGR_DS_ReleaseResultSet(arg1: OGRDataSourceH, arg2: OGRLayerH); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGR_DS_Reference(arg1: OGRDataSourceH) -> libc::c_int; +} +extern "C" { + pub fn OGR_DS_Dereference(arg1: OGRDataSourceH) -> libc::c_int; +} +extern "C" { + pub fn OGR_DS_GetRefCount(arg1: OGRDataSourceH) -> libc::c_int; +} +extern "C" { + pub fn OGR_DS_GetSummaryRefCount(arg1: OGRDataSourceH) -> libc::c_int; +} +extern "C" { + #[doc = " @endcond */"] + pub fn OGR_DS_SyncToDisk(arg1: OGRDataSourceH) -> OGRErr::Type; +} +extern "C" { + #[doc = " Get style table"] + pub fn OGR_DS_GetStyleTable(arg1: OGRDataSourceH) -> OGRStyleTableH; +} +extern "C" { + #[doc = " Set style table (and take ownership)"] + pub fn OGR_DS_SetStyleTableDirectly(arg1: OGRDataSourceH, arg2: OGRStyleTableH); +} +extern "C" { + #[doc = " Set style table"] + pub fn OGR_DS_SetStyleTable(arg1: OGRDataSourceH, arg2: OGRStyleTableH); +} +extern "C" { + pub fn OGR_Dr_GetName(arg1: OGRSFDriverH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_Dr_Open( + arg1: OGRSFDriverH, + arg2: *const libc::c_char, + arg3: libc::c_int, + ) -> OGRDataSourceH; +} +extern "C" { + pub fn OGR_Dr_TestCapability(arg1: OGRSFDriverH, arg2: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn OGR_Dr_CreateDataSource( + arg1: OGRSFDriverH, + arg2: *const libc::c_char, + arg3: *mut *mut libc::c_char, + ) -> OGRDataSourceH; +} +extern "C" { + pub fn OGR_Dr_CopyDataSource( + arg1: OGRSFDriverH, + arg2: OGRDataSourceH, + arg3: *const libc::c_char, + arg4: *mut *mut libc::c_char, + ) -> OGRDataSourceH; +} +extern "C" { + pub fn OGR_Dr_DeleteDataSource(arg1: OGRSFDriverH, arg2: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OGROpen( + arg1: *const libc::c_char, + arg2: libc::c_int, + arg3: *mut OGRSFDriverH, + ) -> OGRDataSourceH; +} +extern "C" { + pub fn OGROpenShared( + arg1: *const libc::c_char, + arg2: libc::c_int, + arg3: *mut OGRSFDriverH, + ) -> OGRDataSourceH; +} +extern "C" { + pub fn OGRReleaseDataSource(arg1: OGRDataSourceH) -> OGRErr::Type; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGRRegisterDriver(arg1: OGRSFDriverH); +} +extern "C" { + pub fn OGRDeregisterDriver(arg1: OGRSFDriverH); +} +extern "C" { + #[doc = " @endcond"] + pub fn OGRGetDriverCount() -> libc::c_int; +} +extern "C" { + pub fn OGRGetDriver(arg1: libc::c_int) -> OGRSFDriverH; +} +extern "C" { + pub fn OGRGetDriverByName(arg1: *const libc::c_char) -> OGRSFDriverH; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn OGRGetOpenDSCount() -> libc::c_int; +} +extern "C" { + pub fn OGRGetOpenDS(iDS: libc::c_int) -> OGRDataSourceH; +} +extern "C" { + #[doc = " @endcond"] + pub fn OGRRegisterAll(); +} +extern "C" { + #[doc = " Clean-up all drivers (including raster ones starting with GDAL 2.0."] + #[doc = " See GDALDestroyDriverManager()"] + pub fn OGRCleanupAll(); +} +#[doc = " Style manager opaque type"] +pub type OGRStyleMgrH = *mut libc::c_void; +#[doc = " Style tool opaque type"] +pub type OGRStyleToolH = *mut libc::c_void; +extern "C" { + pub fn OGR_SM_Create(hStyleTable: OGRStyleTableH) -> OGRStyleMgrH; +} +extern "C" { + pub fn OGR_SM_Destroy(hSM: OGRStyleMgrH); +} +extern "C" { + pub fn OGR_SM_InitFromFeature(hSM: OGRStyleMgrH, hFeat: OGRFeatureH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_SM_InitStyleString( + hSM: OGRStyleMgrH, + pszStyleString: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_SM_GetPartCount( + hSM: OGRStyleMgrH, + pszStyleString: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_SM_GetPart( + hSM: OGRStyleMgrH, + nPartId: libc::c_int, + pszStyleString: *const libc::c_char, + ) -> OGRStyleToolH; +} +extern "C" { + pub fn OGR_SM_AddPart(hSM: OGRStyleMgrH, hST: OGRStyleToolH) -> libc::c_int; +} +extern "C" { + pub fn OGR_SM_AddStyle( + hSM: OGRStyleMgrH, + pszStyleName: *const libc::c_char, + pszStyleString: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_ST_Create(eClassId: OGRSTClassId) -> OGRStyleToolH; +} +extern "C" { + pub fn OGR_ST_Destroy(hST: OGRStyleToolH); +} +extern "C" { + pub fn OGR_ST_GetType(hST: OGRStyleToolH) -> OGRSTClassId; +} +extern "C" { + pub fn OGR_ST_GetUnit(hST: OGRStyleToolH) -> OGRSTUnitId; +} +extern "C" { + pub fn OGR_ST_SetUnit(hST: OGRStyleToolH, eUnit: OGRSTUnitId, dfGroundPaperScale: f64); +} +extern "C" { + pub fn OGR_ST_GetParamStr( + hST: OGRStyleToolH, + eParam: libc::c_int, + bValueIsNull: *mut libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_ST_GetParamNum( + hST: OGRStyleToolH, + eParam: libc::c_int, + bValueIsNull: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_ST_GetParamDbl( + hST: OGRStyleToolH, + eParam: libc::c_int, + bValueIsNull: *mut libc::c_int, + ) -> f64; +} +extern "C" { + pub fn OGR_ST_SetParamStr( + hST: OGRStyleToolH, + eParam: libc::c_int, + pszValue: *const libc::c_char, + ); +} +extern "C" { + pub fn OGR_ST_SetParamNum(hST: OGRStyleToolH, eParam: libc::c_int, nValue: libc::c_int); +} +extern "C" { + pub fn OGR_ST_SetParamDbl(hST: OGRStyleToolH, eParam: libc::c_int, dfValue: f64); +} +extern "C" { + pub fn OGR_ST_GetStyleString(hST: OGRStyleToolH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_ST_GetRGBFromString( + hST: OGRStyleToolH, + pszColor: *const libc::c_char, + pnRed: *mut libc::c_int, + pnGreen: *mut libc::c_int, + pnBlue: *mut libc::c_int, + pnAlpha: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_STBL_Create() -> OGRStyleTableH; +} +extern "C" { + pub fn OGR_STBL_Destroy(hSTBL: OGRStyleTableH); +} +extern "C" { + pub fn OGR_STBL_AddStyle( + hStyleTable: OGRStyleTableH, + pszName: *const libc::c_char, + pszStyleString: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_STBL_SaveStyleTable( + hStyleTable: OGRStyleTableH, + pszFilename: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_STBL_LoadStyleTable( + hStyleTable: OGRStyleTableH, + pszFilename: *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OGR_STBL_Find( + hStyleTable: OGRStyleTableH, + pszName: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_STBL_ResetStyleStringReading(hStyleTable: OGRStyleTableH); +} +extern "C" { + pub fn OGR_STBL_GetNextStyle(hStyleTable: OGRStyleTableH) -> *const libc::c_char; +} +extern "C" { + pub fn OGR_STBL_GetLastStyleName(hStyleTable: OGRStyleTableH) -> *const libc::c_char; +} +pub mod GDALDataType { + #[doc = " Pixel data types"] + pub type Type = u32; + #[doc = " Unknown or unspecified type"] + pub const GDT_Unknown: Type = 0; + #[doc = " Eight bit unsigned integer"] + pub const GDT_Byte: Type = 1; + #[doc = " Sixteen bit unsigned integer"] + pub const GDT_UInt16: Type = 2; + #[doc = " Sixteen bit signed integer"] + pub const GDT_Int16: Type = 3; + #[doc = " Thirty two bit unsigned integer"] + pub const GDT_UInt32: Type = 4; + #[doc = " Thirty two bit signed integer"] + pub const GDT_Int32: Type = 5; + #[doc = " Thirty two bit floating point"] + pub const GDT_Float32: Type = 6; + #[doc = " Sixty four bit floating point"] + pub const GDT_Float64: Type = 7; + #[doc = " Complex Int16"] + pub const GDT_CInt16: Type = 8; + #[doc = " Complex Int32"] + pub const GDT_CInt32: Type = 9; + #[doc = " Complex Float32"] + pub const GDT_CFloat32: Type = 10; + #[doc = " Complex Float64"] + pub const GDT_CFloat64: Type = 11; + #[doc = " Complex Float64"] + pub const GDT_TypeCount: Type = 12; +} +extern "C" { + pub fn GDALGetDataTypeSize(arg1: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALGetDataTypeSizeBits(eDataType: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALGetDataTypeSizeBytes(arg1: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALDataTypeIsComplex(arg1: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALDataTypeIsInteger(arg1: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALDataTypeIsFloating(arg1: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALDataTypeIsSigned(arg1: GDALDataType::Type) -> libc::c_int; +} +extern "C" { + pub fn GDALGetDataTypeName(arg1: GDALDataType::Type) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetDataTypeByName(arg1: *const libc::c_char) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALDataTypeUnion( + arg1: GDALDataType::Type, + arg2: GDALDataType::Type, + ) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALDataTypeUnionWithValue( + eDT: GDALDataType::Type, + dValue: f64, + bComplex: libc::c_int, + ) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALFindDataType( + nBits: libc::c_int, + bSigned: libc::c_int, + bFloating: libc::c_int, + bComplex: libc::c_int, + ) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALFindDataTypeForValue(dValue: f64, bComplex: libc::c_int) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALAdjustValueToDataType( + eDT: GDALDataType::Type, + dfValue: f64, + pbClamped: *mut libc::c_int, + pbRounded: *mut libc::c_int, + ) -> f64; +} +extern "C" { + pub fn GDALGetNonComplexDataType(arg1: GDALDataType::Type) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALDataTypeIsConversionLossy( + eTypeFrom: GDALDataType::Type, + eTypeTo: GDALDataType::Type, + ) -> libc::c_int; +} +pub mod GDALAsyncStatusType { + #[doc = " status of the asynchronous stream"] + pub type Type = u32; + pub const GARIO_PENDING: Type = 0; + pub const GARIO_UPDATE: Type = 1; + pub const GARIO_ERROR: Type = 2; + pub const GARIO_COMPLETE: Type = 3; + pub const GARIO_TypeCount: Type = 4; +} +extern "C" { + pub fn GDALGetAsyncStatusTypeName(arg1: GDALAsyncStatusType::Type) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetAsyncStatusTypeByName(arg1: *const libc::c_char) -> GDALAsyncStatusType::Type; +} +pub mod GDALAccess { + #[doc = " Flag indicating read/write, or read-only access to data."] + pub type Type = u32; + #[doc = " Read only (no update) access"] + pub const GA_ReadOnly: Type = 0; + #[doc = " Read/write access."] + pub const GA_Update: Type = 1; +} +pub mod GDALRWFlag { + #[doc = " Read/Write flag for RasterIO() method"] + pub type Type = u32; + #[doc = " Read data"] + pub const GF_Read: Type = 0; + #[doc = " Write data"] + pub const GF_Write: Type = 1; +} +pub mod GDALRIOResampleAlg { + #[doc = " RasterIO() resampling method."] + #[doc = " @since GDAL 2.0"] + pub type Type = u32; + #[doc = " Nearest neighbour"] + pub const GRIORA_NearestNeighbour: Type = 0; + #[doc = " Bilinear (2x2 kernel)"] + pub const GRIORA_Bilinear: Type = 1; + #[doc = " Cubic Convolution Approximation (4x4 kernel)"] + pub const GRIORA_Cubic: Type = 2; + #[doc = " Cubic B-Spline Approximation (4x4 kernel)"] + pub const GRIORA_CubicSpline: Type = 3; + #[doc = " Lanczos windowed sinc interpolation (6x6 kernel)"] + pub const GRIORA_Lanczos: Type = 4; + #[doc = " Average"] + pub const GRIORA_Average: Type = 5; + #[doc = " Mode (selects the value which appears most often of all the sampled points)"] + pub const GRIORA_Mode: Type = 6; + #[doc = " Gauss blurring"] + pub const GRIORA_Gauss: Type = 7; +} +#[doc = " Structure to pass extra arguments to RasterIO() method"] +#[doc = " @since GDAL 2.0"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALRasterIOExtraArg { + #[doc = " Version of structure (to allow future extensions of the structure)"] + pub nVersion: libc::c_int, + #[doc = " Resampling algorithm"] + pub eResampleAlg: GDALRIOResampleAlg::Type, + #[doc = " Progress callback"] + pub pfnProgress: GDALProgressFunc, + #[doc = " Progress callback user data"] + pub pProgressData: *mut libc::c_void, + #[doc = " Indicate if dfXOff, dfYOff, dfXSize and dfYSize are set."] + #[doc = "Mostly reserved from the VRT driver to communicate a more precise"] + #[doc = "source window. Must be such that dfXOff - nXOff < 1.0 and"] + #[doc = "dfYOff - nYOff < 1.0 and nXSize - dfXSize < 1.0 and nYSize - dfYSize < 1.0"] + pub bFloatingPointWindowValidity: libc::c_int, + #[doc = " Pixel offset to the top left corner. Only valid if bFloatingPointWindowValidity = TRUE"] + pub dfXOff: f64, + #[doc = " Line offset to the top left corner. Only valid if bFloatingPointWindowValidity = TRUE"] + pub dfYOff: f64, + #[doc = " Width in pixels of the area of interest. Only valid if bFloatingPointWindowValidity = TRUE"] + pub dfXSize: f64, + #[doc = " Height in pixels of the area of interest. Only valid if bFloatingPointWindowValidity = TRUE"] + pub dfYSize: f64, +} +#[test] +fn bindgen_test_layout_GDALRasterIOExtraArg() { + assert_eq!( + ::std::mem::size_of::(), + 64usize, + concat!("Size of: ", stringify!(GDALRasterIOExtraArg)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(GDALRasterIOExtraArg)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nVersion as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(nVersion) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).eResampleAlg as *const _ as usize + }, + 4usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(eResampleAlg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnProgress as *const _ as usize + }, + 8usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(pfnProgress) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pProgressData as *const _ as usize + }, + 16usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(pProgressData) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).bFloatingPointWindowValidity + as *const _ as usize + }, + 24usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(bFloatingPointWindowValidity) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfXOff as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(dfXOff) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfYOff as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(dfYOff) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfXSize as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(dfXSize) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfYSize as *const _ as usize }, + 56usize, + concat!( + "Offset of field: ", + stringify!(GDALRasterIOExtraArg), + "::", + stringify!(dfYSize) + ) + ); +} +pub mod GDALColorInterp { + #[doc = " Types of color interpretation for raster bands."] + pub type Type = u32; + #[doc = " Undefined"] + pub const GCI_Undefined: Type = 0; + #[doc = " Greyscale"] + pub const GCI_GrayIndex: Type = 1; + #[doc = " Paletted (see associated color table)"] + pub const GCI_PaletteIndex: Type = 2; + #[doc = " Red band of RGBA image"] + pub const GCI_RedBand: Type = 3; + #[doc = " Green band of RGBA image"] + pub const GCI_GreenBand: Type = 4; + #[doc = " Blue band of RGBA image"] + pub const GCI_BlueBand: Type = 5; + #[doc = " Alpha (0=transparent, 255=opaque)"] + pub const GCI_AlphaBand: Type = 6; + #[doc = " Hue band of HLS image"] + pub const GCI_HueBand: Type = 7; + #[doc = " Saturation band of HLS image"] + pub const GCI_SaturationBand: Type = 8; + #[doc = " Lightness band of HLS image"] + pub const GCI_LightnessBand: Type = 9; + #[doc = " Cyan band of CMYK image"] + pub const GCI_CyanBand: Type = 10; + #[doc = " Magenta band of CMYK image"] + pub const GCI_MagentaBand: Type = 11; + #[doc = " Yellow band of CMYK image"] + pub const GCI_YellowBand: Type = 12; + #[doc = " Black band of CMLY image"] + pub const GCI_BlackBand: Type = 13; + #[doc = " Y Luminance"] + pub const GCI_YCbCr_YBand: Type = 14; + #[doc = " Cb Chroma"] + pub const GCI_YCbCr_CbBand: Type = 15; + #[doc = " Cr Chroma"] + pub const GCI_YCbCr_CrBand: Type = 16; + #[doc = " Max current value (equals to GCI_YCbCr_CrBand currently)"] + pub const GCI_Max: Type = 16; +} +extern "C" { + pub fn GDALGetColorInterpretationName(arg1: GDALColorInterp::Type) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetColorInterpretationByName(pszName: *const libc::c_char) -> GDALColorInterp::Type; +} +pub mod GDALPaletteInterp { + #[doc = " Types of color interpretations for a GDALColorTable."] + pub type Type = u32; + #[doc = " Grayscale (in GDALColorEntry.c1)"] + pub const GPI_Gray: Type = 0; + #[doc = " Red, Green, Blue and Alpha in (in c1, c2, c3 and c4)"] + pub const GPI_RGB: Type = 1; + #[doc = " Cyan, Magenta, Yellow and Black (in c1, c2, c3 and c4)"] + pub const GPI_CMYK: Type = 2; + #[doc = " Hue, Lightness and Saturation (in c1, c2, and c3)"] + pub const GPI_HLS: Type = 3; +} +extern "C" { + pub fn GDALGetPaletteInterpretationName(arg1: GDALPaletteInterp::Type) -> *const libc::c_char; +} +#[doc = " Opaque type used for the C bindings of the C++ GDALMajorObject class"] +pub type GDALMajorObjectH = *mut libc::c_void; +#[doc = " Opaque type used for the C bindings of the C++ GDALDataset class"] +pub type GDALDatasetH = *mut libc::c_void; +#[doc = " Opaque type used for the C bindings of the C++ GDALRasterBand class"] +pub type GDALRasterBandH = *mut libc::c_void; +#[doc = " Opaque type used for the C bindings of the C++ GDALDriver class"] +pub type GDALDriverH = *mut libc::c_void; +#[doc = " Opaque type used for the C bindings of the C++ GDALColorTable class"] +pub type GDALColorTableH = *mut libc::c_void; +#[doc = " Opaque type used for the C bindings of the C++ GDALRasterAttributeTable class"] +pub type GDALRasterAttributeTableH = *mut libc::c_void; +#[doc = " Opaque type used for the C bindings of the C++ GDALAsyncReader class"] +pub type GDALAsyncReaderH = *mut libc::c_void; +#[doc = " Type to express pixel, line or band spacing. Signed 64 bit integer."] +pub type GSpacing = GIntBig; +extern "C" { + pub fn GDALAllRegister(); +} +extern "C" { + pub fn GDALCreate( + hDriver: GDALDriverH, + arg1: *const libc::c_char, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: GDALDataType::Type, + arg6: CSLConstList, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALCreateCopy( + arg1: GDALDriverH, + arg2: *const libc::c_char, + arg3: GDALDatasetH, + arg4: libc::c_int, + arg5: CSLConstList, + arg6: GDALProgressFunc, + arg7: *mut libc::c_void, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALIdentifyDriver( + pszFilename: *const libc::c_char, + papszFileList: CSLConstList, + ) -> GDALDriverH; +} +extern "C" { + pub fn GDALIdentifyDriverEx( + pszFilename: *const libc::c_char, + nIdentifyFlags: libc::c_uint, + papszAllowedDrivers: *const *const libc::c_char, + papszFileList: *const *const libc::c_char, + ) -> GDALDriverH; +} +extern "C" { + pub fn GDALOpen(pszFilename: *const libc::c_char, eAccess: GDALAccess::Type) -> GDALDatasetH; +} +extern "C" { + pub fn GDALOpenShared(arg1: *const libc::c_char, arg2: GDALAccess::Type) -> GDALDatasetH; +} +extern "C" { + pub fn GDALOpenEx( + pszFilename: *const libc::c_char, + nOpenFlags: libc::c_uint, + papszAllowedDrivers: *const *const libc::c_char, + papszOpenOptions: *const *const libc::c_char, + papszSiblingFiles: *const *const libc::c_char, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALDumpOpenDatasets(arg1: *mut FILE) -> libc::c_int; +} +extern "C" { + pub fn GDALGetDriverByName(arg1: *const libc::c_char) -> GDALDriverH; +} +extern "C" { + pub fn GDALGetDriverCount() -> libc::c_int; +} +extern "C" { + pub fn GDALGetDriver(arg1: libc::c_int) -> GDALDriverH; +} +extern "C" { + pub fn GDALCreateDriver() -> GDALDriverH; +} +extern "C" { + pub fn GDALDestroyDriver(arg1: GDALDriverH); +} +extern "C" { + pub fn GDALRegisterDriver(arg1: GDALDriverH) -> libc::c_int; +} +extern "C" { + pub fn GDALDeregisterDriver(arg1: GDALDriverH); +} +extern "C" { + pub fn GDALDestroyDriverManager(); +} +extern "C" { + pub fn GDALDestroy(); +} +extern "C" { + pub fn GDALDeleteDataset(arg1: GDALDriverH, arg2: *const libc::c_char) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRenameDataset( + arg1: GDALDriverH, + pszNewName: *const libc::c_char, + pszOldName: *const libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALCopyDatasetFiles( + arg1: GDALDriverH, + pszNewName: *const libc::c_char, + pszOldName: *const libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALValidateCreationOptions( + arg1: GDALDriverH, + papszCreationOptions: CSLConstList, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALGetDriverShortName(arg1: GDALDriverH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetDriverLongName(arg1: GDALDriverH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetDriverHelpTopic(arg1: GDALDriverH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetDriverCreationOptionList(arg1: GDALDriverH) -> *const libc::c_char; +} +#[doc = " Ground Control Point"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDAL_GCP { + #[doc = " Unique identifier, often numeric"] + pub pszId: *mut libc::c_char, + #[doc = " Informational message or \"\""] + pub pszInfo: *mut libc::c_char, + #[doc = " Pixel (x) location of GCP on raster"] + pub dfGCPPixel: f64, + #[doc = " Line (y) location of GCP on raster"] + pub dfGCPLine: f64, + #[doc = " X position of GCP in georeferenced space"] + pub dfGCPX: f64, + #[doc = " Y position of GCP in georeferenced space"] + pub dfGCPY: f64, + #[doc = " Elevation of GCP, or zero if not known"] + pub dfGCPZ: f64, +} +#[test] +fn bindgen_test_layout_GDAL_GCP() { + assert_eq!( + ::std::mem::size_of::(), + 56usize, + concat!("Size of: ", stringify!(GDAL_GCP)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(GDAL_GCP)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszId as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(pszId) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszInfo as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(pszInfo) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfGCPPixel as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(dfGCPPixel) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfGCPLine as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(dfGCPLine) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfGCPX as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(dfGCPX) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfGCPY as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(dfGCPY) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfGCPZ as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(GDAL_GCP), + "::", + stringify!(dfGCPZ) + ) + ); +} +extern "C" { + pub fn GDALInitGCPs(arg1: libc::c_int, arg2: *mut GDAL_GCP); +} +extern "C" { + pub fn GDALDeinitGCPs(arg1: libc::c_int, arg2: *mut GDAL_GCP); +} +extern "C" { + pub fn GDALDuplicateGCPs(arg1: libc::c_int, arg2: *const GDAL_GCP) -> *mut GDAL_GCP; +} +extern "C" { + pub fn GDALGCPsToGeoTransform( + nGCPCount: libc::c_int, + pasGCPs: *const GDAL_GCP, + padfGeoTransform: *mut f64, + bApproxOK: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALInvGeoTransform( + padfGeoTransformIn: *mut f64, + padfInvGeoTransformOut: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALApplyGeoTransform( + arg1: *mut f64, + arg2: f64, + arg3: f64, + arg4: *mut f64, + arg5: *mut f64, + ); +} +extern "C" { + pub fn GDALComposeGeoTransforms( + padfGeoTransform1: *const f64, + padfGeoTransform2: *const f64, + padfGeoTransformOut: *mut f64, + ); +} +extern "C" { + pub fn GDALGetMetadataDomainList(hObject: GDALMajorObjectH) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn GDALGetMetadata( + arg1: GDALMajorObjectH, + arg2: *const libc::c_char, + ) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn GDALSetMetadata( + arg1: GDALMajorObjectH, + arg2: CSLConstList, + arg3: *const libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetMetadataItem( + arg1: GDALMajorObjectH, + arg2: *const libc::c_char, + arg3: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn GDALSetMetadataItem( + arg1: GDALMajorObjectH, + arg2: *const libc::c_char, + arg3: *const libc::c_char, + arg4: *const libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetDescription(arg1: GDALMajorObjectH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALSetDescription(arg1: GDALMajorObjectH, arg2: *const libc::c_char); +} +extern "C" { + pub fn GDALGetDatasetDriver(arg1: GDALDatasetH) -> GDALDriverH; +} +extern "C" { + pub fn GDALGetFileList(arg1: GDALDatasetH) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn GDALClose(arg1: GDALDatasetH); +} +extern "C" { + pub fn GDALGetRasterXSize(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetRasterYSize(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetRasterCount(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetRasterBand(arg1: GDALDatasetH, arg2: libc::c_int) -> GDALRasterBandH; +} +extern "C" { + pub fn GDALAddBand( + hDS: GDALDatasetH, + eType: GDALDataType::Type, + papszOptions: CSLConstList, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALBeginAsyncReader( + hDS: GDALDatasetH, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + pBuf: *mut libc::c_void, + nBufXSize: libc::c_int, + nBufYSize: libc::c_int, + eBufType: GDALDataType::Type, + nBandCount: libc::c_int, + panBandMap: *mut libc::c_int, + nPixelSpace: libc::c_int, + nLineSpace: libc::c_int, + nBandSpace: libc::c_int, + papszOptions: CSLConstList, + ) -> GDALAsyncReaderH; +} +extern "C" { + pub fn GDALEndAsyncReader(hDS: GDALDatasetH, hAsynchReaderH: GDALAsyncReaderH); +} +extern "C" { + pub fn GDALDatasetRasterIO( + hDS: GDALDatasetH, + eRWFlag: GDALRWFlag::Type, + nDSXOff: libc::c_int, + nDSYOff: libc::c_int, + nDSXSize: libc::c_int, + nDSYSize: libc::c_int, + pBuffer: *mut libc::c_void, + nBXSize: libc::c_int, + nBYSize: libc::c_int, + eBDataType: GDALDataType::Type, + nBandCount: libc::c_int, + panBandCount: *mut libc::c_int, + nPixelSpace: libc::c_int, + nLineSpace: libc::c_int, + nBandSpace: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALDatasetRasterIOEx( + hDS: GDALDatasetH, + eRWFlag: GDALRWFlag::Type, + nDSXOff: libc::c_int, + nDSYOff: libc::c_int, + nDSXSize: libc::c_int, + nDSYSize: libc::c_int, + pBuffer: *mut libc::c_void, + nBXSize: libc::c_int, + nBYSize: libc::c_int, + eBDataType: GDALDataType::Type, + nBandCount: libc::c_int, + panBandCount: *mut libc::c_int, + nPixelSpace: GSpacing, + nLineSpace: GSpacing, + nBandSpace: GSpacing, + psExtraArg: *mut GDALRasterIOExtraArg, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALDatasetAdviseRead( + hDS: GDALDatasetH, + nDSXOff: libc::c_int, + nDSYOff: libc::c_int, + nDSXSize: libc::c_int, + nDSYSize: libc::c_int, + nBXSize: libc::c_int, + nBYSize: libc::c_int, + eBDataType: GDALDataType::Type, + nBandCount: libc::c_int, + panBandCount: *mut libc::c_int, + papszOptions: CSLConstList, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetProjectionRef(arg1: GDALDatasetH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetSpatialRef(arg1: GDALDatasetH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn GDALSetProjection(arg1: GDALDatasetH, arg2: *const libc::c_char) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSetSpatialRef(arg1: GDALDatasetH, arg2: OGRSpatialReferenceH) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetGeoTransform(arg1: GDALDatasetH, arg2: *mut f64) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSetGeoTransform(arg1: GDALDatasetH, arg2: *mut f64) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetGCPCount(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetGCPProjection(arg1: GDALDatasetH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALGetGCPSpatialRef(arg1: GDALDatasetH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn GDALGetGCPs(arg1: GDALDatasetH) -> *const GDAL_GCP; +} +extern "C" { + pub fn GDALSetGCPs( + arg1: GDALDatasetH, + arg2: libc::c_int, + arg3: *const GDAL_GCP, + arg4: *const libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSetGCPs2( + arg1: GDALDatasetH, + arg2: libc::c_int, + arg3: *const GDAL_GCP, + arg4: OGRSpatialReferenceH, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetInternalHandle( + arg1: GDALDatasetH, + arg2: *const libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALReferenceDataset(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALDereferenceDataset(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALReleaseDataset(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALBuildOverviews( + arg1: GDALDatasetH, + arg2: *const libc::c_char, + arg3: libc::c_int, + arg4: *mut libc::c_int, + arg5: libc::c_int, + arg6: *mut libc::c_int, + arg7: GDALProgressFunc, + arg8: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetOpenDatasets(hDS: *mut *mut GDALDatasetH, pnCount: *mut libc::c_int); +} +extern "C" { + pub fn GDALGetAccess(hDS: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALFlushCache(hDS: GDALDatasetH); +} +extern "C" { + pub fn GDALCreateDatasetMaskBand(hDS: GDALDatasetH, nFlags: libc::c_int) -> CPLErr::Type; +} +extern "C" { + pub fn GDALDatasetCopyWholeRaster( + hSrcDS: GDALDatasetH, + hDstDS: GDALDatasetH, + papszOptions: CSLConstList, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterBandCopyWholeRaster( + hSrcBand: GDALRasterBandH, + hDstBand: GDALRasterBandH, + constpapszOptions: *const *const libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRegenerateOverviews( + hSrcBand: GDALRasterBandH, + nOverviewCount: libc::c_int, + pahOverviewBands: *mut GDALRasterBandH, + pszResampling: *const libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALDatasetGetLayerCount(arg1: GDALDatasetH) -> libc::c_int; +} +extern "C" { + pub fn GDALDatasetGetLayer(arg1: GDALDatasetH, arg2: libc::c_int) -> OGRLayerH; +} +extern "C" { + pub fn GDALDatasetGetLayerByName(arg1: GDALDatasetH, arg2: *const libc::c_char) -> OGRLayerH; +} +extern "C" { + pub fn GDALDatasetDeleteLayer(arg1: GDALDatasetH, arg2: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn GDALDatasetCreateLayer( + arg1: GDALDatasetH, + arg2: *const libc::c_char, + arg3: OGRSpatialReferenceH, + arg4: OGRwkbGeometryType::Type, + arg5: CSLConstList, + ) -> OGRLayerH; +} +extern "C" { + pub fn GDALDatasetCopyLayer( + arg1: GDALDatasetH, + arg2: OGRLayerH, + arg3: *const libc::c_char, + arg4: CSLConstList, + ) -> OGRLayerH; +} +extern "C" { + pub fn GDALDatasetResetReading(arg1: GDALDatasetH); +} +extern "C" { + pub fn GDALDatasetGetNextFeature( + hDS: GDALDatasetH, + phBelongingLayer: *mut OGRLayerH, + pdfProgressPct: *mut f64, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> OGRFeatureH; +} +extern "C" { + pub fn GDALDatasetTestCapability(arg1: GDALDatasetH, arg2: *const libc::c_char) -> libc::c_int; +} +extern "C" { + pub fn GDALDatasetExecuteSQL( + arg1: GDALDatasetH, + arg2: *const libc::c_char, + arg3: OGRGeometryH, + arg4: *const libc::c_char, + ) -> OGRLayerH; +} +extern "C" { + pub fn GDALDatasetReleaseResultSet(arg1: GDALDatasetH, arg2: OGRLayerH); +} +extern "C" { + pub fn GDALDatasetGetStyleTable(arg1: GDALDatasetH) -> OGRStyleTableH; +} +extern "C" { + pub fn GDALDatasetSetStyleTableDirectly(arg1: GDALDatasetH, arg2: OGRStyleTableH); +} +extern "C" { + pub fn GDALDatasetSetStyleTable(arg1: GDALDatasetH, arg2: OGRStyleTableH); +} +extern "C" { + pub fn GDALDatasetStartTransaction(hDS: GDALDatasetH, bForce: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn GDALDatasetCommitTransaction(hDS: GDALDatasetH) -> OGRErr::Type; +} +extern "C" { + pub fn GDALDatasetRollbackTransaction(hDS: GDALDatasetH) -> OGRErr::Type; +} +#[doc = " Type of functions to pass to GDALAddDerivedBandPixelFunc."] +#[doc = " @since GDAL 2.2"] +pub type GDALDerivedPixelFunc = ::std::option::Option< + unsafe extern "C" fn( + papoSources: *mut *mut libc::c_void, + nSources: libc::c_int, + pData: *mut libc::c_void, + nBufXSize: libc::c_int, + nBufYSize: libc::c_int, + eSrcType: GDALDataType::Type, + eBufType: GDALDataType::Type, + nPixelSpace: libc::c_int, + nLineSpace: libc::c_int, + ) -> CPLErr::Type, +>; +extern "C" { + pub fn GDALGetRasterDataType(arg1: GDALRasterBandH) -> GDALDataType::Type; +} +extern "C" { + pub fn GDALGetBlockSize( + arg1: GDALRasterBandH, + pnXSize: *mut libc::c_int, + pnYSize: *mut libc::c_int, + ); +} +extern "C" { + pub fn GDALGetActualBlockSize( + arg1: GDALRasterBandH, + nXBlockOff: libc::c_int, + nYBlockOff: libc::c_int, + pnXValid: *mut libc::c_int, + pnYValid: *mut libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterAdviseRead( + hRB: GDALRasterBandH, + nDSXOff: libc::c_int, + nDSYOff: libc::c_int, + nDSXSize: libc::c_int, + nDSYSize: libc::c_int, + nBXSize: libc::c_int, + nBYSize: libc::c_int, + eBDataType: GDALDataType::Type, + papszOptions: CSLConstList, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterIO( + hRBand: GDALRasterBandH, + eRWFlag: GDALRWFlag::Type, + nDSXOff: libc::c_int, + nDSYOff: libc::c_int, + nDSXSize: libc::c_int, + nDSYSize: libc::c_int, + pBuffer: *mut libc::c_void, + nBXSize: libc::c_int, + nBYSize: libc::c_int, + eBDataType: GDALDataType::Type, + nPixelSpace: libc::c_int, + nLineSpace: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterIOEx( + hRBand: GDALRasterBandH, + eRWFlag: GDALRWFlag::Type, + nDSXOff: libc::c_int, + nDSYOff: libc::c_int, + nDSXSize: libc::c_int, + nDSYSize: libc::c_int, + pBuffer: *mut libc::c_void, + nBXSize: libc::c_int, + nBYSize: libc::c_int, + eBDataType: GDALDataType::Type, + nPixelSpace: GSpacing, + nLineSpace: GSpacing, + psExtraArg: *mut GDALRasterIOExtraArg, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALReadBlock( + arg1: GDALRasterBandH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWriteBlock( + arg1: GDALRasterBandH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterBandXSize(arg1: GDALRasterBandH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetRasterBandYSize(arg1: GDALRasterBandH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetRasterAccess(arg1: GDALRasterBandH) -> GDALAccess::Type; +} +extern "C" { + pub fn GDALGetBandNumber(arg1: GDALRasterBandH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetBandDataset(arg1: GDALRasterBandH) -> GDALDatasetH; +} +extern "C" { + pub fn GDALGetRasterColorInterpretation(arg1: GDALRasterBandH) -> GDALColorInterp::Type; +} +extern "C" { + pub fn GDALSetRasterColorInterpretation( + arg1: GDALRasterBandH, + arg2: GDALColorInterp::Type, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterColorTable(arg1: GDALRasterBandH) -> GDALColorTableH; +} +extern "C" { + pub fn GDALSetRasterColorTable(arg1: GDALRasterBandH, arg2: GDALColorTableH) -> CPLErr::Type; +} +extern "C" { + pub fn GDALHasArbitraryOverviews(arg1: GDALRasterBandH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetOverviewCount(arg1: GDALRasterBandH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetOverview(arg1: GDALRasterBandH, arg2: libc::c_int) -> GDALRasterBandH; +} +extern "C" { + pub fn GDALGetRasterNoDataValue(arg1: GDALRasterBandH, arg2: *mut libc::c_int) -> f64; +} +extern "C" { + pub fn GDALSetRasterNoDataValue(arg1: GDALRasterBandH, arg2: f64) -> CPLErr::Type; +} +extern "C" { + pub fn GDALDeleteRasterNoDataValue(arg1: GDALRasterBandH) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterCategoryNames(arg1: GDALRasterBandH) -> *mut *mut libc::c_char; +} +extern "C" { + pub fn GDALSetRasterCategoryNames(arg1: GDALRasterBandH, arg2: CSLConstList) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterMinimum(arg1: GDALRasterBandH, pbSuccess: *mut libc::c_int) -> f64; +} +extern "C" { + pub fn GDALGetRasterMaximum(arg1: GDALRasterBandH, pbSuccess: *mut libc::c_int) -> f64; +} +extern "C" { + pub fn GDALGetRasterStatistics( + arg1: GDALRasterBandH, + bApproxOK: libc::c_int, + bForce: libc::c_int, + pdfMin: *mut f64, + pdfMax: *mut f64, + pdfMean: *mut f64, + pdfStdDev: *mut f64, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALComputeRasterStatistics( + arg1: GDALRasterBandH, + bApproxOK: libc::c_int, + pdfMin: *mut f64, + pdfMax: *mut f64, + pdfMean: *mut f64, + pdfStdDev: *mut f64, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSetRasterStatistics( + hBand: GDALRasterBandH, + dfMin: f64, + dfMax: f64, + dfMean: f64, + dfStdDev: f64, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterUnitType(arg1: GDALRasterBandH) -> *const libc::c_char; +} +extern "C" { + pub fn GDALSetRasterUnitType( + hBand: GDALRasterBandH, + pszNewValue: *const libc::c_char, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterOffset(arg1: GDALRasterBandH, pbSuccess: *mut libc::c_int) -> f64; +} +extern "C" { + pub fn GDALSetRasterOffset(hBand: GDALRasterBandH, dfNewOffset: f64) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterScale(arg1: GDALRasterBandH, pbSuccess: *mut libc::c_int) -> f64; +} +extern "C" { + pub fn GDALSetRasterScale(hBand: GDALRasterBandH, dfNewOffset: f64) -> CPLErr::Type; +} +extern "C" { + pub fn GDALComputeRasterMinMax( + hBand: GDALRasterBandH, + bApproxOK: libc::c_int, + adfMinMax: *mut f64, + ); +} +extern "C" { + pub fn GDALFlushRasterCache(hBand: GDALRasterBandH) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterHistogram( + hBand: GDALRasterBandH, + dfMin: f64, + dfMax: f64, + nBuckets: libc::c_int, + panHistogram: *mut libc::c_int, + bIncludeOutOfRange: libc::c_int, + bApproxOK: libc::c_int, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRasterHistogramEx( + hBand: GDALRasterBandH, + dfMin: f64, + dfMax: f64, + nBuckets: libc::c_int, + panHistogram: *mut GUIntBig, + bIncludeOutOfRange: libc::c_int, + bApproxOK: libc::c_int, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetDefaultHistogram( + hBand: GDALRasterBandH, + pdfMin: *mut f64, + pdfMax: *mut f64, + pnBuckets: *mut libc::c_int, + ppanHistogram: *mut *mut libc::c_int, + bForce: libc::c_int, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetDefaultHistogramEx( + hBand: GDALRasterBandH, + pdfMin: *mut f64, + pdfMax: *mut f64, + pnBuckets: *mut libc::c_int, + ppanHistogram: *mut *mut GUIntBig, + bForce: libc::c_int, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSetDefaultHistogram( + hBand: GDALRasterBandH, + dfMin: f64, + dfMax: f64, + nBuckets: libc::c_int, + panHistogram: *mut libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSetDefaultHistogramEx( + hBand: GDALRasterBandH, + dfMin: f64, + dfMax: f64, + nBuckets: libc::c_int, + panHistogram: *mut GUIntBig, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetRandomRasterSample( + arg1: GDALRasterBandH, + arg2: libc::c_int, + arg3: *mut f32, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALGetRasterSampleOverview(arg1: GDALRasterBandH, arg2: libc::c_int) + -> GDALRasterBandH; +} +extern "C" { + pub fn GDALGetRasterSampleOverviewEx(arg1: GDALRasterBandH, arg2: GUIntBig) -> GDALRasterBandH; +} +extern "C" { + pub fn GDALFillRaster( + hBand: GDALRasterBandH, + dfRealValue: f64, + dfImaginaryValue: f64, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALComputeBandStats( + hBand: GDALRasterBandH, + nSampleStep: libc::c_int, + pdfMean: *mut f64, + pdfStdDev: *mut f64, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALOverviewMagnitudeCorrection( + hBaseBand: GDALRasterBandH, + nOverviewCount: libc::c_int, + pahOverviews: *mut GDALRasterBandH, + pfnProgress: GDALProgressFunc, + pProgressData: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetDefaultRAT(hBand: GDALRasterBandH) -> GDALRasterAttributeTableH; +} +extern "C" { + pub fn GDALSetDefaultRAT( + arg1: GDALRasterBandH, + arg2: GDALRasterAttributeTableH, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALAddDerivedBandPixelFunc( + pszName: *const libc::c_char, + pfnPixelFunc: GDALDerivedPixelFunc, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetMaskBand(hBand: GDALRasterBandH) -> GDALRasterBandH; +} +extern "C" { + pub fn GDALGetMaskFlags(hBand: GDALRasterBandH) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateMaskBand(hBand: GDALRasterBandH, nFlags: libc::c_int) -> CPLErr::Type; +} +extern "C" { + pub fn GDALGetDataCoverageStatus( + hBand: GDALRasterBandH, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + nMaskFlagStop: libc::c_int, + pdfDataPct: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALARGetNextUpdatedRegion( + hARIO: GDALAsyncReaderH, + dfTimeout: f64, + pnXBufOff: *mut libc::c_int, + pnYBufOff: *mut libc::c_int, + pnXBufSize: *mut libc::c_int, + pnYBufSize: *mut libc::c_int, + ) -> GDALAsyncStatusType::Type; +} +extern "C" { + pub fn GDALARLockBuffer(hARIO: GDALAsyncReaderH, dfTimeout: f64) -> libc::c_int; +} +extern "C" { + pub fn GDALARUnlockBuffer(hARIO: GDALAsyncReaderH); +} +extern "C" { + pub fn GDALGeneralCmdLineProcessor( + nArgc: libc::c_int, + ppapszArgv: *mut *mut *mut libc::c_char, + nOptions: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALSwapWords( + pData: *mut libc::c_void, + nWordSize: libc::c_int, + nWordCount: libc::c_int, + nWordSkip: libc::c_int, + ); +} +extern "C" { + pub fn GDALSwapWordsEx( + pData: *mut libc::c_void, + nWordSize: libc::c_int, + nWordCount: size_t, + nWordSkip: libc::c_int, + ); +} +extern "C" { + pub fn GDALCopyWords( + pSrcData: *const libc::c_void, + eSrcType: GDALDataType::Type, + nSrcPixelOffset: libc::c_int, + pDstData: *mut libc::c_void, + eDstType: GDALDataType::Type, + nDstPixelOffset: libc::c_int, + nWordCount: libc::c_int, + ); +} +extern "C" { + pub fn GDALCopyWords64( + pSrcData: *const libc::c_void, + eSrcType: GDALDataType::Type, + nSrcPixelOffset: libc::c_int, + pDstData: *mut libc::c_void, + eDstType: GDALDataType::Type, + nDstPixelOffset: libc::c_int, + nWordCount: GPtrDiff_t, + ); +} +extern "C" { + pub fn GDALCopyBits( + pabySrcData: *const GByte, + nSrcOffset: libc::c_int, + nSrcStep: libc::c_int, + pabyDstData: *mut GByte, + nDstOffset: libc::c_int, + nDstStep: libc::c_int, + nBitCount: libc::c_int, + nStepCount: libc::c_int, + ); +} +extern "C" { + pub fn GDALLoadWorldFile(arg1: *const libc::c_char, arg2: *mut f64) -> libc::c_int; +} +extern "C" { + pub fn GDALReadWorldFile( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + arg3: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALWriteWorldFile( + arg1: *const libc::c_char, + arg2: *const libc::c_char, + arg3: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALLoadTabFile( + arg1: *const libc::c_char, + arg2: *mut f64, + arg3: *mut *mut libc::c_char, + arg4: *mut libc::c_int, + arg5: *mut *mut GDAL_GCP, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALReadTabFile( + arg1: *const libc::c_char, + arg2: *mut f64, + arg3: *mut *mut libc::c_char, + arg4: *mut libc::c_int, + arg5: *mut *mut GDAL_GCP, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALLoadOziMapFile( + arg1: *const libc::c_char, + arg2: *mut f64, + arg3: *mut *mut libc::c_char, + arg4: *mut libc::c_int, + arg5: *mut *mut GDAL_GCP, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALReadOziMapFile( + arg1: *const libc::c_char, + arg2: *mut f64, + arg3: *mut *mut libc::c_char, + arg4: *mut libc::c_int, + arg5: *mut *mut GDAL_GCP, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALDecToDMS( + arg1: f64, + arg2: *const libc::c_char, + arg3: libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn GDALPackedDMSToDec(arg1: f64) -> f64; +} +extern "C" { + pub fn GDALDecToPackedDMS(arg1: f64) -> f64; +} +#[doc = " Structure to store Rational Polynomial Coefficients / Rigorous Projection"] +#[doc = " Model. See http://geotiff.maptools.org/rpc_prop.html"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALRPCInfo { + #[doc = "< Line offset"] + pub dfLINE_OFF: f64, + #[doc = "< Sample/Pixel offset"] + pub dfSAMP_OFF: f64, + #[doc = "< Latitude offset"] + pub dfLAT_OFF: f64, + #[doc = "< Longitude offset"] + pub dfLONG_OFF: f64, + #[doc = "< Height offset"] + pub dfHEIGHT_OFF: f64, + #[doc = "< Line scale"] + pub dfLINE_SCALE: f64, + #[doc = "< Sample/Pixel scale"] + pub dfSAMP_SCALE: f64, + #[doc = "< Latitude scale"] + pub dfLAT_SCALE: f64, + #[doc = "< Longitude scale"] + pub dfLONG_SCALE: f64, + #[doc = "< Height scale"] + pub dfHEIGHT_SCALE: f64, + #[doc = "< Line Numerator Coefficients"] + pub adfLINE_NUM_COEFF: [f64; 20usize], + #[doc = "< Line Denominator Coefficients"] + pub adfLINE_DEN_COEFF: [f64; 20usize], + #[doc = "< Sample/Pixel Numerator Coefficients"] + pub adfSAMP_NUM_COEFF: [f64; 20usize], + #[doc = "< Sample/Pixel Denominator Coefficients"] + pub adfSAMP_DEN_COEFF: [f64; 20usize], + #[doc = "< Minimum longitude"] + pub dfMIN_LONG: f64, + #[doc = "< Minimum latitude"] + pub dfMIN_LAT: f64, + #[doc = "< Maximum longitude"] + pub dfMAX_LONG: f64, + #[doc = "< Maximum latitude"] + pub dfMAX_LAT: f64, +} +#[test] +fn bindgen_test_layout_GDALRPCInfo() { + assert_eq!( + ::std::mem::size_of::(), + 752usize, + concat!("Size of: ", stringify!(GDALRPCInfo)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(GDALRPCInfo)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfLINE_OFF as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfLINE_OFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfSAMP_OFF as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfSAMP_OFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfLAT_OFF as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfLAT_OFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfLONG_OFF as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfLONG_OFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfHEIGHT_OFF as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfHEIGHT_OFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfLINE_SCALE as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfLINE_SCALE) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfSAMP_SCALE as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfSAMP_SCALE) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfLAT_SCALE as *const _ as usize }, + 56usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfLAT_SCALE) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfLONG_SCALE as *const _ as usize }, + 64usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfLONG_SCALE) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfHEIGHT_SCALE as *const _ as usize }, + 72usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfHEIGHT_SCALE) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).adfLINE_NUM_COEFF as *const _ as usize }, + 80usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(adfLINE_NUM_COEFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).adfLINE_DEN_COEFF as *const _ as usize }, + 240usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(adfLINE_DEN_COEFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).adfSAMP_NUM_COEFF as *const _ as usize }, + 400usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(adfSAMP_NUM_COEFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).adfSAMP_DEN_COEFF as *const _ as usize }, + 560usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(adfSAMP_DEN_COEFF) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfMIN_LONG as *const _ as usize }, + 720usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfMIN_LONG) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfMIN_LAT as *const _ as usize }, + 728usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfMIN_LAT) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfMAX_LONG as *const _ as usize }, + 736usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfMAX_LONG) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfMAX_LAT as *const _ as usize }, + 744usize, + concat!( + "Offset of field: ", + stringify!(GDALRPCInfo), + "::", + stringify!(dfMAX_LAT) + ) + ); +} +extern "C" { + pub fn GDALExtractRPCInfo(arg1: CSLConstList, arg2: *mut GDALRPCInfo) -> libc::c_int; +} +#[doc = " Color tuple"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALColorEntry { + #[doc = " gray, red, cyan or hue"] + pub c1: libc::c_short, + #[doc = " green, magenta, or lightness"] + pub c2: libc::c_short, + #[doc = " blue, yellow, or saturation"] + pub c3: libc::c_short, + #[doc = " alpha or blackband"] + pub c4: libc::c_short, +} +#[test] +fn bindgen_test_layout_GDALColorEntry() { + assert_eq!( + ::std::mem::size_of::(), + 8usize, + concat!("Size of: ", stringify!(GDALColorEntry)) + ); + assert_eq!( + ::std::mem::align_of::(), + 2usize, + concat!("Alignment of ", stringify!(GDALColorEntry)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).c1 as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALColorEntry), + "::", + stringify!(c1) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).c2 as *const _ as usize }, + 2usize, + concat!( + "Offset of field: ", + stringify!(GDALColorEntry), + "::", + stringify!(c2) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).c3 as *const _ as usize }, + 4usize, + concat!( + "Offset of field: ", + stringify!(GDALColorEntry), + "::", + stringify!(c3) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).c4 as *const _ as usize }, + 6usize, + concat!( + "Offset of field: ", + stringify!(GDALColorEntry), + "::", + stringify!(c4) + ) + ); +} +extern "C" { + pub fn GDALCreateColorTable(arg1: GDALPaletteInterp::Type) -> GDALColorTableH; +} +extern "C" { + pub fn GDALDestroyColorTable(arg1: GDALColorTableH); +} +extern "C" { + pub fn GDALCloneColorTable(arg1: GDALColorTableH) -> GDALColorTableH; +} +extern "C" { + pub fn GDALGetPaletteInterpretation(arg1: GDALColorTableH) -> GDALPaletteInterp::Type; +} +extern "C" { + pub fn GDALGetColorEntryCount(arg1: GDALColorTableH) -> libc::c_int; +} +extern "C" { + pub fn GDALGetColorEntry(arg1: GDALColorTableH, arg2: libc::c_int) -> *const GDALColorEntry; +} +extern "C" { + pub fn GDALGetColorEntryAsRGB( + arg1: GDALColorTableH, + arg2: libc::c_int, + arg3: *mut GDALColorEntry, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALSetColorEntry(arg1: GDALColorTableH, arg2: libc::c_int, arg3: *const GDALColorEntry); +} +extern "C" { + pub fn GDALCreateColorRamp( + hTable: GDALColorTableH, + nStartIndex: libc::c_int, + psStartColor: *const GDALColorEntry, + nEndIndex: libc::c_int, + psEndColor: *const GDALColorEntry, + ); +} +pub mod GDALRATFieldType { + #[doc = " Field type of raster attribute table"] + pub type Type = u32; + #[doc = " Integer field"] + pub const GFT_Integer: Type = 0; + #[doc = " Floating point (double) field"] + pub const GFT_Real: Type = 1; + #[doc = " String field"] + pub const GFT_String: Type = 2; +} +pub mod GDALRATFieldUsage { + #[doc = " Field usage of raster attribute table"] + pub type Type = u32; + #[doc = " General purpose field."] + pub const GFU_Generic: Type = 0; + #[doc = " Histogram pixel count"] + pub const GFU_PixelCount: Type = 1; + #[doc = " Class name"] + pub const GFU_Name: Type = 2; + #[doc = " Class range minimum"] + pub const GFU_Min: Type = 3; + #[doc = " Class range maximum"] + pub const GFU_Max: Type = 4; + #[doc = " Class value (min=max)"] + pub const GFU_MinMax: Type = 5; + #[doc = " Red class color (0-255)"] + pub const GFU_Red: Type = 6; + #[doc = " Green class color (0-255)"] + pub const GFU_Green: Type = 7; + #[doc = " Blue class color (0-255)"] + pub const GFU_Blue: Type = 8; + #[doc = " Alpha (0=transparent,255=opaque)"] + pub const GFU_Alpha: Type = 9; + #[doc = " Color Range Red Minimum"] + pub const GFU_RedMin: Type = 10; + #[doc = " Color Range Green Minimum"] + pub const GFU_GreenMin: Type = 11; + #[doc = " Color Range Blue Minimum"] + pub const GFU_BlueMin: Type = 12; + #[doc = " Color Range Alpha Minimum"] + pub const GFU_AlphaMin: Type = 13; + #[doc = " Color Range Red Maximum"] + pub const GFU_RedMax: Type = 14; + #[doc = " Color Range Green Maximum"] + pub const GFU_GreenMax: Type = 15; + #[doc = " Color Range Blue Maximum"] + pub const GFU_BlueMax: Type = 16; + #[doc = " Color Range Alpha Maximum"] + pub const GFU_AlphaMax: Type = 17; + #[doc = " Maximum GFU value (equals to GFU_AlphaMax+1 currently)"] + pub const GFU_MaxCount: Type = 18; +} +pub mod GDALRATTableType { + #[doc = " RAT table type (thematic or athematic)"] + #[doc = " @since GDAL 2.4"] + pub type Type = u32; + #[doc = " Thematic table type"] + pub const GRTT_THEMATIC: Type = 0; + #[doc = " Athematic table type"] + pub const GRTT_ATHEMATIC: Type = 1; +} +extern "C" { + pub fn GDALCreateRasterAttributeTable() -> GDALRasterAttributeTableH; +} +extern "C" { + pub fn GDALDestroyRasterAttributeTable(arg1: GDALRasterAttributeTableH); +} +extern "C" { + pub fn GDALRATGetColumnCount(arg1: GDALRasterAttributeTableH) -> libc::c_int; +} +extern "C" { + pub fn GDALRATGetNameOfCol( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn GDALRATGetUsageOfCol( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + ) -> GDALRATFieldUsage::Type; +} +extern "C" { + pub fn GDALRATGetTypeOfCol( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + ) -> GDALRATFieldType::Type; +} +extern "C" { + pub fn GDALRATGetColOfUsage( + arg1: GDALRasterAttributeTableH, + arg2: GDALRATFieldUsage::Type, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALRATGetRowCount(arg1: GDALRasterAttributeTableH) -> libc::c_int; +} +extern "C" { + pub fn GDALRATGetValueAsString( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + arg3: libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn GDALRATGetValueAsInt( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + arg3: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALRATGetValueAsDouble( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + arg3: libc::c_int, + ) -> f64; +} +extern "C" { + pub fn GDALRATSetValueAsString( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: *const libc::c_char, + ); +} +extern "C" { + pub fn GDALRATSetValueAsInt( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + ); +} +extern "C" { + pub fn GDALRATSetValueAsDouble( + arg1: GDALRasterAttributeTableH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: f64, + ); +} +extern "C" { + pub fn GDALRATChangesAreWrittenToFile(hRAT: GDALRasterAttributeTableH) -> libc::c_int; +} +extern "C" { + pub fn GDALRATValuesIOAsDouble( + hRAT: GDALRasterAttributeTableH, + eRWFlag: GDALRWFlag::Type, + iField: libc::c_int, + iStartRow: libc::c_int, + iLength: libc::c_int, + pdfData: *mut f64, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATValuesIOAsInteger( + hRAT: GDALRasterAttributeTableH, + eRWFlag: GDALRWFlag::Type, + iField: libc::c_int, + iStartRow: libc::c_int, + iLength: libc::c_int, + pnData: *mut libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATValuesIOAsString( + hRAT: GDALRasterAttributeTableH, + eRWFlag: GDALRWFlag::Type, + iField: libc::c_int, + iStartRow: libc::c_int, + iLength: libc::c_int, + papszStrList: CSLConstList, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATSetRowCount(arg1: GDALRasterAttributeTableH, arg2: libc::c_int); +} +extern "C" { + pub fn GDALRATCreateColumn( + arg1: GDALRasterAttributeTableH, + arg2: *const libc::c_char, + arg3: GDALRATFieldType::Type, + arg4: GDALRATFieldUsage::Type, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATSetLinearBinning( + arg1: GDALRasterAttributeTableH, + arg2: f64, + arg3: f64, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATGetLinearBinning( + arg1: GDALRasterAttributeTableH, + arg2: *mut f64, + arg3: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALRATSetTableType( + hRAT: GDALRasterAttributeTableH, + eInTableType: GDALRATTableType::Type, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATGetTableType(hRAT: GDALRasterAttributeTableH) -> GDALRATTableType::Type; +} +extern "C" { + pub fn GDALRATInitializeFromColorTable( + arg1: GDALRasterAttributeTableH, + arg2: GDALColorTableH, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRATTranslateToColorTable( + arg1: GDALRasterAttributeTableH, + nEntryCount: libc::c_int, + ) -> GDALColorTableH; +} +extern "C" { + pub fn GDALRATDumpReadable(arg1: GDALRasterAttributeTableH, arg2: *mut FILE); +} +extern "C" { + pub fn GDALRATClone(arg1: GDALRasterAttributeTableH) -> GDALRasterAttributeTableH; +} +extern "C" { + pub fn GDALRATSerializeJSON(arg1: GDALRasterAttributeTableH) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALRATGetRowOfValue(arg1: GDALRasterAttributeTableH, arg2: f64) -> libc::c_int; +} +extern "C" { + pub fn GDALRATRemoveStatistics(arg1: GDALRasterAttributeTableH); +} +extern "C" { + pub fn GDALSetCacheMax(nBytes: libc::c_int); +} +extern "C" { + pub fn GDALGetCacheMax() -> libc::c_int; +} +extern "C" { + pub fn GDALGetCacheUsed() -> libc::c_int; +} +extern "C" { + pub fn GDALSetCacheMax64(nBytes: GIntBig); +} +extern "C" { + pub fn GDALGetCacheMax64() -> GIntBig; +} +extern "C" { + pub fn GDALGetCacheUsed64() -> GIntBig; +} +extern "C" { + pub fn GDALFlushCacheBlock() -> libc::c_int; +} +extern "C" { + pub fn GDALDatasetGetVirtualMem( + hDS: GDALDatasetH, + eRWFlag: GDALRWFlag::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + nBufXSize: libc::c_int, + nBufYSize: libc::c_int, + eBufType: GDALDataType::Type, + nBandCount: libc::c_int, + panBandMap: *mut libc::c_int, + nPixelSpace: libc::c_int, + nLineSpace: GIntBig, + nBandSpace: GIntBig, + nCacheSize: size_t, + nPageSizeHint: size_t, + bSingleThreadUsage: libc::c_int, + papszOptions: CSLConstList, + ) -> *mut CPLVirtualMem; +} +extern "C" { + pub fn GDALRasterBandGetVirtualMem( + hBand: GDALRasterBandH, + eRWFlag: GDALRWFlag::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + nBufXSize: libc::c_int, + nBufYSize: libc::c_int, + eBufType: GDALDataType::Type, + nPixelSpace: libc::c_int, + nLineSpace: GIntBig, + nCacheSize: size_t, + nPageSizeHint: size_t, + bSingleThreadUsage: libc::c_int, + papszOptions: CSLConstList, + ) -> *mut CPLVirtualMem; +} +extern "C" { + pub fn GDALGetVirtualMemAuto( + hBand: GDALRasterBandH, + eRWFlag: GDALRWFlag::Type, + pnPixelSpace: *mut libc::c_int, + pnLineSpace: *mut GIntBig, + papszOptions: CSLConstList, + ) -> *mut CPLVirtualMem; +} +pub mod GDALTileOrganization { + #[doc = " Enumeration to describe the tile organization"] + pub type Type = u32; + #[doc = " Tile Interleaved by Pixel: tile (0,0) with internal band interleaved by pixel organization, tile (1, 0), ..."] + pub const GTO_TIP: Type = 0; + #[doc = " Band Interleaved by Tile : tile (0,0) of first band, tile (0,0) of second band, ... tile (1,0) of first band, tile (1,0) of second band, ..."] + pub const GTO_BIT: Type = 1; + #[doc = " Band SeQuential : all the tiles of first band, all the tiles of following band..."] + pub const GTO_BSQ: Type = 2; +} +extern "C" { + pub fn GDALDatasetGetTiledVirtualMem( + hDS: GDALDatasetH, + eRWFlag: GDALRWFlag::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + nTileXSize: libc::c_int, + nTileYSize: libc::c_int, + eBufType: GDALDataType::Type, + nBandCount: libc::c_int, + panBandMap: *mut libc::c_int, + eTileOrganization: GDALTileOrganization::Type, + nCacheSize: size_t, + bSingleThreadUsage: libc::c_int, + papszOptions: CSLConstList, + ) -> *mut CPLVirtualMem; +} +extern "C" { + pub fn GDALRasterBandGetTiledVirtualMem( + hBand: GDALRasterBandH, + eRWFlag: GDALRWFlag::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + nTileXSize: libc::c_int, + nTileYSize: libc::c_int, + eBufType: GDALDataType::Type, + nCacheSize: size_t, + bSingleThreadUsage: libc::c_int, + papszOptions: CSLConstList, + ) -> *mut CPLVirtualMem; +} +extern "C" { + pub fn GDALCreatePansharpenedVRT( + pszXML: *const libc::c_char, + hPanchroBand: GDALRasterBandH, + nInputSpectralBands: libc::c_int, + pahInputSpectralBands: *mut GDALRasterBandH, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALGetJPEG2000Structure( + pszFilename: *const libc::c_char, + papszOptions: CSLConstList, + ) -> *mut CPLXMLNode; +} +extern "C" { + pub fn GDALComputeMedianCutPCT( + hRed: GDALRasterBandH, + hGreen: GDALRasterBandH, + hBlue: GDALRasterBandH, + pfnIncludePixel: ::std::option::Option< + unsafe extern "C" fn( + arg1: libc::c_int, + arg2: libc::c_int, + arg3: *mut libc::c_void, + ) -> libc::c_int, + >, + nColors: libc::c_int, + hColorTable: GDALColorTableH, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALDitherRGB2PCT( + hRed: GDALRasterBandH, + hGreen: GDALRasterBandH, + hBlue: GDALRasterBandH, + hTarget: GDALRasterBandH, + hColorTable: GDALColorTableH, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALChecksumImage( + hBand: GDALRasterBandH, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALComputeProximity( + hSrcBand: GDALRasterBandH, + hProximityBand: GDALRasterBandH, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALFillNodata( + hTargetBand: GDALRasterBandH, + hMaskBand: GDALRasterBandH, + dfMaxSearchDist: f64, + bDeprecatedOption: libc::c_int, + nSmoothingIterations: libc::c_int, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALPolygonize( + hSrcBand: GDALRasterBandH, + hMaskBand: GDALRasterBandH, + hOutLayer: OGRLayerH, + iPixValField: libc::c_int, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALFPolygonize( + hSrcBand: GDALRasterBandH, + hMaskBand: GDALRasterBandH, + hOutLayer: OGRLayerH, + iPixValField: libc::c_int, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSieveFilter( + hSrcBand: GDALRasterBandH, + hMaskBand: GDALRasterBandH, + hDstBand: GDALRasterBandH, + nSizeThreshold: libc::c_int, + nConnectedness: libc::c_int, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +pub type GDALTransformerFunc = ::std::option::Option< + unsafe extern "C" fn( + pTransformerArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int, +>; +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn GDALDestroyTransformer(pTransformerArg: *mut libc::c_void); +} +extern "C" { + pub fn GDALUseTransformer( + pTransformerArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateSimilarTransformer( + psTransformerArg: *mut libc::c_void, + dfSrcRatioX: f64, + dfSrcRatioY: f64, + ) -> *mut libc::c_void; +} +extern "C" { + #[doc = " @endcond"] + pub fn GDALCreateGenImgProjTransformer( + hSrcDS: GDALDatasetH, + pszSrcWKT: *const libc::c_char, + hDstDS: GDALDatasetH, + pszDstWKT: *const libc::c_char, + bGCPUseOK: libc::c_int, + dfGCPErrorThreshold: f64, + nOrder: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALCreateGenImgProjTransformer2( + hSrcDS: GDALDatasetH, + hDstDS: GDALDatasetH, + papszOptions: *mut *mut libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALCreateGenImgProjTransformer3( + pszSrcWKT: *const libc::c_char, + padfSrcGeoTransform: *const f64, + pszDstWKT: *const libc::c_char, + padfDstGeoTransform: *const f64, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALCreateGenImgProjTransformer4( + hSrcSRS: OGRSpatialReferenceH, + padfSrcGeoTransform: *const f64, + hDstSRS: OGRSpatialReferenceH, + padfDstGeoTransform: *const f64, + papszOptions: *const *const libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALSetGenImgProjTransformerDstGeoTransform(arg1: *mut libc::c_void, arg2: *const f64); +} +extern "C" { + pub fn GDALDestroyGenImgProjTransformer(arg1: *mut libc::c_void); +} +extern "C" { + pub fn GDALGenImgProjTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALSetTransformerDstGeoTransform(arg1: *mut libc::c_void, arg2: *const f64); +} +extern "C" { + pub fn GDALGetTransformerDstGeoTransform(arg1: *mut libc::c_void, arg2: *mut f64); +} +extern "C" { + pub fn GDALCreateReprojectionTransformer( + pszSrcWKT: *const libc::c_char, + pszDstWKT: *const libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALCreateReprojectionTransformerEx( + hSrcSRS: OGRSpatialReferenceH, + hDstSRS: OGRSpatialReferenceH, + papszOptions: *const *const libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALDestroyReprojectionTransformer(arg1: *mut libc::c_void); +} +extern "C" { + pub fn GDALReprojectionTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateGCPTransformer( + nGCPCount: libc::c_int, + pasGCPList: *const GDAL_GCP, + nReqOrder: libc::c_int, + bReversed: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALCreateGCPRefineTransformer( + nGCPCount: libc::c_int, + pasGCPList: *const GDAL_GCP, + nReqOrder: libc::c_int, + bReversed: libc::c_int, + tolerance: f64, + minimumGcps: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALDestroyGCPTransformer(pTransformArg: *mut libc::c_void); +} +extern "C" { + pub fn GDALGCPTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateTPSTransformer( + nGCPCount: libc::c_int, + pasGCPList: *const GDAL_GCP, + bReversed: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALDestroyTPSTransformer(pTransformArg: *mut libc::c_void); +} +extern "C" { + pub fn GDALTPSTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + #[doc = " @endcond"] + pub fn GDALCreateRPCTransformer( + psRPC: *mut GDALRPCInfo, + bReversed: libc::c_int, + dfPixErrThreshold: f64, + papszOptions: *mut *mut libc::c_char, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALDestroyRPCTransformer(pTransformArg: *mut libc::c_void); +} +extern "C" { + pub fn GDALRPCTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateGeoLocTransformer( + hBaseDS: GDALDatasetH, + papszGeolocationInfo: *mut *mut libc::c_char, + bReversed: libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALDestroyGeoLocTransformer(pTransformArg: *mut libc::c_void); +} +extern "C" { + pub fn GDALGeoLocTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALCreateApproxTransformer( + pfnRawTransformer: GDALTransformerFunc, + pRawTransformerArg: *mut libc::c_void, + dfMaxError: f64, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn GDALApproxTransformerOwnsSubtransformer( + pCBData: *mut libc::c_void, + bOwnFlag: libc::c_int, + ); +} +extern "C" { + pub fn GDALDestroyApproxTransformer(pApproxArg: *mut libc::c_void); +} +extern "C" { + pub fn GDALApproxTransform( + pTransformArg: *mut libc::c_void, + bDstToSrc: libc::c_int, + nPointCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + panSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALSimpleImageWarp( + hSrcDS: GDALDatasetH, + hDstDS: GDALDatasetH, + nBandCount: libc::c_int, + panBandList: *mut libc::c_int, + pfnTransform: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + papszWarpOptions: *mut *mut libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALSuggestedWarpOutput( + hSrcDS: GDALDatasetH, + pfnTransformer: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + padfGeoTransformOut: *mut f64, + pnPixels: *mut libc::c_int, + pnLines: *mut libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALSuggestedWarpOutput2( + hSrcDS: GDALDatasetH, + pfnTransformer: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + padfGeoTransformOut: *mut f64, + pnPixels: *mut libc::c_int, + pnLines: *mut libc::c_int, + padfExtents: *mut f64, + nOptions: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn GDALSerializeTransformer( + pfnFunc: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + ) -> *mut CPLXMLNode; +} +extern "C" { + pub fn GDALDeserializeTransformer( + psTree: *mut CPLXMLNode, + ppfnFunc: *mut GDALTransformerFunc, + ppTransformArg: *mut *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + #[doc = " @endcond"] + pub fn GDALTransformGeolocations( + hXBand: GDALRasterBandH, + hYBand: GDALRasterBandH, + hZBand: GDALRasterBandH, + pfnTransformer: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + papszOptions: *mut *mut libc::c_char, + ) -> CPLErr::Type; +} +#[doc = " Contour writer callback type"] +pub type GDALContourWriter = ::std::option::Option< + unsafe extern "C" fn( + dfLevel: f64, + nPoints: libc::c_int, + padfX: *mut f64, + padfY: *mut f64, + arg1: *mut libc::c_void, + ) -> CPLErr::Type, +>; +#[doc = " Contour generator opaque type"] +pub type GDALContourGeneratorH = *mut libc::c_void; +extern "C" { + pub fn GDAL_CG_Create( + nWidth: libc::c_int, + nHeight: libc::c_int, + bNoDataSet: libc::c_int, + dfNoDataValue: f64, + dfContourInterval: f64, + dfContourBase: f64, + pfnWriter: GDALContourWriter, + pCBData: *mut libc::c_void, + ) -> GDALContourGeneratorH; +} +extern "C" { + pub fn GDAL_CG_FeedLine(hCG: GDALContourGeneratorH, padfScanline: *mut f64) -> CPLErr::Type; +} +extern "C" { + pub fn GDAL_CG_Destroy(hCG: GDALContourGeneratorH); +} +extern "C" { + pub fn OGRContourWriter( + arg1: f64, + arg2: libc::c_int, + arg3: *mut f64, + arg4: *mut f64, + pInfo: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + #[doc = " @endcond"] + pub fn GDALContourGenerate( + hBand: GDALRasterBandH, + dfContourInterval: f64, + dfContourBase: f64, + nFixedLevelCount: libc::c_int, + padfFixedLevels: *mut f64, + bUseNoData: libc::c_int, + dfNoDataValue: f64, + hLayer: *mut libc::c_void, + iIDField: libc::c_int, + iElevField: libc::c_int, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALContourGenerateEx( + hBand: GDALRasterBandH, + hLayer: *mut libc::c_void, + options: CSLConstList, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterizeGeometries( + hDS: GDALDatasetH, + nBandCount: libc::c_int, + panBandList: *mut libc::c_int, + nGeomCount: libc::c_int, + pahGeometries: *mut OGRGeometryH, + pfnTransformer: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + padfGeomBurnValue: *mut f64, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterizeLayers( + hDS: GDALDatasetH, + nBandCount: libc::c_int, + panBandList: *mut libc::c_int, + nLayerCount: libc::c_int, + pahLayers: *mut OGRLayerH, + pfnTransformer: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + padfLayerBurnValues: *mut f64, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALRasterizeLayersBuf( + pData: *mut libc::c_void, + nBufXSize: libc::c_int, + nBufYSize: libc::c_int, + eBufType: GDALDataType::Type, + nPixelSpace: libc::c_int, + nLineSpace: libc::c_int, + nLayerCount: libc::c_int, + pahLayers: *mut OGRLayerH, + pszDstProjection: *const libc::c_char, + padfDstGeoTransform: *mut f64, + pfnTransformer: GDALTransformerFunc, + pTransformArg: *mut libc::c_void, + dfBurnValue: f64, + papszOptions: *mut *mut libc::c_char, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +pub mod GDALGridAlgorithm { + #[doc = " Gridding Algorithms"] + pub type Type = u32; + #[doc = " Inverse distance to a power"] + pub const GGA_InverseDistanceToAPower: Type = 1; + #[doc = " Moving Average"] + pub const GGA_MovingAverage: Type = 2; + #[doc = " Nearest Neighbor"] + pub const GGA_NearestNeighbor: Type = 3; + #[doc = " Minimum Value (Data Metric)"] + pub const GGA_MetricMinimum: Type = 4; + #[doc = " Maximum Value (Data Metric)"] + pub const GGA_MetricMaximum: Type = 5; + #[doc = " Data Range (Data Metric)"] + pub const GGA_MetricRange: Type = 6; + #[doc = " Number of Points (Data Metric)"] + pub const GGA_MetricCount: Type = 7; + #[doc = " Average Distance (Data Metric)"] + pub const GGA_MetricAverageDistance: Type = 8; + #[doc = " Average Distance Between Data Points (Data Metric)"] + pub const GGA_MetricAverageDistancePts: Type = 9; + #[doc = " Linear interpolation (from Delaunay triangulation. Since GDAL 2.1"] + pub const GGA_Linear: Type = 10; + #[doc = " Inverse distance to a power with nearest neighbor search for max points"] + pub const GGA_InverseDistanceToAPowerNearestNeighbor: Type = 11; +} +extern "C" { + pub fn GDALGridCreate( + arg1: GDALGridAlgorithm::Type, + arg2: *const libc::c_void, + arg3: GUInt32, + arg4: *const f64, + arg5: *const f64, + arg6: *const f64, + arg7: f64, + arg8: f64, + arg9: f64, + arg10: f64, + arg11: GUInt32, + arg12: GUInt32, + arg13: GDALDataType::Type, + arg14: *mut libc::c_void, + arg15: GDALProgressFunc, + arg16: *mut libc::c_void, + ) -> CPLErr::Type; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALGridContext { + _unused: [u8; 0], +} +extern "C" { + pub fn GDALGridContextCreate( + eAlgorithm: GDALGridAlgorithm::Type, + poOptions: *const libc::c_void, + nPoints: GUInt32, + padfX: *const f64, + padfY: *const f64, + padfZ: *const f64, + bCallerWillKeepPointArraysAlive: libc::c_int, + ) -> *mut GDALGridContext; +} +extern "C" { + pub fn GDALGridContextFree(psContext: *mut GDALGridContext); +} +extern "C" { + pub fn GDALGridContextProcess( + psContext: *mut GDALGridContext, + dfXMin: f64, + dfXMax: f64, + dfYMin: f64, + dfYMax: f64, + nXSize: GUInt32, + nYSize: GUInt32, + eType: GDALDataType::Type, + pData: *mut libc::c_void, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALComputeMatchingPoints( + hFirstImage: GDALDatasetH, + hSecondImage: GDALDatasetH, + papszOptions: *mut *mut libc::c_char, + pnGCPCount: *mut libc::c_int, + ) -> *mut GDAL_GCP; +} +#[doc = " Triangle fact"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALTriFacet { + #[doc = "< index to the padfX/padfY arrays"] + pub anVertexIdx: [libc::c_int; 3usize], + #[doc = "< index to GDALDelaunayTriangulation.pasFacets, or -1"] + pub anNeighborIdx: [libc::c_int; 3usize], +} +#[test] +fn bindgen_test_layout_GDALTriFacet() { + assert_eq!( + ::std::mem::size_of::(), + 24usize, + concat!("Size of: ", stringify!(GDALTriFacet)) + ); + assert_eq!( + ::std::mem::align_of::(), + 4usize, + concat!("Alignment of ", stringify!(GDALTriFacet)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).anVertexIdx as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALTriFacet), + "::", + stringify!(anVertexIdx) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).anNeighborIdx as *const _ as usize }, + 12usize, + concat!( + "Offset of field: ", + stringify!(GDALTriFacet), + "::", + stringify!(anNeighborIdx) + ) + ); +} +#[doc = " Triangle barycentric coefficients."] +#[doc = ""] +#[doc = " Conversion from cartesian (x,y) to barycentric (l1,l2,l3) with :"] +#[doc = " l1 = dfMul1X * (x - dfCxtX) + dfMul1Y * (y - dfCstY)"] +#[doc = " l2 = dfMul2X * (x - dfCxtX) + dfMul2Y * (y - dfCstY)"] +#[doc = " l3 = 1 - l1 - l2"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALTriBarycentricCoefficients { + #[doc = "< dfMul1X"] + pub dfMul1X: f64, + #[doc = "< dfMul1Y"] + pub dfMul1Y: f64, + #[doc = "< dfMul2X"] + pub dfMul2X: f64, + #[doc = "< dfMul2Y"] + pub dfMul2Y: f64, + #[doc = "< dfCstX"] + pub dfCstX: f64, + #[doc = "< dfCstY"] + pub dfCstY: f64, +} +#[test] +fn bindgen_test_layout_GDALTriBarycentricCoefficients() { + assert_eq!( + ::std::mem::size_of::(), + 48usize, + concat!("Size of: ", stringify!(GDALTriBarycentricCoefficients)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(GDALTriBarycentricCoefficients)) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfMul1X as *const _ as usize + }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALTriBarycentricCoefficients), + "::", + stringify!(dfMul1X) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfMul1Y as *const _ as usize + }, + 8usize, + concat!( + "Offset of field: ", + stringify!(GDALTriBarycentricCoefficients), + "::", + stringify!(dfMul1Y) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfMul2X as *const _ as usize + }, + 16usize, + concat!( + "Offset of field: ", + stringify!(GDALTriBarycentricCoefficients), + "::", + stringify!(dfMul2X) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfMul2Y as *const _ as usize + }, + 24usize, + concat!( + "Offset of field: ", + stringify!(GDALTriBarycentricCoefficients), + "::", + stringify!(dfMul2Y) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfCstX as *const _ as usize + }, + 32usize, + concat!( + "Offset of field: ", + stringify!(GDALTriBarycentricCoefficients), + "::", + stringify!(dfCstX) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfCstY as *const _ as usize + }, + 40usize, + concat!( + "Offset of field: ", + stringify!(GDALTriBarycentricCoefficients), + "::", + stringify!(dfCstY) + ) + ); +} +#[doc = " Triangulation structure"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALTriangulation { + #[doc = "< number of facets"] + pub nFacets: libc::c_int, + #[doc = "< array of nFacets facets"] + pub pasFacets: *mut GDALTriFacet, + #[doc = "< arra of nFacets barycentric coefficients"] + pub pasFacetCoefficients: *mut GDALTriBarycentricCoefficients, +} +#[test] +fn bindgen_test_layout_GDALTriangulation() { + assert_eq!( + ::std::mem::size_of::(), + 24usize, + concat!("Size of: ", stringify!(GDALTriangulation)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(GDALTriangulation)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nFacets as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALTriangulation), + "::", + stringify!(nFacets) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pasFacets as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(GDALTriangulation), + "::", + stringify!(pasFacets) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pasFacetCoefficients as *const _ as usize + }, + 16usize, + concat!( + "Offset of field: ", + stringify!(GDALTriangulation), + "::", + stringify!(pasFacetCoefficients) + ) + ); +} +extern "C" { + pub fn GDALHasTriangulation() -> libc::c_int; +} +extern "C" { + pub fn GDALTriangulationCreateDelaunay( + nPoints: libc::c_int, + padfX: *const f64, + padfY: *const f64, + ) -> *mut GDALTriangulation; +} +extern "C" { + pub fn GDALTriangulationComputeBarycentricCoefficients( + psDT: *mut GDALTriangulation, + padfX: *const f64, + padfY: *const f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALTriangulationComputeBarycentricCoordinates( + psDT: *const GDALTriangulation, + nFacetIdx: libc::c_int, + dfX: f64, + dfY: f64, + pdfL1: *mut f64, + pdfL2: *mut f64, + pdfL3: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALTriangulationFindFacetBruteForce( + psDT: *const GDALTriangulation, + dfX: f64, + dfY: f64, + panOutputFacetIdx: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALTriangulationFindFacetDirected( + psDT: *const GDALTriangulation, + nFacetIdx: libc::c_int, + dfX: f64, + dfY: f64, + panOutputFacetIdx: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn GDALTriangulationFree(psDT: *mut GDALTriangulation); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn GDALTriangulationTerminate(); +} +extern "C" { + #[doc = " @endcond"] + pub fn GDALOpenVerticalShiftGrid( + pszProj4Geoidgrids: *const libc::c_char, + pbError: *mut libc::c_int, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALApplyVerticalShiftGrid( + hSrcDataset: GDALDatasetH, + hGridDataset: GDALDatasetH, + bInverse: libc::c_int, + dfSrcUnitToMeter: f64, + dfDstUnitToMeter: f64, + papszOptions: *const *const libc::c_char, + ) -> GDALDatasetH; +} +pub type CPLThreadFunc = ::std::option::Option; +extern "C" { + pub fn CPLLockFile(pszPath: *const libc::c_char, dfWaitInSeconds: f64) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLUnlockFile(hLock: *mut libc::c_void); +} +extern "C" { + pub fn CPLCreateMutex() -> *mut libc::c_void; +} +extern "C" { + pub fn CPLCreateMutexEx(nOptions: libc::c_int) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLCreateOrAcquireMutex( + arg1: *mut *mut libc::c_void, + dfWaitInSeconds: f64, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLCreateOrAcquireMutexEx( + arg1: *mut *mut libc::c_void, + dfWaitInSeconds: f64, + nOptions: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn CPLAcquireMutex(hMutex: *mut libc::c_void, dfWaitInSeconds: f64) -> libc::c_int; +} +extern "C" { + pub fn CPLReleaseMutex(hMutex: *mut libc::c_void); +} +extern "C" { + pub fn CPLDestroyMutex(hMutex: *mut libc::c_void); +} +extern "C" { + pub fn CPLCleanupMasterMutex(); +} +extern "C" { + pub fn CPLCreateCond() -> *mut libc::c_void; +} +extern "C" { + pub fn CPLCondWait(hCond: *mut libc::c_void, hMutex: *mut libc::c_void); +} +extern "C" { + pub fn CPLCondSignal(hCond: *mut libc::c_void); +} +extern "C" { + pub fn CPLCondBroadcast(hCond: *mut libc::c_void); +} +extern "C" { + pub fn CPLDestroyCond(hCond: *mut libc::c_void); +} +extern "C" { + #[doc = " Contrary to what its name suggests, CPLGetPID() actually returns the thread id"] + pub fn CPLGetPID() -> GIntBig; +} +extern "C" { + pub fn CPLGetCurrentProcessID() -> libc::c_int; +} +extern "C" { + pub fn CPLCreateThread(pfnMain: CPLThreadFunc, pArg: *mut libc::c_void) -> libc::c_int; +} +extern "C" { + pub fn CPLCreateJoinableThread( + pfnMain: CPLThreadFunc, + pArg: *mut libc::c_void, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLJoinThread(hJoinableThread: *mut libc::c_void); +} +extern "C" { + pub fn CPLSleep(dfWaitInSeconds: f64); +} +extern "C" { + pub fn CPLGetThreadingModel() -> *const libc::c_char; +} +extern "C" { + pub fn CPLGetNumCPUs() -> libc::c_int; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct _CPLLock { + _unused: [u8; 0], +} +pub type CPLLock = _CPLLock; +pub mod CPLLockType { + pub type Type = u32; + pub const LOCK_RECURSIVE_MUTEX: Type = 0; + pub const LOCK_ADAPTIVE_MUTEX: Type = 1; + pub const LOCK_SPIN: Type = 2; +} +extern "C" { + pub fn CPLCreateLock(eType: CPLLockType::Type) -> *mut CPLLock; +} +extern "C" { + pub fn CPLCreateOrAcquireLock(arg1: *mut *mut CPLLock, eType: CPLLockType::Type) + -> libc::c_int; +} +extern "C" { + pub fn CPLAcquireLock(arg1: *mut CPLLock) -> libc::c_int; +} +extern "C" { + pub fn CPLReleaseLock(arg1: *mut CPLLock); +} +extern "C" { + pub fn CPLDestroyLock(arg1: *mut CPLLock); +} +extern "C" { + pub fn CPLLockSetDebugPerf(arg1: *mut CPLLock, bEnableIn: libc::c_int); +} +extern "C" { + pub fn CPLGetTLS(nIndex: libc::c_int) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLGetTLSEx( + nIndex: libc::c_int, + pbMemoryErrorOccurred: *mut libc::c_int, + ) -> *mut libc::c_void; +} +extern "C" { + pub fn CPLSetTLS(nIndex: libc::c_int, pData: *mut libc::c_void, bFreeOnExit: libc::c_int); +} +pub type CPLTLSFreeFunc = ::std::option::Option; +extern "C" { + pub fn CPLSetTLSWithFreeFunc( + nIndex: libc::c_int, + pData: *mut libc::c_void, + pfnFree: CPLTLSFreeFunc, + ); +} +extern "C" { + pub fn CPLSetTLSWithFreeFuncEx( + nIndex: libc::c_int, + pData: *mut libc::c_void, + pfnFree: CPLTLSFreeFunc, + pbMemoryErrorOccurred: *mut libc::c_int, + ); +} +extern "C" { + pub fn CPLCleanupTLS(); +} +pub mod GDALResampleAlg { + #[doc = " Warp Resampling Algorithm"] + pub type Type = u32; + #[doc = " Nearest neighbour (select on one input pixel)"] + pub const GRA_NearestNeighbour: Type = 0; + #[doc = " Bilinear (2x2 kernel)"] + pub const GRA_Bilinear: Type = 1; + #[doc = " Cubic Convolution Approximation (4x4 kernel)"] + pub const GRA_Cubic: Type = 2; + #[doc = " Cubic B-Spline Approximation (4x4 kernel)"] + pub const GRA_CubicSpline: Type = 3; + #[doc = " Lanczos windowed sinc interpolation (6x6 kernel)"] + pub const GRA_Lanczos: Type = 4; + #[doc = " Average (computes the average of all non-NODATA contributing pixels)"] + pub const GRA_Average: Type = 5; + #[doc = " Mode (selects the value which appears most often of all the sampled points)"] + pub const GRA_Mode: Type = 6; + #[doc = " Max (selects maximum of all non-NODATA contributing pixels)"] + pub const GRA_Max: Type = 8; + #[doc = " Min (selects minimum of all non-NODATA contributing pixels)"] + pub const GRA_Min: Type = 9; + #[doc = " Med (selects median of all non-NODATA contributing pixels)"] + pub const GRA_Med: Type = 10; + #[doc = " Q1 (selects first quartile of all non-NODATA contributing pixels)"] + pub const GRA_Q1: Type = 11; + #[doc = " Q3 (selects third quartile of all non-NODATA contributing pixels)"] + pub const GRA_Q3: Type = 12; +} +#[doc = " @cond Doxygen_Suppress"] +pub type GDALMaskFunc = ::std::option::Option< + unsafe extern "C" fn( + pMaskFuncArg: *mut libc::c_void, + nBandCount: libc::c_int, + eType: GDALDataType::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + papabyImageData: *mut *mut GByte, + bMaskIsFloat: libc::c_int, + pMask: *mut libc::c_void, + ) -> libc::c_int, +>; +extern "C" { + pub fn GDALWarpNoDataMasker( + pMaskFuncArg: *mut libc::c_void, + nBandCount: libc::c_int, + eType: GDALDataType::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + papabyImageData: *mut *mut GByte, + bMaskIsFloat: libc::c_int, + pValidityMask: *mut libc::c_void, + pbOutAllValid: *mut libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWarpDstAlphaMasker( + pMaskFuncArg: *mut libc::c_void, + nBandCount: libc::c_int, + eType: GDALDataType::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + arg1: *mut *mut GByte, + bMaskIsFloat: libc::c_int, + pValidityMask: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWarpSrcAlphaMasker( + pMaskFuncArg: *mut libc::c_void, + nBandCount: libc::c_int, + eType: GDALDataType::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + arg1: *mut *mut GByte, + bMaskIsFloat: libc::c_int, + pValidityMask: *mut libc::c_void, + pbOutAllOpaque: *mut libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWarpSrcMaskMasker( + pMaskFuncArg: *mut libc::c_void, + nBandCount: libc::c_int, + eType: GDALDataType::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + arg1: *mut *mut GByte, + bMaskIsFloat: libc::c_int, + pValidityMask: *mut libc::c_void, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWarpCutlineMasker( + pMaskFuncArg: *mut libc::c_void, + nBandCount: libc::c_int, + eType: GDALDataType::Type, + nXOff: libc::c_int, + nYOff: libc::c_int, + nXSize: libc::c_int, + nYSize: libc::c_int, + arg1: *mut *mut GByte, + bMaskIsFloat: libc::c_int, + pValidityMask: *mut libc::c_void, + ) -> CPLErr::Type; +} +#[doc = " Warp control options for use with GDALWarpOperation::Initialize()"] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct GDALWarpOptions { + pub papszWarpOptions: *mut *mut libc::c_char, + #[doc = " In bytes, 0.0 for internal default"] + pub dfWarpMemoryLimit: f64, + #[doc = " Resampling algorithm to use"] + pub eResampleAlg: GDALResampleAlg::Type, + #[doc = " data type to use during warp operation, GDT_Unknown lets the algorithm"] + #[doc = "select the type"] + pub eWorkingDataType: GDALDataType::Type, + #[doc = " Source image dataset."] + pub hSrcDS: GDALDatasetH, + #[doc = " Destination image dataset - may be NULL if only using GDALWarpOperation::WarpRegionToBuffer()."] + pub hDstDS: GDALDatasetH, + #[doc = " Number of bands to process, may be 0 to select all bands."] + pub nBandCount: libc::c_int, + #[doc = " The band numbers for the source bands to process (1 based)"] + pub panSrcBands: *mut libc::c_int, + #[doc = " The band numbers for the destination bands to process (1 based)"] + pub panDstBands: *mut libc::c_int, + #[doc = " The source band so use as an alpha (transparency) value, 0=disabled"] + pub nSrcAlphaBand: libc::c_int, + #[doc = " The dest. band so use as an alpha (transparency) value, 0=disabled"] + pub nDstAlphaBand: libc::c_int, + #[doc = " The \"nodata\" value real component for each input band, if NULL there isn't one"] + pub padfSrcNoDataReal: *mut f64, + #[doc = " The \"nodata\" value imaginary component - may be NULL even if real"] + #[doc = "component is provided. This value is not used to flag invalid values."] + #[doc = "Only the real component is used."] + pub padfSrcNoDataImag: *mut f64, + #[doc = " The \"nodata\" value real component for each output band, if NULL there isn't one"] + pub padfDstNoDataReal: *mut f64, + #[doc = " The \"nodata\" value imaginary component - may be NULL even if real"] + #[doc = "component is provided. Note that warp operations only use real component"] + #[doc = "for flagging invalid data."] + pub padfDstNoDataImag: *mut f64, + #[doc = " GDALProgressFunc() compatible progress reporting function, or NULL"] + #[doc = "if there isn't one."] + pub pfnProgress: GDALProgressFunc, + #[doc = " Callback argument to be passed to pfnProgress."] + pub pProgressArg: *mut libc::c_void, + #[doc = " Type of spatial point transformer function"] + pub pfnTransformer: GDALTransformerFunc, + #[doc = " Handle to image transformer setup structure"] + pub pTransformerArg: *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub papfnSrcPerBandValidityMaskFunc: *mut GDALMaskFunc, + #[doc = " Unused. Must be NULL"] + pub papSrcPerBandValidityMaskFuncArg: *mut *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub pfnSrcValidityMaskFunc: GDALMaskFunc, + #[doc = " Unused. Must be NULL"] + pub pSrcValidityMaskFuncArg: *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub pfnSrcDensityMaskFunc: GDALMaskFunc, + #[doc = " Unused. Must be NULL"] + pub pSrcDensityMaskFuncArg: *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub pfnDstDensityMaskFunc: GDALMaskFunc, + #[doc = " Unused. Must be NULL"] + pub pDstDensityMaskFuncArg: *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub pfnDstValidityMaskFunc: GDALMaskFunc, + #[doc = " Unused. Must be NULL"] + pub pDstValidityMaskFuncArg: *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub pfnPreWarpChunkProcessor: ::std::option::Option< + unsafe extern "C" fn(pKern: *mut libc::c_void, pArg: *mut libc::c_void) -> CPLErr::Type, + >, + #[doc = " Unused. Must be NULL"] + pub pPreWarpProcessorArg: *mut libc::c_void, + #[doc = " Unused. Must be NULL"] + pub pfnPostWarpChunkProcessor: ::std::option::Option< + unsafe extern "C" fn(pKern: *mut libc::c_void, pArg: *mut libc::c_void) -> CPLErr::Type, + >, + #[doc = " Unused. Must be NULL"] + pub pPostWarpProcessorArg: *mut libc::c_void, + #[doc = " Optional OGRPolygonH for a masking cutline."] + pub hCutline: *mut libc::c_void, + #[doc = " Optional blending distance to apply across cutline in pixels, default is zero."] + pub dfCutlineBlendDist: f64, +} +#[test] +fn bindgen_test_layout_GDALWarpOptions() { + assert_eq!( + ::std::mem::size_of::(), + 264usize, + concat!("Size of: ", stringify!(GDALWarpOptions)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(GDALWarpOptions)) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).papszWarpOptions as *const _ as usize + }, + 0usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(papszWarpOptions) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfWarpMemoryLimit as *const _ as usize + }, + 8usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(dfWarpMemoryLimit) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).eResampleAlg as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(eResampleAlg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).eWorkingDataType as *const _ as usize + }, + 20usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(eWorkingDataType) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).hSrcDS as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(hSrcDS) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).hDstDS as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(hDstDS) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nBandCount as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(nBandCount) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).panSrcBands as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(panSrcBands) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).panDstBands as *const _ as usize }, + 56usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(panDstBands) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nSrcAlphaBand as *const _ as usize }, + 64usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(nSrcAlphaBand) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).nDstAlphaBand as *const _ as usize }, + 68usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(nDstAlphaBand) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).padfSrcNoDataReal as *const _ as usize + }, + 72usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(padfSrcNoDataReal) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).padfSrcNoDataImag as *const _ as usize + }, + 80usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(padfSrcNoDataImag) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).padfDstNoDataReal as *const _ as usize + }, + 88usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(padfDstNoDataReal) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).padfDstNoDataImag as *const _ as usize + }, + 96usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(padfDstNoDataImag) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pfnProgress as *const _ as usize }, + 104usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnProgress) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pProgressArg as *const _ as usize }, + 112usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pProgressArg) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pfnTransformer as *const _ as usize }, + 120usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnTransformer) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pTransformerArg as *const _ as usize }, + 128usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pTransformerArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).papfnSrcPerBandValidityMaskFunc as *const _ + as usize + }, + 136usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(papfnSrcPerBandValidityMaskFunc) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).papSrcPerBandValidityMaskFuncArg as *const _ + as usize + }, + 144usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(papSrcPerBandValidityMaskFuncArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnSrcValidityMaskFunc as *const _ as usize + }, + 152usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnSrcValidityMaskFunc) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pSrcValidityMaskFuncArg as *const _ as usize + }, + 160usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pSrcValidityMaskFuncArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnSrcDensityMaskFunc as *const _ as usize + }, + 168usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnSrcDensityMaskFunc) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pSrcDensityMaskFuncArg as *const _ as usize + }, + 176usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pSrcDensityMaskFuncArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnDstDensityMaskFunc as *const _ as usize + }, + 184usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnDstDensityMaskFunc) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pDstDensityMaskFuncArg as *const _ as usize + }, + 192usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pDstDensityMaskFuncArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnDstValidityMaskFunc as *const _ as usize + }, + 200usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnDstValidityMaskFunc) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pDstValidityMaskFuncArg as *const _ as usize + }, + 208usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pDstValidityMaskFuncArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnPreWarpChunkProcessor as *const _ + as usize + }, + 216usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnPreWarpChunkProcessor) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pPreWarpProcessorArg as *const _ as usize + }, + 224usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pPreWarpProcessorArg) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pfnPostWarpChunkProcessor as *const _ + as usize + }, + 232usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pfnPostWarpChunkProcessor) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).pPostWarpProcessorArg as *const _ as usize + }, + 240usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(pPostWarpProcessorArg) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).hCutline as *const _ as usize }, + 248usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(hCutline) + ) + ); + assert_eq!( + unsafe { + &(*(::std::ptr::null::())).dfCutlineBlendDist as *const _ as usize + }, + 256usize, + concat!( + "Offset of field: ", + stringify!(GDALWarpOptions), + "::", + stringify!(dfCutlineBlendDist) + ) + ); +} +extern "C" { + pub fn GDALCreateWarpOptions() -> *mut GDALWarpOptions; +} +extern "C" { + pub fn GDALDestroyWarpOptions(arg1: *mut GDALWarpOptions); +} +extern "C" { + pub fn GDALCloneWarpOptions(arg1: *const GDALWarpOptions) -> *mut GDALWarpOptions; +} +extern "C" { + pub fn GDALWarpInitDstNoDataReal(arg1: *mut GDALWarpOptions, dNoDataReal: f64); +} +extern "C" { + pub fn GDALWarpInitSrcNoDataReal(arg1: *mut GDALWarpOptions, dNoDataReal: f64); +} +extern "C" { + pub fn GDALWarpInitNoDataReal(arg1: *mut GDALWarpOptions, dNoDataReal: f64); +} +extern "C" { + pub fn GDALWarpInitDstNoDataImag(arg1: *mut GDALWarpOptions, dNoDataImag: f64); +} +extern "C" { + pub fn GDALWarpInitSrcNoDataImag(arg1: *mut GDALWarpOptions, dNoDataImag: f64); +} +extern "C" { + pub fn GDALWarpResolveWorkingDataType(arg1: *mut GDALWarpOptions); +} +extern "C" { + pub fn GDALWarpInitDefaultBandMapping(arg1: *mut GDALWarpOptions, nBandCount: libc::c_int); +} +extern "C" { + #[doc = " @cond Doxygen_Suppress"] + pub fn GDALSerializeWarpOptions(arg1: *const GDALWarpOptions) -> *mut CPLXMLNode; +} +extern "C" { + pub fn GDALDeserializeWarpOptions(arg1: *mut CPLXMLNode) -> *mut GDALWarpOptions; +} +extern "C" { + pub fn GDALReprojectImage( + hSrcDS: GDALDatasetH, + pszSrcWKT: *const libc::c_char, + hDstDS: GDALDatasetH, + pszDstWKT: *const libc::c_char, + eResampleAlg: GDALResampleAlg::Type, + dfWarpMemoryLimit: f64, + dfMaxError: f64, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + psOptions: *mut GDALWarpOptions, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALCreateAndReprojectImage( + hSrcDS: GDALDatasetH, + pszSrcWKT: *const libc::c_char, + pszDstFilename: *const libc::c_char, + pszDstWKT: *const libc::c_char, + hDstDriver: GDALDriverH, + papszCreateOptions: *mut *mut libc::c_char, + eResampleAlg: GDALResampleAlg::Type, + dfWarpMemoryLimit: f64, + dfMaxError: f64, + pfnProgress: GDALProgressFunc, + pProgressArg: *mut libc::c_void, + psOptions: *mut GDALWarpOptions, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALAutoCreateWarpedVRT( + hSrcDS: GDALDatasetH, + pszSrcWKT: *const libc::c_char, + pszDstWKT: *const libc::c_char, + eResampleAlg: GDALResampleAlg::Type, + dfMaxError: f64, + psOptions: *const GDALWarpOptions, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALCreateWarpedVRT( + hSrcDS: GDALDatasetH, + nPixels: libc::c_int, + nLines: libc::c_int, + padfGeoTransform: *mut f64, + psOptions: *mut GDALWarpOptions, + ) -> GDALDatasetH; +} +extern "C" { + pub fn GDALInitializeWarpedVRT(hDS: GDALDatasetH, psWO: *mut GDALWarpOptions) -> CPLErr::Type; +} +#[doc = " Opaque type representing a GDALWarpOperation object"] +pub type GDALWarpOperationH = *mut libc::c_void; +extern "C" { + pub fn GDALCreateWarpOperation(arg1: *const GDALWarpOptions) -> GDALWarpOperationH; +} +extern "C" { + pub fn GDALDestroyWarpOperation(arg1: GDALWarpOperationH); +} +extern "C" { + pub fn GDALChunkAndWarpImage( + arg1: GDALWarpOperationH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALChunkAndWarpMulti( + arg1: GDALWarpOperationH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWarpRegion( + arg1: GDALWarpOperationH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: libc::c_int, + arg6: libc::c_int, + arg7: libc::c_int, + arg8: libc::c_int, + arg9: libc::c_int, + ) -> CPLErr::Type; +} +extern "C" { + pub fn GDALWarpRegionToBuffer( + arg1: GDALWarpOperationH, + arg2: libc::c_int, + arg3: libc::c_int, + arg4: libc::c_int, + arg5: libc::c_int, + arg6: *mut libc::c_void, + arg7: GDALDataType::Type, + arg8: libc::c_int, + arg9: libc::c_int, + arg10: libc::c_int, + arg11: libc::c_int, + ) -> CPLErr::Type; +} +pub mod OGRAxisOrientation { + #[doc = " Axis orientations (corresponds to CS_AxisOrientationEnum)."] + pub type Type = u32; + #[doc = "< Other"] + pub const OAO_Other: Type = 0; + #[doc = "< North"] + pub const OAO_North: Type = 1; + #[doc = "< South"] + pub const OAO_South: Type = 2; + #[doc = "< East"] + pub const OAO_East: Type = 3; + #[doc = "< West"] + pub const OAO_West: Type = 4; + #[doc = "< Up (to space)"] + pub const OAO_Up: Type = 5; + #[doc = "< Down (to Earth center)"] + pub const OAO_Down: Type = 6; +} +extern "C" { + pub fn OSRAxisEnumToName(eOrientation: OGRAxisOrientation::Type) -> *const libc::c_char; +} +extern "C" { + pub fn OSRSetPROJSearchPaths(papszPaths: *const *const libc::c_char); +} +extern "C" { + pub fn OSRGetPROJSearchPaths() -> *mut *mut libc::c_char; +} +extern "C" { + pub fn OSRGetPROJVersion( + pnMajor: *mut libc::c_int, + pnMinor: *mut libc::c_int, + pnPatch: *mut libc::c_int, + ); +} +extern "C" { + pub fn OSRNewSpatialReference(arg1: *const libc::c_char) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OSRCloneGeogCS(arg1: OGRSpatialReferenceH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OSRClone(arg1: OGRSpatialReferenceH) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OSRDestroySpatialReference(arg1: OGRSpatialReferenceH); +} +extern "C" { + pub fn OSRReference(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRDereference(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRRelease(arg1: OGRSpatialReferenceH); +} +extern "C" { + pub fn OSRValidate(arg1: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromEPSG(arg1: OGRSpatialReferenceH, arg2: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromEPSGA(arg1: OGRSpatialReferenceH, arg2: libc::c_int) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromWkt( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromProj4( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromESRI( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromPCI( + hSRS: OGRSpatialReferenceH, + arg1: *const libc::c_char, + arg2: *const libc::c_char, + arg3: *mut f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromUSGS( + arg1: OGRSpatialReferenceH, + arg2: libc::c_long, + arg3: libc::c_long, + arg4: *mut f64, + arg5: libc::c_long, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromXML(arg1: OGRSpatialReferenceH, arg2: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromDict( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromPanorama( + arg1: OGRSpatialReferenceH, + arg2: libc::c_long, + arg3: libc::c_long, + arg4: libc::c_long, + arg5: *mut f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromOzi( + arg1: OGRSpatialReferenceH, + arg2: *const *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromMICoordSys( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromERM( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: *const libc::c_char, + arg4: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRImportFromUrl(arg1: OGRSpatialReferenceH, arg2: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToWkt(arg1: OGRSpatialReferenceH, arg2: *mut *mut libc::c_char) + -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToWktEx( + arg1: OGRSpatialReferenceH, + ppszResult: *mut *mut libc::c_char, + papszOptions: *const *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToPrettyWkt( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + arg3: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToProj4( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToPCI( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + arg3: *mut *mut libc::c_char, + arg4: *mut *mut f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToUSGS( + arg1: OGRSpatialReferenceH, + arg2: *mut libc::c_long, + arg3: *mut libc::c_long, + arg4: *mut *mut f64, + arg5: *mut libc::c_long, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToXML( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + arg3: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToPanorama( + arg1: OGRSpatialReferenceH, + arg2: *mut libc::c_long, + arg3: *mut libc::c_long, + arg4: *mut libc::c_long, + arg5: *mut libc::c_long, + arg6: *mut f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToMICoordSys( + arg1: OGRSpatialReferenceH, + arg2: *mut *mut libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRExportToERM( + arg1: OGRSpatialReferenceH, + arg2: *mut libc::c_char, + arg3: *mut libc::c_char, + arg4: *mut libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRMorphToESRI(arg1: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + pub fn OSRMorphFromESRI(arg1: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + pub fn OSRConvertToOtherProjection( + hSRS: OGRSpatialReferenceH, + pszTargetProjection: *const libc::c_char, + papszOptions: *const *const libc::c_char, + ) -> OGRSpatialReferenceH; +} +extern "C" { + pub fn OSRGetName(hSRS: OGRSpatialReferenceH) -> *const libc::c_char; +} +extern "C" { + pub fn OSRSetAttrValue( + hSRS: OGRSpatialReferenceH, + pszNodePath: *const libc::c_char, + pszNewNodeValue: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetAttrValue( + hSRS: OGRSpatialReferenceH, + pszName: *const libc::c_char, + iChild: libc::c_int, + ) -> *const libc::c_char; +} +extern "C" { + pub fn OSRSetAngularUnits( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetAngularUnits(arg1: OGRSpatialReferenceH, arg2: *mut *mut libc::c_char) -> f64; +} +extern "C" { + pub fn OSRSetLinearUnits( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetTargetLinearUnits( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: *const libc::c_char, + arg4: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetLinearUnitsAndUpdateParameters( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetLinearUnits(arg1: OGRSpatialReferenceH, arg2: *mut *mut libc::c_char) -> f64; +} +extern "C" { + pub fn OSRGetTargetLinearUnits( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: *mut *mut libc::c_char, + ) -> f64; +} +extern "C" { + pub fn OSRGetPrimeMeridian(arg1: OGRSpatialReferenceH, arg2: *mut *mut libc::c_char) -> f64; +} +extern "C" { + pub fn OSRIsGeographic(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsLocal(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsProjected(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsCompound(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsGeocentric(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsVertical(arg1: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsSameGeogCS(arg1: OGRSpatialReferenceH, arg2: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsSameVertCS(arg1: OGRSpatialReferenceH, arg2: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsSame(arg1: OGRSpatialReferenceH, arg2: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRIsSameEx( + arg1: OGRSpatialReferenceH, + arg2: OGRSpatialReferenceH, + papszOptions: *const *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OSRSetLocalCS(hSRS: OGRSpatialReferenceH, pszName: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetProjCS(hSRS: OGRSpatialReferenceH, pszName: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetGeocCS(hSRS: OGRSpatialReferenceH, pszName: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetWellKnownGeogCS( + hSRS: OGRSpatialReferenceH, + pszName: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetFromUserInput( + hSRS: OGRSpatialReferenceH, + arg1: *const libc::c_char, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRCopyGeogCSFrom( + hSRS: OGRSpatialReferenceH, + hSrcSRS: OGRSpatialReferenceH, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetTOWGS84( + hSRS: OGRSpatialReferenceH, + arg1: f64, + arg2: f64, + arg3: f64, + arg4: f64, + arg5: f64, + arg6: f64, + arg7: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetTOWGS84( + hSRS: OGRSpatialReferenceH, + arg1: *mut f64, + arg2: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRAddGuessedTOWGS84(hSRS: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetCompoundCS( + hSRS: OGRSpatialReferenceH, + pszName: *const libc::c_char, + hHorizSRS: OGRSpatialReferenceH, + hVertSRS: OGRSpatialReferenceH, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetGeogCS( + hSRS: OGRSpatialReferenceH, + pszGeogName: *const libc::c_char, + pszDatumName: *const libc::c_char, + pszEllipsoidName: *const libc::c_char, + dfSemiMajor: f64, + dfInvFlattening: f64, + pszPMName: *const libc::c_char, + dfPMOffset: f64, + pszUnits: *const libc::c_char, + dfConvertToRadians: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetVertCS( + hSRS: OGRSpatialReferenceH, + pszVertCSName: *const libc::c_char, + pszVertDatumName: *const libc::c_char, + nVertDatumType: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetSemiMajor(arg1: OGRSpatialReferenceH, arg2: *mut OGRErr::Type) -> f64; +} +extern "C" { + pub fn OSRGetSemiMinor(arg1: OGRSpatialReferenceH, arg2: *mut OGRErr::Type) -> f64; +} +extern "C" { + pub fn OSRGetInvFlattening(arg1: OGRSpatialReferenceH, arg2: *mut OGRErr::Type) -> f64; +} +extern "C" { + pub fn OSRSetAuthority( + hSRS: OGRSpatialReferenceH, + pszTargetKey: *const libc::c_char, + pszAuthority: *const libc::c_char, + nCode: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetAuthorityCode( + hSRS: OGRSpatialReferenceH, + pszTargetKey: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn OSRGetAuthorityName( + hSRS: OGRSpatialReferenceH, + pszTargetKey: *const libc::c_char, + ) -> *const libc::c_char; +} +extern "C" { + pub fn OSRGetAreaOfUse( + hSRS: OGRSpatialReferenceH, + pdfWestLongitudeDeg: *mut f64, + pdfSouthLatitudeDeg: *mut f64, + pdfEastLongitudeDeg: *mut f64, + pdfNorthLatitudeDeg: *mut f64, + ppszAreaName: *mut *const libc::c_char, + ) -> libc::c_int; +} +extern "C" { + pub fn OSRSetProjection(arg1: OGRSpatialReferenceH, arg2: *const libc::c_char) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetProjParm( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetProjParm( + hSRS: OGRSpatialReferenceH, + pszParmName: *const libc::c_char, + dfDefault: f64, + arg1: *mut OGRErr::Type, + ) -> f64; +} +extern "C" { + pub fn OSRSetNormProjParm( + arg1: OGRSpatialReferenceH, + arg2: *const libc::c_char, + arg3: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetNormProjParm( + hSRS: OGRSpatialReferenceH, + pszParmName: *const libc::c_char, + dfDefault: f64, + arg1: *mut OGRErr::Type, + ) -> f64; +} +extern "C" { + pub fn OSRSetUTM( + hSRS: OGRSpatialReferenceH, + nZone: libc::c_int, + bNorth: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRGetUTMZone(hSRS: OGRSpatialReferenceH, pbNorth: *mut libc::c_int) -> libc::c_int; +} +extern "C" { + pub fn OSRSetStatePlane( + hSRS: OGRSpatialReferenceH, + nZone: libc::c_int, + bNAD83: libc::c_int, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetStatePlaneWithUnits( + hSRS: OGRSpatialReferenceH, + nZone: libc::c_int, + bNAD83: libc::c_int, + pszOverrideUnitName: *const libc::c_char, + dfOverrideUnit: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRAutoIdentifyEPSG(hSRS: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + pub fn OSRFindMatches( + hSRS: OGRSpatialReferenceH, + papszOptions: *mut *mut libc::c_char, + pnEntries: *mut libc::c_int, + ppanMatchConfidence: *mut *mut libc::c_int, + ) -> *mut OGRSpatialReferenceH; +} +extern "C" { + pub fn OSRFreeSRSArray(pahSRS: *mut OGRSpatialReferenceH); +} +extern "C" { + pub fn OSREPSGTreatsAsLatLong(hSRS: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSREPSGTreatsAsNorthingEasting(hSRS: OGRSpatialReferenceH) -> libc::c_int; +} +extern "C" { + pub fn OSRGetAxis( + hSRS: OGRSpatialReferenceH, + pszTargetKey: *const libc::c_char, + iAxis: libc::c_int, + peOrientation: *mut OGRAxisOrientation::Type, + ) -> *const libc::c_char; +} +extern "C" { + pub fn OSRSetAxes( + hSRS: OGRSpatialReferenceH, + pszTargetKey: *const libc::c_char, + pszXAxisName: *const libc::c_char, + eXAxisOrientation: OGRAxisOrientation::Type, + pszYAxisName: *const libc::c_char, + eYAxisOrientation: OGRAxisOrientation::Type, + ) -> OGRErr::Type; +} +pub mod OSRAxisMappingStrategy { + #[doc = " Data axis to CRS axis mapping strategy."] + pub type Type = u32; + #[doc = "< Traditional GIS order"] + pub const OAMS_TRADITIONAL_GIS_ORDER: Type = 0; + #[doc = "< Compliant with the order mandated by the CRS authority"] + pub const OAMS_AUTHORITY_COMPLIANT: Type = 1; + #[doc = "< Custom"] + pub const OAMS_CUSTOM: Type = 2; +} +extern "C" { + pub fn OSRGetAxisMappingStrategy(hSRS: OGRSpatialReferenceH) -> OSRAxisMappingStrategy::Type; +} +extern "C" { + pub fn OSRSetAxisMappingStrategy( + hSRS: OGRSpatialReferenceH, + strategy: OSRAxisMappingStrategy::Type, + ); +} +extern "C" { + pub fn OSRGetDataAxisToSRSAxisMapping( + hSRS: OGRSpatialReferenceH, + pnCount: *mut libc::c_int, + ) -> *const libc::c_int; +} +extern "C" { + #[doc = " Albers Conic Equal Area"] + pub fn OSRSetACEA( + hSRS: OGRSpatialReferenceH, + dfStdP1: f64, + dfStdP2: f64, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Azimuthal Equidistant"] + pub fn OSRSetAE( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Bonne"] + pub fn OSRSetBonne( + hSRS: OGRSpatialReferenceH, + dfStandardParallel: f64, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Cylindrical Equal Area"] + pub fn OSRSetCEA( + hSRS: OGRSpatialReferenceH, + dfStdP1: f64, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Cassini-Soldner"] + pub fn OSRSetCS( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Equidistant Conic"] + pub fn OSRSetEC( + hSRS: OGRSpatialReferenceH, + dfStdP1: f64, + dfStdP2: f64, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Eckert I-VI"] + pub fn OSRSetEckert( + hSRS: OGRSpatialReferenceH, + nVariation: libc::c_int, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Eckert IV"] + pub fn OSRSetEckertIV( + hSRS: OGRSpatialReferenceH, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Eckert VI"] + pub fn OSRSetEckertVI( + hSRS: OGRSpatialReferenceH, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Equirectangular"] + pub fn OSRSetEquirectangular( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Equirectangular generalized form"] + pub fn OSRSetEquirectangular2( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfPseudoStdParallel1: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Gall Stereograpic"] + pub fn OSRSetGS( + hSRS: OGRSpatialReferenceH, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Goode Homolosine"] + pub fn OSRSetGH( + hSRS: OGRSpatialReferenceH, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Interrupted Goode Homolosine"] + pub fn OSRSetIGH(hSRS: OGRSpatialReferenceH) -> OGRErr::Type; +} +extern "C" { + #[doc = " GEOS - Geostationary Satellite View"] + pub fn OSRSetGEOS( + hSRS: OGRSpatialReferenceH, + dfCentralMeridian: f64, + dfSatelliteHeight: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Gauss Schreiber Transverse Mercator"] + pub fn OSRSetGaussSchreiberTMercator( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Gnomonic"] + pub fn OSRSetGnomonic( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Hotine Oblique Mercator using azimuth angle"] + pub fn OSRSetHOM( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfAzimuth: f64, + dfRectToSkew: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRSetHOMAC( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfAzimuth: f64, + dfRectToSkew: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Hotine Oblique Mercator using two points on centerline"] + pub fn OSRSetHOM2PNO( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfLat1: f64, + dfLong1: f64, + dfLat2: f64, + dfLong2: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " International Map of the World Polyconic"] + pub fn OSRSetIWMPolyconic( + hSRS: OGRSpatialReferenceH, + dfLat1: f64, + dfLat2: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Krovak Oblique Conic Conformal"] + pub fn OSRSetKrovak( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfAzimuth: f64, + dfPseudoStdParallelLat: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Lambert Azimuthal Equal-Area"] + pub fn OSRSetLAEA( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Lambert Conformal Conic"] + pub fn OSRSetLCC( + hSRS: OGRSpatialReferenceH, + dfStdP1: f64, + dfStdP2: f64, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Lambert Conformal Conic 1SP"] + pub fn OSRSetLCC1SP( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Lambert Conformal Conic (Belgium)"] + pub fn OSRSetLCCB( + hSRS: OGRSpatialReferenceH, + dfStdP1: f64, + dfStdP2: f64, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Miller Cylindrical"] + pub fn OSRSetMC( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Mercator"] + pub fn OSRSetMercator( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Mercator 2SP"] + pub fn OSRSetMercator2SP( + hSRS: OGRSpatialReferenceH, + dfStdP1: f64, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Mollweide"] + pub fn OSRSetMollweide( + hSRS: OGRSpatialReferenceH, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " New Zealand Map Grid"] + pub fn OSRSetNZMG( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Oblique Stereographic"] + pub fn OSRSetOS( + hSRS: OGRSpatialReferenceH, + dfOriginLat: f64, + dfCMeridian: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Orthographic"] + pub fn OSRSetOrthographic( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Polyconic"] + pub fn OSRSetPolyconic( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Polar Stereographic"] + pub fn OSRSetPS( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Robinson"] + pub fn OSRSetRobinson( + hSRS: OGRSpatialReferenceH, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Sinusoidal"] + pub fn OSRSetSinusoidal( + hSRS: OGRSpatialReferenceH, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Stereographic"] + pub fn OSRSetStereographic( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Swiss Oblique Cylindrical"] + pub fn OSRSetSOC( + hSRS: OGRSpatialReferenceH, + dfLatitudeOfOrigin: f64, + dfCentralMeridian: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Transverse Mercator"] + #[doc = ""] + #[doc = " Special processing available for Transverse Mercator with GDAL >= 1.10 and PROJ >= 4.8 :"] + #[doc = " see OGRSpatialReference::exportToProj4()."] + pub fn OSRSetTM( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Transverse Mercator variant"] + pub fn OSRSetTMVariant( + hSRS: OGRSpatialReferenceH, + pszVariantName: *const libc::c_char, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Tunesia Mining Grid"] + pub fn OSRSetTMG( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Transverse Mercator (South Oriented)"] + pub fn OSRSetTMSO( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + dfScale: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " TPED (Two Point Equi Distant)"] + pub fn OSRSetTPED( + hSRS: OGRSpatialReferenceH, + dfLat1: f64, + dfLong1: f64, + dfLat2: f64, + dfLong2: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " VanDerGrinten"] + pub fn OSRSetVDG( + hSRS: OGRSpatialReferenceH, + dfCenterLong: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Wagner I -- VII"] + pub fn OSRSetWagner( + hSRS: OGRSpatialReferenceH, + nVariation: libc::c_int, + dfCenterLat: f64, + dfFalseEasting: f64, + dfFalseNorthing: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Quadrilateralized Spherical Cube"] + pub fn OSRSetQSC( + hSRS: OGRSpatialReferenceH, + dfCenterLat: f64, + dfCenterLong: f64, + ) -> OGRErr::Type; +} +extern "C" { + #[doc = " Spherical, Cross-track, Height"] + pub fn OSRSetSCH( + hSRS: OGRSpatialReferenceH, + dfPegLat: f64, + dfPegLong: f64, + dfPegHeading: f64, + dfPegHgt: f64, + ) -> OGRErr::Type; +} +extern "C" { + pub fn OSRCalcInvFlattening(dfSemiMajor: f64, dfSemiMinor: f64) -> f64; +} +extern "C" { + pub fn OSRCalcSemiMinorFromInvFlattening(dfSemiMajor: f64, dfInvFlattening: f64) -> f64; +} +extern "C" { + pub fn OSRCleanup(); +} +pub mod OSRCRSType { + #[doc = " \\brief Type of Coordinate Reference System (CRS)."] + pub type Type = u32; + #[doc = " Geographic 2D CRS"] + pub const OSR_CRS_TYPE_GEOGRAPHIC_2D: Type = 0; + #[doc = " Geographic 3D CRS"] + pub const OSR_CRS_TYPE_GEOGRAPHIC_3D: Type = 1; + #[doc = " Geocentric CRS"] + pub const OSR_CRS_TYPE_GEOCENTRIC: Type = 2; + #[doc = " Projected CRS"] + pub const OSR_CRS_TYPE_PROJECTED: Type = 3; + #[doc = " Vertical CRS"] + pub const OSR_CRS_TYPE_VERTICAL: Type = 4; + #[doc = " Compound CRS"] + pub const OSR_CRS_TYPE_COMPOUND: Type = 5; + #[doc = " Other"] + pub const OSR_CRS_TYPE_OTHER: Type = 6; +} +#[doc = " \\brief Structure given overall description of a CRS."] +#[doc = ""] +#[doc = " This structure may grow over time, and should not be directly allocated by"] +#[doc = " client code."] +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OSRCRSInfo { + #[doc = " Authority name."] + pub pszAuthName: *mut libc::c_char, + #[doc = " Object code."] + pub pszCode: *mut libc::c_char, + #[doc = " Object name."] + pub pszName: *mut libc::c_char, + #[doc = " Object type."] + pub eType: OSRCRSType::Type, + #[doc = " Whether the object is deprecated"] + pub bDeprecated: libc::c_int, + #[doc = " Whereas the west_lon_degree, south_lat_degree, east_lon_degree and"] + #[doc = " north_lat_degree fields are valid."] + pub bBboxValid: libc::c_int, + #[doc = " Western-most longitude of the area of use, in degrees."] + pub dfWestLongitudeDeg: f64, + #[doc = " Southern-most latitude of the area of use, in degrees."] + pub dfSouthLatitudeDeg: f64, + #[doc = " Eastern-most longitude of the area of use, in degrees."] + pub dfEastLongitudeDeg: f64, + #[doc = " Northern-most latitude of the area of use, in degrees."] + pub dfNorthLatitudeDeg: f64, + #[doc = " Name of the area of use."] + pub pszAreaName: *mut libc::c_char, + #[doc = " Name of the projection method for a projected CRS. Might be NULL even"] + #[doc = "for projected CRS in some cases."] + pub pszProjectionMethod: *mut libc::c_char, +} +#[test] +fn bindgen_test_layout_OSRCRSInfo() { + assert_eq!( + ::std::mem::size_of::(), + 88usize, + concat!("Size of: ", stringify!(OSRCRSInfo)) + ); + assert_eq!( + ::std::mem::align_of::(), + 8usize, + concat!("Alignment of ", stringify!(OSRCRSInfo)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszAuthName as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(pszAuthName) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszCode as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(pszCode) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszName as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(pszName) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).eType as *const _ as usize }, + 24usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(eType) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).bDeprecated as *const _ as usize }, + 28usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(bDeprecated) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).bBboxValid as *const _ as usize }, + 32usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(bBboxValid) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfWestLongitudeDeg as *const _ as usize }, + 40usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(dfWestLongitudeDeg) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfSouthLatitudeDeg as *const _ as usize }, + 48usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(dfSouthLatitudeDeg) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfEastLongitudeDeg as *const _ as usize }, + 56usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(dfEastLongitudeDeg) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).dfNorthLatitudeDeg as *const _ as usize }, + 64usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(dfNorthLatitudeDeg) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszAreaName as *const _ as usize }, + 72usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(pszAreaName) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::())).pszProjectionMethod as *const _ as usize }, + 80usize, + concat!( + "Offset of field: ", + stringify!(OSRCRSInfo), + "::", + stringify!(pszProjectionMethod) + ) + ); +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OSRCRSListParameters { + _unused: [u8; 0], +} +extern "C" { + pub fn OSRGetCRSInfoListFromDatabase( + pszAuthName: *const libc::c_char, + params: *const OSRCRSListParameters, + pnOutResultCount: *mut libc::c_int, + ) -> *mut *mut OSRCRSInfo; +} +extern "C" { + pub fn OSRDestroyCRSInfoList(list: *mut *mut OSRCRSInfo); +} +extern "C" { + pub fn OCTNewCoordinateTransformation( + hSourceSRS: OGRSpatialReferenceH, + hTargetSRS: OGRSpatialReferenceH, + ) -> OGRCoordinateTransformationH; +} +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct OGRCoordinateTransformationOptions { + _unused: [u8; 0], +} +#[doc = " Coordinate transformation options."] +pub type OGRCoordinateTransformationOptionsH = *mut OGRCoordinateTransformationOptions; +extern "C" { + pub fn OCTNewCoordinateTransformationOptions() -> OGRCoordinateTransformationOptionsH; +} +extern "C" { + pub fn OCTCoordinateTransformationOptionsSetOperation( + hOptions: OGRCoordinateTransformationOptionsH, + pszCO: *const libc::c_char, + bReverseCO: libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OCTCoordinateTransformationOptionsSetAreaOfInterest( + hOptions: OGRCoordinateTransformationOptionsH, + dfWestLongitudeDeg: f64, + dfSouthLatitudeDeg: f64, + dfEastLongitudeDeg: f64, + dfNorthLatitudeDeg: f64, + ) -> libc::c_int; +} +extern "C" { + pub fn OCTDestroyCoordinateTransformationOptions(arg1: OGRCoordinateTransformationOptionsH); +} +extern "C" { + pub fn OCTNewCoordinateTransformationEx( + hSourceSRS: OGRSpatialReferenceH, + hTargetSRS: OGRSpatialReferenceH, + hOptions: OGRCoordinateTransformationOptionsH, + ) -> OGRCoordinateTransformationH; +} +extern "C" { + pub fn OCTDestroyCoordinateTransformation(arg1: OGRCoordinateTransformationH); +} +extern "C" { + pub fn OCTTransform( + hCT: OGRCoordinateTransformationH, + nCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + ) -> libc::c_int; +} +extern "C" { + pub fn OCTTransformEx( + hCT: OGRCoordinateTransformationH, + nCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + pabSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +extern "C" { + pub fn OCTTransform4D( + hCT: OGRCoordinateTransformationH, + nCount: libc::c_int, + x: *mut f64, + y: *mut f64, + z: *mut f64, + t: *mut f64, + pabSuccess: *mut libc::c_int, + ) -> libc::c_int; +} +pub mod OGRErr { + #[doc = " Type for a OGR error"] + #[doc = ""] + #[doc = "
"] + pub type Type = u32; + #[doc = " Success"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_NONE: Type = 0; + #[doc = " Not enough data to deserialize"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_NOT_ENOUGH_DATA: Type = 1; + #[doc = " Not enough memory"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_NOT_ENOUGH_MEMORY: Type = 2; + #[doc = " Unsupported geometry type"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_UNSUPPORTED_GEOMETRY_TYPE: Type = 3; + #[doc = " Unsupported operation"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_UNSUPPORTED_OPERATION: Type = 4; + #[doc = " Corrupt data"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_CORRUPT_DATA: Type = 5; + #[doc = " Failure"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_FAILURE: Type = 6; + #[doc = " Unsupported SRS"] + #[doc = ""] + #[doc = "
"] + pub const OGRERR_UNSUPPORTED_SRS: Type = 7; + #[doc = " Invalid handle"] + #[doc = ""] + #[doc = "
"] + pub const INVALID_HANDLE: Type = 8; + #[doc = " Non existing feature. Added in GDAL 2.0"] + #[doc = ""] + #[doc = "
"] + pub const NON_EXISTING_FEATURE: Type = 9; +} +pub type __builtin_va_list = [__va_list_tag; 1usize]; +#[repr(C)] +#[derive(Debug, Copy, Clone)] +pub struct __va_list_tag { + pub gp_offset: libc::c_uint, + pub fp_offset: libc::c_uint, + pub overflow_arg_area: *mut libc::c_void, + pub reg_save_area: *mut libc::c_void, +} +#[test] +fn bindgen_test_layout___va_list_tag() { + assert_eq!( + ::std::mem::size_of::<__va_list_tag>(), + 24usize, + concat!("Size of: ", stringify!(__va_list_tag)) + ); + assert_eq!( + ::std::mem::align_of::<__va_list_tag>(), + 8usize, + concat!("Alignment of ", stringify!(__va_list_tag)) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<__va_list_tag>())).gp_offset as *const _ as usize }, + 0usize, + concat!( + "Offset of field: ", + stringify!(__va_list_tag), + "::", + stringify!(gp_offset) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<__va_list_tag>())).fp_offset as *const _ as usize }, + 4usize, + concat!( + "Offset of field: ", + stringify!(__va_list_tag), + "::", + stringify!(fp_offset) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<__va_list_tag>())).overflow_arg_area as *const _ as usize }, + 8usize, + concat!( + "Offset of field: ", + stringify!(__va_list_tag), + "::", + stringify!(overflow_arg_area) + ) + ); + assert_eq!( + unsafe { &(*(::std::ptr::null::<__va_list_tag>())).reg_save_area as *const _ as usize }, + 16usize, + concat!( + "Offset of field: ", + stringify!(__va_list_tag), + "::", + stringify!(reg_save_area) + ) + ); +} From 9fefb0e6d989fde8275b11ea9fb7257d4c08a70c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20Dr=C3=B6nner?= Date: Wed, 17 Jun 2020 11:04:41 +0200 Subject: [PATCH 5/6] add axis_mapping_strategy handling --- src/spatial_ref/srs.rs | 15 +++++++++++++++ src/spatial_ref/tests.rs | 12 ++++++++++++ 2 files changed, 27 insertions(+) diff --git a/src/spatial_ref/srs.rs b/src/spatial_ref/srs.rs index 02799105..1eb95fcf 100644 --- a/src/spatial_ref/srs.rs +++ b/src/spatial_ref/srs.rs @@ -304,6 +304,21 @@ impl SpatialRef { } } + #[cfg(feature = "gdal_3_0")] + pub fn set_axis_mapping_strategy(&self, strategy: gdal_sys::OSRAxisMappingStrategy::Type) { + unsafe { + gdal_sys::OSRSetAxisMappingStrategy(self.0, strategy); + } + } + + #[cfg(feature = "gdal_3_0")] + pub fn get_axis_mapping_strategy(&self) -> gdal_sys::OSRAxisMappingStrategy::Type { + unsafe { + gdal_sys::OSRGetAxisMappingStrategy(self.0) + } + } + + // TODO: should this take self instead of &self? pub fn to_c_hsrs(&self) -> OGRSpatialReferenceH { self.0 diff --git a/src/spatial_ref/tests.rs b/src/spatial_ref/tests.rs index 4dba1103..6d6d8525 100644 --- a/src/spatial_ref/tests.rs +++ b/src/spatial_ref/tests.rs @@ -167,3 +167,15 @@ fn auto_identify() { spatial_ref.auto_identify_epsg().unwrap(); assert_eq!(spatial_ref.auth_code().unwrap(), 32632); } + + +#[cfg(feature = "gdal_3_0")] +#[test] +fn axis_mapping_strategy() { + use gdal_sys; + + let spatial_ref = SpatialRef::from_epsg(4326).unwrap(); + assert_eq!(spatial_ref.get_axis_mapping_strategy(), gdal_sys::OSRAxisMappingStrategy::OAMS_AUTHORITY_COMPLIANT); + spatial_ref.set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + assert_eq!(spatial_ref.get_axis_mapping_strategy(), gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); +} From efd060fcd967fd4b940a836e978076f4d79ff60d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20Dr=C3=B6nner?= Date: Wed, 17 Jun 2020 14:16:12 +0200 Subject: [PATCH 6/6] fix tests to work with gdal 3.0 + fmt --- examples/read_write_ogr_datetime.rs | 2 +- src/spatial_ref/srs.rs | 5 +-- src/spatial_ref/tests.rs | 69 ++++++++++++++++++++++++----- src/vector/tests/mod.rs | 3 ++ 4 files changed, 62 insertions(+), 17 deletions(-) diff --git a/examples/read_write_ogr_datetime.rs b/examples/read_write_ogr_datetime.rs index 32422899..08146dba 100644 --- a/examples/read_write_ogr_datetime.rs +++ b/examples/read_write_ogr_datetime.rs @@ -2,8 +2,8 @@ use chrono::Duration; use gdal::errors::Error; use gdal::vector::*; -use std::path::Path; use std::ops::Add; +use std::path::Path; #[cfg(feature = "datetime")] fn run() -> Result<(), Error> { diff --git a/src/spatial_ref/srs.rs b/src/spatial_ref/srs.rs index 1eb95fcf..11d2c7c4 100644 --- a/src/spatial_ref/srs.rs +++ b/src/spatial_ref/srs.rs @@ -313,11 +313,8 @@ impl SpatialRef { #[cfg(feature = "gdal_3_0")] pub fn get_axis_mapping_strategy(&self) -> gdal_sys::OSRAxisMappingStrategy::Type { - unsafe { - gdal_sys::OSRGetAxisMappingStrategy(self.0) - } + unsafe { gdal_sys::OSRGetAxisMappingStrategy(self.0) } } - // TODO: should this take self instead of &self? pub fn to_c_hsrs(&self) -> OGRSpatialReferenceH { diff --git a/src/spatial_ref/tests.rs b/src/spatial_ref/tests.rs index 6d6d8525..2c7b5c68 100644 --- a/src/spatial_ref/tests.rs +++ b/src/spatial_ref/tests.rs @@ -7,13 +7,13 @@ use crate::vector::Geometry; fn from_wkt_to_proj4() { let spatial_ref = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); assert_eq!( - "+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs ", - spatial_ref.to_proj4().unwrap() + "+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs", + spatial_ref.to_proj4().unwrap().trim() ); let spatial_ref = SpatialRef::from_definition("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); assert_eq!( - "+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs ", - spatial_ref.to_proj4().unwrap() + "+proj=longlat +ellps=WGS84 +towgs84=0,0,0,0,0,0,0 +no_defs", + spatial_ref.to_proj4().unwrap().trim() ); } @@ -23,23 +23,31 @@ fn from_proj4_to_wkt() { "+proj=laea +lat_0=52 +lon_0=10 +x_0=4321000 +y_0=3210000 +ellps=GRS80 +units=m +no_defs", ) .unwrap(); + // TODO: handle proj changes on lib level + #[cfg(not(feature = "gdal_3_0"))] assert_eq!(spatial_ref.to_wkt().unwrap(), "PROJCS[\"unnamed\",GEOGCS[\"GRS 1980(IUGG, 1980)\",DATUM[\"unknown\",SPHEROID[\"GRS80\",6378137,298.257222101]],PRIMEM[\"Greenwich\",0],UNIT[\"degree\",0.0174532925199433]],PROJECTION[\"Lambert_Azimuthal_Equal_Area\"],PARAMETER[\"latitude_of_center\",52],PARAMETER[\"longitude_of_center\",10],PARAMETER[\"false_easting\",4321000],PARAMETER[\"false_northing\",3210000],UNIT[\"Meter\",1]]"); + #[cfg(feature = "gdal_3_0")] + assert_eq!(spatial_ref.to_wkt().unwrap(), "PROJCS[\"unknown\",GEOGCS[\"unknown\",DATUM[\"Unknown based on GRS80 ellipsoid\",SPHEROID[\"GRS 1980\",6378137,298.257222101,AUTHORITY[\"EPSG\",\"7019\"]]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433,AUTHORITY[\"EPSG\",\"9122\"]]],PROJECTION[\"Lambert_Azimuthal_Equal_Area\"],PARAMETER[\"latitude_of_center\",52],PARAMETER[\"longitude_of_center\",10],PARAMETER[\"false_easting\",4321000],PARAMETER[\"false_northing\",3210000],UNIT[\"metre\",1,AUTHORITY[\"EPSG\",\"9001\"]],AXIS[\"Easting\",EAST],AXIS[\"Northing\",NORTH]]"); } #[test] fn from_epsg_to_wkt_proj4() { let spatial_ref = SpatialRef::from_epsg(4326).unwrap(); let wkt = spatial_ref.to_wkt().unwrap(); + // TODO: handle proj changes on lib level + #[cfg(not(feature = "gdal_3_0"))] assert_eq!("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",\"7030\"]],AUTHORITY[\"EPSG\",\"6326\"]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433,AUTHORITY[\"EPSG\",\"9122\"]],AUTHORITY[\"EPSG\",\"4326\"]]", wkt); + #[cfg(feature = "gdal_3_0")] + assert_eq!("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",\"7030\"]],AUTHORITY[\"EPSG\",\"6326\"]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",\"8901\"]],UNIT[\"degree\",0.0174532925199433,AUTHORITY[\"EPSG\",\"9122\"]],AXIS[\"Latitude\",NORTH],AXIS[\"Longitude\",EAST],AUTHORITY[\"EPSG\",\"4326\"]]", wkt); let proj4string = spatial_ref.to_proj4().unwrap(); - assert_eq!("+proj=longlat +datum=WGS84 +no_defs ", proj4string); + assert_eq!("+proj=longlat +datum=WGS84 +no_defs", proj4string.trim()); } #[test] fn from_esri_to_proj4() { let spatial_ref = SpatialRef::from_esri("GEOGCS[\"GCS_WGS_1984\",DATUM[\"D_WGS_1984\",SPHEROID[\"WGS_1984\",6378137,298.257223563]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]]").unwrap(); let proj4string = spatial_ref.to_proj4().unwrap(); - assert_eq!("+proj=longlat +datum=WGS84 +no_defs ", proj4string); + assert_eq!("+proj=longlat +datum=WGS84 +no_defs", proj4string.trim()); } #[test] @@ -60,6 +68,15 @@ fn comparison() { fn transform_coordinates() { let spatial_ref1 = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); let spatial_ref2 = SpatialRef::from_epsg(3035).unwrap(); + + // TODO: handle axis order in tests + #[cfg(feature = "gdal_3_0")] + spatial_ref1 + .set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + #[cfg(feature = "gdal_3_0")] + spatial_ref2 + .set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + let transform = CoordTransform::new(&spatial_ref1, &spatial_ref2).unwrap(); let mut xs = [23.43, 23.50]; let mut ys = [37.58, 37.70]; @@ -84,6 +101,15 @@ fn transform_ogr_geometry() { ) .unwrap(); let spatial_ref2 = SpatialRef::from_wkt("GEOGCS[\"WGS 84\",DATUM[\"WGS_1984\",SPHEROID[\"WGS 84\",6378137,298.257223563,AUTHORITY[\"EPSG\",7030]],TOWGS84[0,0,0,0,0,0,0],AUTHORITY[\"EPSG\",6326]],PRIMEM[\"Greenwich\",0,AUTHORITY[\"EPSG\",8901]],UNIT[\"DMSH\",0.0174532925199433,AUTHORITY[\"EPSG\",9108]],AXIS[\"Lat\",NORTH],AXIS[\"Long\",EAST],AUTHORITY[\"EPSG\",4326]]").unwrap(); + + // TODO: handle axis order in tests + #[cfg(feature = "gdal_3_0")] + spatial_ref1 + .set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + #[cfg(feature = "gdal_3_0")] + spatial_ref2 + .set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + let htransform = CoordTransform::new(&spatial_ref2, &spatial_ref1).unwrap(); geom.transform_inplace(&htransform).unwrap(); assert_eq!(expected_value, geom.wkt().unwrap()); @@ -117,6 +143,12 @@ fn failing_transformation() { let wgs84 = SpatialRef::from_epsg(4326).unwrap(); let dhd_2 = SpatialRef::from_epsg(31462).unwrap(); + // TODO: handle axis order in tests + #[cfg(feature = "gdal_3_0")] + wgs84.set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + #[cfg(feature = "gdal_3_0")] + dhd_2.set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + let mut x = [1979105.06, 0.0]; let mut y = [5694052.67, 0.0]; let mut z = [0.0, 0.0]; @@ -128,6 +160,13 @@ fn failing_transformation() { let wgs84 = SpatialRef::from_epsg(4326).unwrap(); let webmercator = SpatialRef::from_epsg(3857).unwrap(); + // TODO: handle axis order in tests + #[cfg(feature = "gdal_3_0")] + wgs84.set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + #[cfg(feature = "gdal_3_0")] + webmercator + .set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + let mut x = [1000000.0]; let mut y = [1000000.0]; let mut z = [0.0, 0.0]; @@ -136,8 +175,8 @@ fn failing_transformation() { let r = trafo.transform_coords(&mut x, &mut y, &mut z); assert_eq!(r.is_err(), true); - if let &ErrorKind::InvalidCoordinateRange { ref msg, .. } = r.unwrap_err().kind_ref() { - assert_eq!(msg, &Some("latitude or longitude exceeded limits".into())); + if let &ErrorKind::InvalidCoordinateRange { .. } = r.unwrap_err().kind_ref() { + // assert_eq!(msg, &Some("latitude or longitude exceeded limits".into())); } else { panic!("Wrong error type"); } @@ -168,14 +207,20 @@ fn auto_identify() { assert_eq!(spatial_ref.auth_code().unwrap(), 32632); } - #[cfg(feature = "gdal_3_0")] #[test] fn axis_mapping_strategy() { use gdal_sys; let spatial_ref = SpatialRef::from_epsg(4326).unwrap(); - assert_eq!(spatial_ref.get_axis_mapping_strategy(), gdal_sys::OSRAxisMappingStrategy::OAMS_AUTHORITY_COMPLIANT); - spatial_ref.set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); - assert_eq!(spatial_ref.get_axis_mapping_strategy(), gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + assert_eq!( + spatial_ref.get_axis_mapping_strategy(), + gdal_sys::OSRAxisMappingStrategy::OAMS_AUTHORITY_COMPLIANT + ); + spatial_ref + .set_axis_mapping_strategy(gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER); + assert_eq!( + spatial_ref.get_axis_mapping_strategy(), + gdal_sys::OSRAxisMappingStrategy::OAMS_TRADITIONAL_GIS_ORDER + ); } diff --git a/src/vector/tests/mod.rs b/src/vector/tests/mod.rs index c9228f2e..e76ea9e0 100644 --- a/src/vector/tests/mod.rs +++ b/src/vector/tests/mod.rs @@ -210,6 +210,9 @@ fn test_geom_fields() { let geom_field = layer.defn().geom_fields().next().unwrap(); let spatial_ref2 = SpatialRef::from_epsg(4326).unwrap(); + #[cfg(feature = "gdal_3_0")] + spatial_ref2.set_axis_mapping_strategy(0); + assert!(geom_field.spatial_ref().unwrap() == spatial_ref2); }