Show More
@@ -499,13 +499,23 class svnsubrepo(abstractsubrepo): | |||||
499 | raise util.Abort(stderr) |
|
499 | raise util.Abort(stderr) | |
500 | return stdout |
|
500 | return stdout | |
501 |
|
501 | |||
502 | def _wcrev(self): |
|
502 | def _wcrevs(self): | |
|
503 | # Get the working directory revision as well as the last | |||
|
504 | # commit revision so we can compare the subrepo state with | |||
|
505 | # both. We used to store the working directory one. | |||
503 | output = self._svncommand(['info', '--xml']) |
|
506 | output = self._svncommand(['info', '--xml']) | |
504 | doc = xml.dom.minidom.parseString(output) |
|
507 | doc = xml.dom.minidom.parseString(output) | |
505 | entries = doc.getElementsByTagName('entry') |
|
508 | entries = doc.getElementsByTagName('entry') | |
506 | if not entries: |
|
509 | lastrev, rev = '0', '0' | |
507 | return '0' |
|
510 | if entries: | |
508 |
|
|
511 | rev = str(entries[0].getAttribute('revision')) or '0' | |
|
512 | commits = entries[0].getElementsByTagName('commit') | |||
|
513 | if commits: | |||
|
514 | lastrev = str(commits[0].getAttribute('revision')) or '0' | |||
|
515 | return (lastrev, rev) | |||
|
516 | ||||
|
517 | def _wcrev(self): | |||
|
518 | return self._wcrevs()[0] | |||
509 |
|
519 | |||
510 | def _wcchanged(self): |
|
520 | def _wcchanged(self): | |
511 | """Return (changes, extchanges) where changes is True |
|
521 | """Return (changes, extchanges) where changes is True | |
@@ -534,7 +544,7 class svnsubrepo(abstractsubrepo): | |||||
534 | return bool(changes), False |
|
544 | return bool(changes), False | |
535 |
|
545 | |||
536 | def dirty(self): |
|
546 | def dirty(self): | |
537 |
if |
|
547 | if self._state[1] in self._wcrevs() and not self._wcchanged()[0]: | |
538 | return False |
|
548 | return False | |
539 | return True |
|
549 | return True | |
540 |
|
550 |
@@ -123,6 +123,25 change file in svn and hg, commit | |||||
123 | source file://*/svn-repo/src (glob) |
|
123 | source file://*/svn-repo/src (glob) | |
124 | revision 2 |
|
124 | revision 2 | |
125 |
|
125 | |||
|
126 | add an unrelated revision in svn and update the subrepo to without | |||
|
127 | bringing any changes. | |||
|
128 | ||||
|
129 | $ svn mkdir --parents "$SVNREPO/unrelated" -m 'create unrelated' | |||
|
130 | ||||
|
131 | Committed revision 4. | |||
|
132 | $ svn up s | |||
|
133 | ||||
|
134 | Fetching external item into 's/externals' | |||
|
135 | External at revision 1. | |||
|
136 | ||||
|
137 | At revision 4. | |||
|
138 | $ hg sum | |||
|
139 | parent: 2:* tip (glob) | |||
|
140 | Message! | |||
|
141 | branch: default | |||
|
142 | commit: (clean) | |||
|
143 | update: (current) | |||
|
144 | ||||
126 | $ echo a > s/a |
|
145 | $ echo a > s/a | |
127 |
|
146 | |||
128 | should be empty despite change to s/a |
|
147 | should be empty despite change to s/a | |
@@ -139,14 +158,14 add a commit from svn | |||||
139 | A externals/other |
|
158 | A externals/other | |
140 | Updated external to revision 1. |
|
159 | Updated external to revision 1. | |
141 |
|
160 | |||
142 |
Updated to revision |
|
161 | Updated to revision 4. | |
143 | $ echo xyz >> alpha |
|
162 | $ echo xyz >> alpha | |
144 | $ svn propset svn:mime-type 'text/xml' alpha |
|
163 | $ svn propset svn:mime-type 'text/xml' alpha | |
145 | property 'svn:mime-type' set on 'alpha' |
|
164 | property 'svn:mime-type' set on 'alpha' | |
146 | $ svn ci -m 'amend a from svn' |
|
165 | $ svn ci -m 'amend a from svn' | |
147 | Sending src/alpha |
|
166 | Sending src/alpha | |
148 | Transmitting file data . |
|
167 | Transmitting file data . | |
149 |
Committed revision |
|
168 | Committed revision 5. | |
150 | $ cd ../../sub/t |
|
169 | $ cd ../../sub/t | |
151 |
|
170 | |||
152 | this commit from hg will fail |
|
171 | this commit from hg will fail |
General Comments 0
You need to be logged in to leave comments.
Login now