use crate::error::XcError;
use crate::families::XcEval;
use crate::func::FunctionalId;
mod gga_c_lyp;
mod gga_c_pbe;
mod gga_c_pbe_sol;
mod gga_x_b88;
mod gga_x_pbe;
mod gga_x_pbe_r;
mod gga_x_pbe_sol;
mod gga_x_rpbe;
mod hybrids;
mod lda_c_pw;
mod lda_c_vwn;
mod lda_c_vwn_3;
mod lda_c_vwn_rpa;
mod lda_x;
mod mgga_c_m06_l;
mod mgga_c_r2scan;
mod mgga_c_tpss;
mod mgga_x_m06_l;
mod mgga_x_r2scan;
mod mgga_x_tpss;
pub(crate) fn build(id: FunctionalId) -> Result<Box<dyn XcEval>, XcError> {
use FunctionalId::*;
match id {
LdaX => Ok(lda_x::LdaX::boxed()),
LdaCPw => Ok(lda_c_pw::LdaCPw::boxed()),
LdaCVwn => Ok(lda_c_vwn::LdaCVwn::boxed()),
LdaCVwn3 => Ok(lda_c_vwn_3::LdaCVwn3::boxed()),
LdaCVwnRpa => Ok(lda_c_vwn_rpa::LdaCVwnRpa::boxed()),
GgaXPbe => Ok(gga_x_pbe::GgaXPbe::boxed()),
GgaXB88 => Ok(gga_x_b88::GgaXB88::boxed()),
GgaCPbe => Ok(gga_c_pbe::GgaCPbe::boxed()),
GgaCLyp => Ok(gga_c_lyp::GgaCLyp::boxed()),
GgaXPbeR => Ok(gga_x_pbe_r::GgaXPbeR::boxed()),
GgaXPbeSol => Ok(gga_x_pbe_sol::GgaXPbeSol::boxed()),
GgaXRpbe => Ok(gga_x_rpbe::GgaXRpbe::boxed()),
GgaCPbeSol => Ok(gga_c_pbe_sol::GgaCPbeSol::boxed()),
MggaXTpss => Ok(mgga_x_tpss::MggaXTpss::boxed()),
MggaCTpss => Ok(mgga_c_tpss::MggaCTpss::boxed()),
MggaXR2scan => Ok(mgga_x_r2scan::MggaXR2scan::boxed()),
MggaCR2scan => Ok(mgga_c_r2scan::MggaCR2scan::boxed()),
MggaXM06L => Ok(mgga_x_m06_l::MggaXM06L::boxed()),
MggaCM06L => Ok(mgga_c_m06_l::MggaCM06L::boxed()),
HybGgaXcPbeh => hybrids::pbeh(),
HybGgaXcB3lyp5 => hybrids::b3lyp5(),
HybGgaXcB3lyp => hybrids::b3lyp(),
}
}