File: sci_strcmpi.sci

package info (click to toggle)
scilab 4.0-12
  • links: PTS
  • area: non-free
  • in suites: etch, etch-m68k
  • size: 100,640 kB
  • ctags: 57,333
  • sloc: ansic: 377,889; fortran: 242,862; xml: 179,819; tcl: 42,062; sh: 10,593; ml: 9,441; makefile: 4,377; cpp: 1,354; java: 621; csh: 260; yacc: 247; perl: 130; lex: 126; asm: 72; lisp: 30
file content (26 lines) | stat: -rw-r--r-- 784 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
function [tree]=sci_strcmpi(tree)
// Copyright INRIA
// M2SCI function
// Conversion function for Matlab strcmpi()
// Input: tree = Matlab funcall tree
// Ouput: tree = Scilab equivalent for tree
// Emulation function: mtlb_strcmpi()
// V.C.

[A,B] = getrhs(tree)

if A.vtype==String & B.vtype==String then
  A = Funcall("convstr",1,Rhs(A),list())
  B = Funcall("convstr",1,Rhs(B),list())
  tree = Operation("==",list(A,B),tree.lhs)
  tree.out(1).dims=list(1,1)
  tree.out(1).type=Type(Boolean,Real)
elseif A.vtype<>Unknown & B.vtype<>Unknown then
  // At least one argument is not a character string matrix in call of strcmpi() so result is set to 0
  tree = Cste(%F)
else
  tree.name="mtlb_strcmpi"
  tree.lhs(1).dims=list(1,1)
  tree.lhs(1).type=Type(Boolean,Real)
end
endfunction