nu_cmd_extra/extra/math/
arcsinh.rs

1use nu_engine::command_prelude::*;
2
3#[derive(Clone)]
4pub struct MathArcSinH;
5
6impl Command for MathArcSinH {
7    fn name(&self) -> &str {
8        "math arcsinh"
9    }
10
11    fn signature(&self) -> Signature {
12        Signature::build("math arcsinh")
13            .input_output_types(vec![
14                (Type::Number, Type::Float),
15                (
16                    Type::List(Box::new(Type::Number)),
17                    Type::List(Box::new(Type::Float)),
18                ),
19            ])
20            .allow_variants_without_examples(true)
21            .category(Category::Math)
22    }
23
24    fn description(&self) -> &str {
25        "Returns the inverse of the hyperbolic sine function."
26    }
27
28    fn search_terms(&self) -> Vec<&str> {
29        vec!["trigonometry", "inverse", "hyperbolic"]
30    }
31
32    fn run(
33        &self,
34        engine_state: &EngineState,
35        _stack: &mut Stack,
36        call: &Call,
37        input: PipelineData,
38    ) -> Result<PipelineData, ShellError> {
39        let head = call.head;
40        // This doesn't match explicit nulls
41        if let PipelineData::Empty = input {
42            return Err(ShellError::PipelineEmpty { dst_span: head });
43        }
44        input.map(move |value| operate(value, head), engine_state.signals())
45    }
46
47    fn examples(&self) -> Vec<Example<'_>> {
48        vec![Example {
49            description: "Get the arcsinh of 0",
50            example: "0 | math arcsinh",
51            result: Some(Value::test_float(0.0f64)),
52        }]
53    }
54}
55
56fn operate(value: Value, head: Span) -> Value {
57    match value {
58        numeric @ (Value::Int { .. } | Value::Float { .. }) => {
59            let span = numeric.span();
60            let (val, span) = match numeric {
61                Value::Int { val, .. } => (val as f64, span),
62                Value::Float { val, .. } => (val, span),
63                _ => unreachable!(),
64            };
65
66            let val = val.asinh();
67
68            Value::float(val, span)
69        }
70        Value::Error { .. } => value,
71        other => Value::error(
72            ShellError::OnlySupportsThisInputType {
73                exp_input_type: "numeric".into(),
74                wrong_type: other.get_type().to_string(),
75                dst_span: head,
76                src_span: other.span(),
77            },
78            head,
79        ),
80    }
81}
82
83#[cfg(test)]
84mod test {
85    use super::*;
86
87    #[test]
88    fn test_examples() {
89        use crate::test_examples;
90
91        test_examples(MathArcSinH {})
92    }
93}