summaryrefslogtreecommitdiff
path: root/modules/overloading/macros/%b_i_s.sci
blob: 26ae99ecb059023dca5d0647c1c3837427d53449 (plain)
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
30
31
32
33
34
35
// Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
// Copyright (C) INRIA
//
// This file must be used under the terms of the CeCILL.
// This source file is licensed as described in the file COPYING, which
// you should have received as part of this distribution.  The terms
// are also available at
// http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
function M=%b_i_s(varargin)


    [lhs,rhs]=argn(0)
    M=varargin(rhs)
    //if M<>[] then M=M<>0,end
    N=varargin(rhs-1)//inserted matrix
    index=varargin(1) //

    if rhs==3&(type(index)==10|type(index)==15) then
        M=createstruct(index,N)
        if type(index(1))<>10 & index(2)=="entries" then
            // change struct to cell
            f=getfield(1,M);f(1)="ce"
            setfield(1,f,M)
        end
    elseif rhs>4 then //more than 2 indices: insertion of a boolean in a matrix of numbers
        M=varargin($)
        if M<>[] then varargin($-1)=bool2s(varargin($-1)),end
        M=mlist(["hm","dims","entries"],int32(size(M)),M(:))
        varargin($)=M;
        M=generic_i_hm(%f,varargin(:))
    else //type conversion
        M=varargin($)
        M(varargin(1:$-2))=bool2s(varargin($-1))
    end
endfunction