summaryrefslogtreecommitdiffstats
path: root/app/models/repository
diff options
context:
space:
mode:
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-05-26 10:12:00 +0000
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-05-26 10:12:00 +0000
commita267babfe8064691fe7e9a85434236de3f606e46 (patch)
tree315a9e3c74a5cbaa75410b5b58b8d8f8e38bd915 /app/models/repository
parentadbe6af44a1605de73c094dfbad51300d0aa4601 (diff)
downloadredmine-a267babfe8064691fe7e9a85434236de3f606e46.tar.gz
redmine-a267babfe8064691fe7e9a85434236de3f606e46.zip
scm: mercurial: code clean up model.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@5931 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/repository')
-rw-r--r--app/models/repository/mercurial.rb29
1 files changed, 16 insertions, 13 deletions
diff --git a/app/models/repository/mercurial.rb b/app/models/repository/mercurial.rb
index 60948ce55..128797e65 100644
--- a/app/models/repository/mercurial.rb
+++ b/app/models/repository/mercurial.rb
@@ -19,12 +19,15 @@ require 'redmine/scm/adapters/mercurial_adapter'
class Repository::Mercurial < Repository
# sort changesets by revision number
- has_many :changesets, :order => "#{Changeset.table_name}.id DESC", :foreign_key => 'repository_id'
+ has_many :changesets,
+ :order => "#{Changeset.table_name}.id DESC",
+ :foreign_key => 'repository_id'
- attr_protected :root_url
+ attr_protected :root_url
validates_presence_of :url
- FETCH_AT_ONCE = 100 # number of changesets to fetch at once
+ # number of changesets to fetch at once
+ FETCH_AT_ONCE = 100
def self.human_attribute_name(attribute_key_name)
attr_name = attribute_key_name
@@ -84,9 +87,11 @@ class Repository::Mercurial < Repository
# Sqlite3 and PostgreSQL pass.
# Is this MySQL bug?
def latest_changesets(path, rev, limit=10)
- changesets.find(:all, :include => :user,
+ changesets.find(:all,
+ :include => :user,
:conditions => latest_changesets_cond(path, rev, limit),
- :limit => limit, :order => "#{Changeset.table_name}.id DESC")
+ :limit => limit,
+ :order => "#{Changeset.table_name}.id DESC")
end
def latest_changesets_cond(path, rev, limit)
@@ -108,7 +113,6 @@ class Repository::Mercurial < Repository
cond << "#{Changeset.table_name}.id <= ?"
args << last.id
end
-
unless path.blank?
cond << "EXISTS (SELECT * FROM #{Change.table_name}
WHERE #{Change.table_name}.changeset_id = #{Changeset.table_name}.id
@@ -117,26 +121,25 @@ class Repository::Mercurial < Repository
args << path.with_leading_slash
args << "#{path.with_leading_slash.gsub(%r{[%_\\]}) { |s| "\\#{s}" }}/%" << '\\'
end
-
[cond.join(' AND '), *args] unless cond.empty?
end
private :latest_changesets_cond
def fetch_changesets
scm_rev = scm.info.lastrev.revision.to_i
- db_rev = latest_changeset ? latest_changeset.revision.to_i : -1
+ db_rev = latest_changeset ? latest_changeset.revision.to_i : -1
return unless db_rev < scm_rev # already up-to-date
logger.debug "Fetching changesets for repository #{url}" if logger
(db_rev + 1).step(scm_rev, FETCH_AT_ONCE) do |i|
transaction do
scm.each_revision('', i, [i + FETCH_AT_ONCE - 1, scm_rev].min) do |re|
- cs = Changeset.create(:repository => self,
- :revision => re.revision,
- :scmid => re.scmid,
- :committer => re.author,
+ cs = Changeset.create(:repository => self,
+ :revision => re.revision,
+ :scmid => re.scmid,
+ :committer => re.author,
:committed_on => re.time,
- :comments => re.message)
+ :comments => re.message)
re.paths.each { |e| cs.create_change(e) }
end
end