#![allow(missing_docs, non_camel_case_types, dead_code)]
use core::ffi::{c_void, c_int, c_char, c_uint};
#[doc = "R_xlen_t is defined as int on 32-bit platforms, and\n that confuses Rust. Keeping it always as ptrdiff_t works\n fine even on 32-bit.\n <div rustbindgen replaces=\"R_xlen_t\"></div>"]
pub type R_xlen_t = isize;
#[cfg_attr(doc,doc(cfg(feature = "register-routines")))]
#[cfg(any(doc, feature = "register-routines"))]
pub type DL_FUNC = *const c_void;
#[repr(C)]
#[cfg_attr(doc,doc(cfg(feature = "register-routines")))]
#[cfg(any(doc, feature = "register-routines"))]
pub struct R_CallMethodDef {
pub name: *const c_char,
pub fun: DL_FUNC,
pub numArgs: c_int,
}
#[repr(C)]
#[derive(Copy, Clone)]
pub struct SEXPREC([u8; 0]);
#[repr(C)]
pub struct DllInfo([u8; 0]);
pub type SEXP = *mut SEXPREC;
#[doc = "NOT YET using enum:\n 1)\tThe internal SEXPREC struct has 'SEXPTYPE type : 5'\n\t(making FUNSXP and CLOSXP equivalent in there),\n\tgiving (-Wall only ?) warnings all over the place\n 2)\tMany switch(type) { case ... } statements need a final `default:'\n\tadded in order to avoid warnings like [e.g. l.170 of ../main/util.c]\n\t \"enumeration value `FUNSXP' not handled in switch\""]
pub type SEXPTYPE = c_uint;
pub type cetype_t = u32;
#[allow(non_upper_case_globals)]
pub const cetype_t_CE_UTF8: u32 = 1;
#[link(name = "R", kind = "dylib")]
extern "C-unwind" {
pub fn Rf_errorcall(call:SEXP, error: *const c_char, ...) -> !; pub fn Rf_mkCharLenCE(
data: *const c_char,
len: c_int,
enc: cetype_t,
) -> SEXP; }
#[link(name = "R", kind = "dylib")]
extern "C" {
#[cfg_attr(doc,doc(cfg(feature = "register-routines")))]
#[cfg(any(doc, feature = "register-routines"))]
pub fn R_registerRoutines(
info: *mut DllInfo,
croutines: *const c_void,
callRoutines: *const R_CallMethodDef,
fortranRoutines: *const c_void,
externalRoutines: *const c_void
) -> c_int;
#[cfg_attr(doc,doc(cfg(feature = "register-routines")))]
#[cfg(any(doc, feature = "register-routines"))]
pub fn R_useDynamicSymbols(dll:*mut DllInfo, flag:c_uint)->c_uint;
#[cfg_attr(doc,doc(cfg(feature = "register-routines")))]
#[cfg(any(doc, feature = "register-routines"))]
pub fn R_forceSymbols(dll:*mut DllInfo, flag:c_uint)->c_uint;
pub static mut R_CurrentExpression: SEXP;
#[doc = "These are the public inlinable functions that are provided in\nRinlinedfuns.h It is *essential* that these do not appear in any\nother header file, with or without the Rf_ prefix."]
pub fn Rf_allocVector(arg1: SEXPTYPE, arg2: R_xlen_t) -> SEXP;
pub fn Rf_protect(arg1: SEXP) -> SEXP;
pub fn Rf_unprotect_ptr(arg1: SEXP);
#[cfg_attr(doc, doc(cfg(not(have_std))))] #[cfg(not(have_std))]
pub fn R_chk_calloc(count: usize, size_and_align: usize) -> *mut c_void;
#[cfg_attr(doc, doc(cfg(not(have_std))))] #[cfg(not(have_std))]
pub fn R_chk_realloc(ptr: *mut c_void, new_size: usize) -> *mut c_void;
#[cfg_attr(doc, doc(cfg(not(have_std))))] #[cfg(not(have_std))]
pub fn R_chk_free(ptr: *mut c_void);
#[cfg_attr(doc, doc(cfg(not(have_std))))] #[cfg(not(have_std))]
pub fn Rprintf(arg1: *const c_char, ...);
pub fn Rf_xlength(arg1: SEXP) -> R_xlen_t;
pub fn MISSING(x: SEXP) -> c_int;
pub fn DATAPTR_RO(x: SEXP) -> *const c_void;
pub fn DATAPTR(x: SEXP) -> *mut c_void;
pub fn TYPEOF(x: SEXP) -> SEXPTYPE;
pub static mut R_NilValue:SEXP;
}