summaryrefslogtreecommitdiff
path: root/modules/atoms/macros/atoms_internals/atomsGetInstalledDetails.sci
blob: 03212f2684b91afbbab66ade3be607333f18187e (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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
// Copyright (C) 2009 - DIGITEO - Pierre MARECHAL <pierre.marechal@scilab.org>
//
// 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

// Internal function

// Renvoie les détails sur l'installation d'un package.

function res = atomsGetInstalledDetails(packages,section)

    rhs = argn(2);
    res = [];

    // Check number of input arguments
    // =========================================================================

    if rhs < 1 | rhs > 2 then
        error(msprintf(gettext("%s: Wrong number of input argument: %d to %d expected.\n"),"atomsGetInstalledDetails",1,2));
    end

    // Check input parameters type
    // =========================================================================

    if type(packages) <> 10 then
        error(msprintf(gettext("%s: Wrong type for input argument #%d: Single string expected.\n"),"atomsGetInstalledDetails",1));
    end

    if and(size(packages(1,:),"*") <> [2 3]) then
        error(msprintf(gettext("%s: Wrong size for input argument #%d: mx2 or mx3 string matrix expected.\n"),"atomsGetInstalledDetails",1));
    end

    // Allusers/user management
    // =========================================================================

    if rhs < 2 then
        section = "all";

    else

        // Process the 2nd input argument : section
        // Allusers can be a boolean or equal to "user" or "allusers"

        if type(section) <> 10 then
            error(msprintf(gettext("%s: Wrong type for input argument #%d: Boolean or single string expected.\n"),"atomsGetInstalledDetails",2));
        end

        if and(section<>["user","allusers","all"]) then
            error(msprintf(gettext("%s: Wrong value for input argument #%d: ''user'' or ''allusers'' or ''all'' expected.\n"),"atomsGetInstalledDetails",2));
        end

    end

    // Complete packages matrix with empty columns
    // =========================================================================

    if size(packages(1,:),"*") == 2 then
        packages = [ packages emptystr(size(packages(:,1),"*"),1) ];
    end

    // Get the list of installed packages
    // =========================================================================
    installedpackages = atomsGetInstalled(section);

    // Loop on name
    // =========================================================================

    for i=1:size(packages(:,1),"*")

        // Filter on names
        packages_filtered = installedpackages( find(installedpackages(:,1) == packages(i,1)) , : );

        // Filter on section
        if ~isempty(packages(i,3)) & packages(i,3)<>"all" then
            packages_filtered = packages_filtered( find(packages_filtered(:,3) == packages(i,3)) , : );
        end

        // Filter on versions

        //  + The packaging version is mentioned
        if ~ isempty(strindex(packages(i,2),"-")) then
            packages_filtered = packages_filtered( find(packages_filtered(:,2) == packages(i,2)) , : );

            //  + The packaging version is not mentioned
        else

            candidates        = packages_filtered;
            packages_filtered = [];

            // Loop on installed versions
            for j=1:size(candidates(:,2),"*")

                candidate_version = candidates(j,2);

                if ~ isempty(strindex(candidate_version,"-")) then
                    candidate_version = part(candidate_version,1:strindex(candidate_version,"-")-1);
                end

                if packages(i,2) == candidate_version then
                    packages_filtered = [ packages_filtered ; candidates(j,:) ];
                end

            end

        end

        if ~ isempty(packages_filtered) then
            res = [ res ; packages_filtered(1,:) ];
        else
            res = [ res ; "" "" "" "" "" ];
        end

    end

endfunction