File: sci_nargout.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 (29 lines) | stat: -rw-r--r-- 979 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
27
28
29
function [tree]=sci_nargout(tree)
// File generated from sci_PROTO15.g: PLEASE DO NOT EDIT !
// Copyright INRIA
// M2SCI function
// Conversion function for Matlab nargout()
// Input: tree = Matlab funcall tree
// Ouput: tree = Scilab equivalent for tree
// V.C.

global("varslist")

if rhs==0 then // Number of arguments of local function
  tree=Variable("%nargout",Infer(list(1,1),Type(Double,Real)))
  varslist($+1)=M2scivar("nargout","%nargout",Infer(list(1,1),Type(Double,Real)))
else // Number of arguments of M-file
  if "nargout"=="nargin" then
    fieldnb=1
  else
    fieldnb=2
  end
  set_infos(rhs2code(tree.rhs)+" considered to be a Scilab macro.",2);
  evstrtree=Funcall("evstr",1,tree.rhs,list())
  macrovartree=Funcall("macrovar",1,Rhs(evstrtree),list())
  getfieldtree=Funcall("getfield",1,Rhs(fieldnb,macrovartree),list())
  tree=Funcall("size",1,Rhs(getfieldtree,"*"),tree.lhs)
  tree.lhs(1).dims=list(1,1)
  tree.lhs(1).type=Type(Double,Real)
end
endfunction