Mercurial > hg > soundsoftware-site
comparison app/models/repository/mercurial.rb @ 119:8661b858af72
* Update to Redmine trunk rev 4705
| author | Chris Cannam |
|---|---|
| date | Thu, 13 Jan 2011 14:12:06 +0000 |
| parents | 513646585e45 |
| children | cd2282d2aa55 051f544170fe |
comparison
equal
deleted
inserted
replaced
| 39:150ceac17a8d | 119:8661b858af72 |
|---|---|
| 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
| 17 | 17 |
| 18 require 'redmine/scm/adapters/mercurial_adapter' | 18 require 'redmine/scm/adapters/mercurial_adapter' |
| 19 | 19 |
| 20 class Repository::Mercurial < Repository | 20 class Repository::Mercurial < Repository |
| 21 # sort changesets by revision number | |
| 22 has_many :changesets, :order => "#{Changeset.table_name}.id DESC", :foreign_key => 'repository_id' | |
| 23 | |
| 21 attr_protected :root_url | 24 attr_protected :root_url |
| 22 validates_presence_of :url | 25 validates_presence_of :url |
| 23 | 26 |
| 24 def scm_adapter | 27 def scm_adapter |
| 25 Redmine::Scm::Adapters::MercurialAdapter | 28 Redmine::Scm::Adapters::MercurialAdapter |
| 26 end | 29 end |
| 27 | 30 |
| 28 def self.scm_name | 31 def self.scm_name |
| 29 'Mercurial' | 32 'Mercurial' |
| 30 end | 33 end |
| 31 | 34 |
| 35 # Returns the readable identifier for the given mercurial changeset | |
| 36 def self.format_changeset_identifier(changeset) | |
| 37 "#{changeset.revision}:#{changeset.scmid}" | |
| 38 end | |
| 39 | |
| 40 # Returns the identifier for the given Mercurial changeset | |
| 41 def self.changeset_identifier(changeset) | |
| 42 changeset.scmid | |
| 43 end | |
| 44 | |
| 45 def diff_format_revisions(cs, cs_to, sep=':') | |
| 46 super(cs, cs_to, ' ') | |
| 47 end | |
| 48 | |
| 32 def entries(path=nil, identifier=nil) | 49 def entries(path=nil, identifier=nil) |
| 33 entries=scm.entries(path, identifier) | 50 entries=scm.entries(path, identifier) |
| 34 if entries | 51 if entries |
| 35 entries.each do |entry| | 52 entries.each do |entry| |
| 36 next unless entry.is_file? | 53 next unless entry.is_file? |
| 48 entry.lastrev.revision = change.revision | 65 entry.lastrev.revision = change.revision |
| 49 end | 66 end |
| 50 end | 67 end |
| 51 end | 68 end |
| 52 entries | 69 entries |
| 70 end | |
| 71 | |
| 72 # Finds and returns a revision with a number or the beginning of a hash | |
| 73 def find_changeset_by_name(name) | |
| 74 return nil if name.nil? || name.empty? | |
| 75 if /[^\d]/ =~ name or name.to_s.size > 8 | |
| 76 e = changesets.find(:first, :conditions => ['scmid = ?', name.to_s]) | |
| 77 else | |
| 78 e = changesets.find(:first, :conditions => ['revision = ?', name.to_s]) | |
| 79 end | |
| 80 return e if e | |
| 81 changesets.find(:first, :conditions => ['scmid LIKE ?', "#{name}%"]) # last ditch | |
| 82 end | |
| 83 | |
| 84 # Returns the latest changesets for +path+; sorted by revision number | |
| 85 def latest_changesets(path, rev, limit=10) | |
| 86 if path.blank? | |
| 87 changesets.find(:all, :include => :user, :limit => limit) | |
| 88 else | |
| 89 changes.find(:all, :include => {:changeset => :user}, | |
| 90 :conditions => ["path = ?", path.with_leading_slash], | |
| 91 :order => "#{Changeset.table_name}.id DESC", | |
| 92 :limit => limit).collect(&:changeset) | |
| 93 end | |
| 53 end | 94 end |
| 54 | 95 |
| 55 def fetch_changesets | 96 def fetch_changesets |
| 56 scm_info = scm.info | 97 scm_info = scm.info |
| 57 if scm_info | 98 if scm_info |
