OSDN Git Service

Update RevisionGraph to 15570
[tortoisegit/TortoiseGitJp.git] / src / TortoiseProc / RevisionGraph / FullGraphFinalizer.h
1 // TortoiseSVN - a Windows shell extension for easy version control\r
2 \r
3 // Copyright (C) 2003-2008 - TortoiseSVN\r
4 \r
5 // This program is free software; you can redistribute it and/or\r
6 // modify it under the terms of the GNU General Public License\r
7 // as published by the Free Software Foundation; either version 2\r
8 // of the License, or (at your option) any later version.\r
9 \r
10 // This program is distributed in the hope that it will be useful,\r
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of\r
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
13 // GNU General Public License for more details.\r
14 \r
15 // You should have received a copy of the GNU General Public License\r
16 // along with this program; if not, write to the Free Software Foundation,\r
17 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.\r
18 //\r
19 #pragma once\r
20 \r
21 #include "PathClassificator.h"\r
22 \r
23 using namespace LogCache;\r
24 \r
25 class CFullHistory;\r
26 class CFullGraph;\r
27 class CFullGraphNode;\r
28 \r
29 /**\r
30  * \ingroup TortoiseProc\r
31  */\r
32 class CFullGraphFinalizer\r
33 {\r
34 public:\r
35 \r
36         CFullGraphFinalizer (const CFullHistory& history, CFullGraph& graph);\r
37         ~CFullGraphFinalizer (void);\r
38 \r
39         void Run();\r
40 \r
41 private:\r
42 \r
43     /// simplify graph\r
44 \r
45     void FindRenames (CFullGraphNode* node);\r
46 \r
47     /// mark nodes according to local properties\r
48 \r
49     void MarkRoot (CFullGraphNode* node);\r
50     void MarkCopySource (CFullGraphNode* node);\r
51     void MarkWCRevision (CFullGraphNode* node);\r
52     void MarkHead (CFullGraphNode* node);\r
53     void AddWCModification (CFullGraphNode* node);\r
54     void ForwardClassification (CFullGraphNode* node);\r
55 \r
56     /// inherit properties\r
57 \r
58     DWORD BackwardClassification (CFullGraphNode* node);\r
59 \r
60     /// data members\r
61 \r
62     const CFullHistory& history;\r
63     CFullGraph& graph;\r
64 \r
65     std::auto_ptr<CPathClassificator> pathClassification;\r
66 };\r