##// END OF EJS Templates
scm: darcs: code clean up model....
Toshi MARUYAMA -
r5312:fbf23a14b837
parent child
Show More
@@ -1,104 +1,106
1 1 # redMine - project management software
2 2 # Copyright (C) 2006-2007 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 require 'redmine/scm/adapters/darcs_adapter'
19 19
20 20 class Repository::Darcs < Repository
21 21 validates_presence_of :url, :log_encoding
22 22
23 23 ATTRIBUTE_KEY_NAMES = {
24 24 "url" => "Root directory",
25 25 "log_encoding" => "Commit messages encoding",
26 26 }
27 27 def self.human_attribute_name(attribute_key_name)
28 28 ATTRIBUTE_KEY_NAMES[attribute_key_name] || super
29 29 end
30 30
31 31 def self.scm_adapter_class
32 32 Redmine::Scm::Adapters::DarcsAdapter
33 33 end
34 34
35 35 def self.scm_name
36 36 'Darcs'
37 37 end
38 38
39 39 def entry(path=nil, identifier=nil)
40 40 patch = identifier.nil? ? nil : changesets.find_by_revision(identifier)
41 41 scm.entry(path, patch.nil? ? nil : patch.scmid)
42 42 end
43 43
44 44 def entries(path=nil, identifier=nil)
45 45 patch = identifier.nil? ? nil : changesets.find_by_revision(identifier)
46 46 entries = scm.entries(path, patch.nil? ? nil : patch.scmid)
47 47 if entries
48 48 entries.each do |entry|
49 49 # Search the DB for the entry's last change
50 changeset = changesets.find_by_scmid(entry.lastrev.scmid) if entry.lastrev && !entry.lastrev.scmid.blank?
50 if entry.lastrev && !entry.lastrev.scmid.blank?
51 changeset = changesets.find_by_scmid(entry.lastrev.scmid)
52 end
51 53 if changeset
52 54 entry.lastrev.identifier = changeset.revision
53 55 entry.lastrev.name = changeset.revision
54 56 entry.lastrev.time = changeset.committed_on
55 57 entry.lastrev.author = changeset.committer
56 58 end
57 59 end
58 60 end
59 61 entries
60 62 end
61 63
62 64 def cat(path, identifier=nil)
63 65 patch = identifier.nil? ? nil : changesets.find_by_revision(identifier.to_s)
64 66 scm.cat(path, patch.nil? ? nil : patch.scmid)
65 67 end
66 68
67 69 def diff(path, rev, rev_to)
68 70 patch_from = changesets.find_by_revision(rev)
69 71 return nil if patch_from.nil?
70 72 patch_to = changesets.find_by_revision(rev_to) if rev_to
71 73 if path.blank?
72 74 path = patch_from.changes.collect{|change| change.path}.join(' ')
73 75 end
74 76 patch_from ? scm.diff(path, patch_from.scmid, patch_to ? patch_to.scmid : nil) : nil
75 77 end
76 78
77 79 def fetch_changesets
78 80 scm_info = scm.info
79 81 if scm_info
80 82 db_last_id = latest_changeset ? latest_changeset.scmid : nil
81 83 next_rev = latest_changeset ? latest_changeset.revision.to_i + 1 : 1
82 84 # latest revision in the repository
83 85 scm_revision = scm_info.lastrev.scmid
84 86 unless changesets.find_by_scmid(scm_revision)
85 87 revisions = scm.revisions('', db_last_id, nil, :with_path => true)
86 88 transaction do
87 89 revisions.reverse_each do |revision|
88 90 changeset = Changeset.create(:repository => self,
89 91 :revision => next_rev,
90 92 :scmid => revision.scmid,
91 93 :committer => revision.author,
92 94 :committed_on => revision.time,
93 95 :comments => revision.message)
94 96
95 97 revision.paths.each do |change|
96 98 changeset.create_change(change)
97 99 end
98 100 next_rev += 1
99 101 end if revisions
100 102 end
101 103 end
102 104 end
103 105 end
104 106 end
General Comments 0
You need to be logged in to leave comments. Login now