use std::ffi::c_char;
use crate::ffi_apis::common::from_json_string;
use crate::ffi_apis::common::to_json_string;
use crate::symbolic::core::Expr;
use crate::symbolic::series::analytic_continuation;
use crate::symbolic::series::analyze_convergence;
use crate::symbolic::series::asymptotic_expansion;
use crate::symbolic::series::fourier_series;
use crate::symbolic::series::laurent_series;
use crate::symbolic::series::product;
use crate::symbolic::series::summation;
use crate::symbolic::series::taylor_series;
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_taylor_series(
expr_json: *const c_char,
var_json: *const c_char,
center_json: *const c_char,
order_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let center: Option<Expr> = from_json_string(center_json);
let order: Option<usize> = from_json_string(order_json);
match (expr, var, center, order) {
| (Some(e), Some(v), Some(c), Some(o)) => {
let result = taylor_series(&e, &v, &c, o);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_laurent_series(
expr_json: *const c_char,
var_json: *const c_char,
center_json: *const c_char,
order_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let center: Option<Expr> = from_json_string(center_json);
let order: Option<usize> = from_json_string(order_json);
match (expr, var, center, order) {
| (Some(e), Some(v), Some(c), Some(o)) => {
let result = laurent_series(&e, &v, &c, o);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_fourier_series(
expr_json: *const c_char,
var_json: *const c_char,
period_json: *const c_char,
order_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let period: Option<Expr> = from_json_string(period_json);
let order: Option<usize> = from_json_string(order_json);
match (expr, var, period, order) {
| (Some(e), Some(v), Some(p), Some(o)) => {
let result = fourier_series(&e, &v, &p, o);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_summation(
expr_json: *const c_char,
var_json: *const c_char,
lower_json: *const c_char,
upper_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let lower: Option<Expr> = from_json_string(lower_json);
let upper: Option<Expr> = from_json_string(upper_json);
match (expr, var, lower, upper) {
| (Some(e), Some(v), Some(l), Some(u)) => {
let result = summation(&e, &v, &l, &u);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_product(
expr_json: *const c_char,
var_json: *const c_char,
lower_json: *const c_char,
upper_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let lower: Option<Expr> = from_json_string(lower_json);
let upper: Option<Expr> = from_json_string(upper_json);
match (expr, var, lower, upper) {
| (Some(e), Some(v), Some(l), Some(u)) => {
let result = product(&e, &v, &l, &u);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_series_json_analyze_convergence(
series_json: *const c_char,
var_json: *const c_char,
) -> *mut c_char {
let series: Option<Expr> = from_json_string(series_json);
let var: Option<String> = from_json_string(var_json);
match (series, var) {
| (Some(s), Some(v)) => {
let result = analyze_convergence(&s, &v);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_asymptotic_expansion(
expr_json: *const c_char,
var_json: *const c_char,
point_json: *const c_char,
order_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let point: Option<Expr> = from_json_string(point_json);
let order: Option<usize> = from_json_string(order_json);
match (expr, var, point, order) {
| (Some(e), Some(v), Some(p), Some(o)) => {
let result = asymptotic_expansion(&e, &v, &p, o);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_json_analytic_continuation(
expr_json: *const c_char,
var_json: *const c_char,
orig_center_json: *const c_char,
new_center_json: *const c_char,
order_json: *const c_char,
) -> *mut c_char {
let expr: Option<Expr> = from_json_string(expr_json);
let var: Option<String> = from_json_string(var_json);
let orig_center: Option<Expr> = from_json_string(orig_center_json);
let new_center: Option<Expr> = from_json_string(new_center_json);
let order: Option<usize> = from_json_string(order_json);
match (expr, var, orig_center, new_center, order) {
| (Some(e), Some(v), Some(oc), Some(nc), Some(o)) => {
let result = analytic_continuation(&e, &v, &oc, &nc, o);
to_json_string(&result)
},
| _ => std::ptr::null_mut(),
}
}