Skip to content

Commit

Permalink
minor tweaks
Browse files Browse the repository at this point in the history
  • Loading branch information
alfanick committed Dec 21, 2016
1 parent 214da13 commit fe75707
Showing 1 changed file with 5 additions and 5 deletions.
10 changes: 5 additions & 5 deletions src/evaluator.rs
Original file line number Diff line number Diff line change
Expand Up @@ -341,7 +341,7 @@ impl Evaluator {
/// assert_eq!(result.unwrap_err(), EvaluationError::ConflictingName(String::from("foo")));
/// ```
pub fn register_function(&mut self, name: &str, function: Function) -> Result<Option<Function>, EvaluationError> {
if let Some(_) = self.constants.get(name) {
if self.constants.contains_key(name) {
return Err(EvaluationError::ConflictingName(name.to_string()));
}

Expand Down Expand Up @@ -401,7 +401,7 @@ impl Evaluator {
/// assert_eq!(result.unwrap_err(), EvaluationError::ConflictingName(String::from("foo")));
/// ```
pub fn register_constant(&mut self, name: &str, constant: Polynomial) -> Result<Option<Polynomial>, EvaluationError> {
if let Some(_) = self.functions.get(name) {
if self.functions.contains_key(name) {
return Err(EvaluationError::ConflictingName(name.to_string()));
}

Expand All @@ -411,13 +411,13 @@ impl Evaluator {
#[inline(always)]
fn call_function(&self, name: &str, position: usize, stack: &mut Vec<Polynomial>) -> Result<Polynomial, EvaluationError> {
if let Some(function) = self.functions.get(name) {
if stack.len() < function.arity {
Err(EvaluationError::ArgumentMissing(name.to_owned(), function.arity, position))
} else {
if stack.len() >= function.arity {
let stack_len = stack.len();
let args: Vec<Polynomial> = stack.split_off(stack_len - function.arity);

(function.handle)(args)
} else {
Err(EvaluationError::ArgumentMissing(name.to_owned(), function.arity, position))
}
} else {
Err(EvaluationError::UnknownSymbol(name.to_owned(), position))
Expand Down

0 comments on commit fe75707

Please sign in to comment.