File: cProjectDependecySorter.h

package info (click to toggle)
codelite 17.0.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 136,204 kB
  • sloc: cpp: 491,547; ansic: 280,393; php: 10,259; sh: 8,930; lisp: 7,664; vhdl: 6,518; python: 6,020; lex: 4,920; yacc: 3,123; perl: 2,385; javascript: 1,715; cs: 1,193; xml: 1,110; makefile: 804; cobol: 741; sql: 709; ruby: 620; f90: 566; ada: 534; asm: 464; fortran: 350; objc: 289; tcl: 258; java: 157; erlang: 61; pascal: 51; ml: 49; awk: 44; haskell: 36
file content (42 lines) | stat: -rw-r--r-- 1,211 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
30
31
32
33
34
35
36
37
38
39
40
41
42
#ifndef CPROJECTDEPENDECYSORTER_H
#define CPROJECTDEPENDECYSORTER_H

#include "cl_exception.h"
#include "codelite_exports.h"

#include <unordered_map>
#include <vector>
#include <wx/arrstr.h>

class WXDLLIMPEXP_SDK clProjectDependecySorter
{
    enum eVisit { kNone, kTemp, kPerm };
    struct Node {
        eVisit marker;
        wxString name;
        std::vector<Node*> adjacents;
        Node()
            : marker(kNone)
        {
        }
    };
    typedef std::unordered_map<std::string, clProjectDependecySorter::Node> Graph_t;

protected:
    void Visit(clProjectDependecySorter::Node* node, wxArrayString& buildOrder);
    clProjectDependecySorter::Node* GetNodeCreateIfNeeded(Graph_t& G, const wxString& name);

public:
    clProjectDependecySorter();
    virtual ~clProjectDependecySorter();

    /**
     * @brief return the build order for a given project taking its dependencies into consideration
     * @param projectName
     * @param buildOrder [output]
     * @return the build order. Throws clException in case of an error
     */
    void GetProjectBuildOrder(const wxString& projectName, const wxString& configName, wxArrayString& buildOrder);
};

#endif // CPROJECTDEPENDECYSORTER_H