File: kigit_pcb_merge.h

package info (click to toggle)
kicad 9.0.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 770,320 kB
  • sloc: cpp: 961,692; ansic: 121,001; xml: 66,428; python: 18,387; sh: 1,010; awk: 301; asm: 292; makefile: 227; javascript: 167; perl: 10
file content (85 lines) | stat: -rw-r--r-- 2,686 bytes parent folder | download | duplicates (3)
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
/*
 * This program source code file is part of KiCad, a free EDA CAD application.
 *
 * Copyright The KiCad Developers, see AUTHORS.TXT for contributors.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 3
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, you may find one here:
 * http://www.gnu.org/licenses/gpl-3.0.html
 * or you may search the http://www.gnu.org website for the version 3 license,
 * or you may write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
 */

#ifndef KIGIT_PCB_MERGE_H
#define KIGIT_PCB_MERGE_H
#include <git2.h>
#include <git2/sys/merge.h>

#include <memory>
#include <wx/string.h>

#include <board.h>

typedef struct KIGIT_PCB_MERGE_DIFFERENCES
{
    std::vector<BOARD_ITEM*> m_added;
    std::vector<BOARD_ITEM*> m_removed;
    std::vector<BOARD_ITEM*> m_changed;
} KIGIT_PCB_MERGE_DIFFERENCES;

class KIGIT_PCB_MERGE
{
    public:
        KIGIT_PCB_MERGE( git_merge_driver_source* aSource, git_buf* aBuf ) : m_mergeDriver( aSource ), m_result( aBuf )
        {}

        virtual ~KIGIT_PCB_MERGE();

        int Merge();

        std::set<BOARD_ITEM*>& GetWeModifiedTheyDeleted()
        {
            return we_modified_they_deleted;
        }

        std::set<BOARD_ITEM*>& GetTheyModifiedWeDeleted()
        {
            return they_modified_we_deleted;
        }

        std::set<BOARD_ITEM*>& GetBothModified()
        {
            return both_modified;
        }

    protected:
        std::unique_ptr<BOARD> readBoard( wxString& aFilename );
        KIGIT_PCB_MERGE_DIFFERENCES compareBoards( BOARD* aAncestor, BOARD* aOther );
        void findSetDifferences( const BOARD_ITEM_SET& aAncestorSet, const BOARD_ITEM_SET& aOtherSet,
                                 std::vector<BOARD_ITEM*>& aAdded, std::vector<BOARD_ITEM*>& aRemoved,
                                 std::vector<BOARD_ITEM*>& aChanged );

    private:

        git_merge_driver_source* m_mergeDriver;
        git_buf* m_result;

    std::set<BOARD_ITEM*> we_modified_they_deleted;
    std::set<BOARD_ITEM*> they_modified_we_deleted;
    std::set<BOARD_ITEM*> both_modified;
};



#endif // KIGIT_PCB_MERGE_H