version 1.1, 2015/06/29 15:42:13
|
version 1.3, 2023/03/13 22:31:22
|
Line 1
|
Line 1
|
# The LearningOnline Network with CAPA - LON-CAPA |
# The LearningOnline Network with CAPA - LON-CAPA |
# Parser |
# Parser |
# |
# |
|
# $Id$ |
|
# |
# Copyright (C) 2014 Michigan State University Board of Trustees |
# Copyright (C) 2014 Michigan State University Board of Trustees |
# |
# |
# This program is free software: you can redistribute it and/or modify |
# This program is free software: you can redistribute it and/or modify |
Line 39 use aliased 'Apache::math_parser::Tokeni
|
Line 41 use aliased 'Apache::math_parser::Tokeni
|
# @optional {boolean} unit_mode - handle only numerical expressions with units (no variable) |
# @optional {boolean} unit_mode - handle only numerical expressions with units (no variable) |
## |
## |
sub new { |
sub new { |
my $class = shift; |
my ($class, $implicit_operators, $unit_mode) = @_; |
|
if (!defined $implicit_operators) { |
|
$implicit_operators = 0; |
|
} |
|
if (!defined $unit_mode) { |
|
$unit_mode = 0; |
|
} |
my $self = { |
my $self = { |
_implicit_operators => shift // 0, |
_implicit_operators => $implicit_operators, |
_unit_mode => shift // 0, |
_unit_mode => $unit_mode, |
_defs => Definitions->new(), |
_defs => Definitions->new(), |
}; |
}; |
$self->{_defs}->define(); |
$self->{_defs}->define(); |
Line 200 sub addHiddenOperators {
|
Line 208 sub addHiddenOperators {
|
($token_type == Token->NAME && $next_token_type == Token->NAME) || |
($token_type == Token->NAME && $next_token_type == Token->NAME) || |
($token_type == Token->NUMBER && $next_token_type == Token->NAME) || |
($token_type == Token->NUMBER && $next_token_type == Token->NAME) || |
($token_type == Token->NUMBER && $next_token_type == Token->NUMBER) || |
($token_type == Token->NUMBER && $next_token_type == Token->NUMBER) || |
($token_type == Token->NUMBER && $next_token_value ~~ ["(","[","{"]) || |
($token_type == Token->NUMBER && string_in_array(["(","[","{"], $next_token_value)) || |
# ($token_type == Token->NAME && $next_token_value eq "(") || |
# ($token_type == Token->NAME && $next_token_value eq "(") || |
# name ( could be a function call |
# name ( could be a function call |
($token_value ~~ [")","]","}"] && $next_token_type == Token->NAME) || |
(string_in_array([")","]","}"], $token_value) && $next_token_type == Token->NAME) || |
($token_value ~~ [")","]","}"] && $next_token_type == Token->NUMBER) || |
(string_in_array([")","]","}"], $token_value) && $next_token_type == Token->NUMBER) || |
($token_value ~~ [")","]","}"] && $next_token_value eq "(") |
(string_in_array([")","]","}"], $token_value) && $next_token_value eq "(") |
) { |
) { |
# support for things like "(1/2) (m/s)" is complex... |
# support for things like "(1/2) (m/s)" is complex... |
my $units = ($self->unit_mode && !$in_units && |
my $units = ($self->unit_mode && !$in_units && |
($token_type == Token->NUMBER || $token_value ~~ [")","]","}"]) && |
($token_type == Token->NUMBER || string_in_array([")","]","}"], $token_value)) && |
($next_token_type == Token->NAME || |
($next_token_type == Token->NAME || |
($next_token_value ~~ ["(","[","{"] && scalar(@{$self->tokens}) > $i + 2 && |
(string_in_array(["(","[","{"], $next_token_value) && scalar(@{$self->tokens}) > $i + 2 && |
$self->tokens->[$i + 2]->type == Token->NAME))); |
$self->tokens->[$i + 2]->type == Token->NAME))); |
if ($units) { |
if ($units) { |
my( $test_token, $index_test); |
my( $test_token, $index_test); |
Line 276 sub parse {
|
Line 284 sub parse {
|
return $root; |
return $root; |
} |
} |
|
|
|
## |
|
# Tests if a string is in an array (using eq) (to avoid using $value ~~ @array) |
|
# @param {Array<string>} array - reference to the array of strings |
|
# @param {string} value - the string to look for |
|
# @returns 1 if found, 0 otherwise |
|
## |
|
sub string_in_array { |
|
my ($array, $value) = @_; |
|
foreach my $v (@{$array}) { |
|
if ($v eq $value) { |
|
return 1; |
|
} |
|
} |
|
return 0; |
|
} |
|
|
1; |
1; |
__END__ |
__END__ |