--- a/hgext/convert/__init__.py Sun Oct 19 20:17:06 2008 +0200
+++ b/hgext/convert/__init__.py Sun Oct 19 20:29:41 2008 +0200
@@ -107,7 +107,7 @@
individual commits to CVS and merge them into changesets. CVS
source uses its internal changeset merging code by default but can
be configured to call the external 'cvsps' program by setting:
- --config convert.cvsps=cvsps -A -u --cvs-direct -q
+ --config convert.cvsps='cvsps -A -u --cvs-direct -q'
This is a legacy option and may be removed in future.
The options shown are the defaults.
--- a/mercurial/parsers.c Sun Oct 19 20:17:06 2008 +0200
+++ b/mercurial/parsers.c Sun Oct 19 20:29:41 2008 +0200
@@ -295,25 +295,27 @@
int comp_len, uncomp_len, base_rev, link_rev, parent_1, parent_2;
const char *c_node_id;
const char *end = data + size;
+ char decode[64]; /* to enforce alignment with inline data */
while (data < end) {
unsigned int step;
-
- offset_flags = ntohl(*((uint32_t *) (data + 4)));
+
+ memcpy(decode, data, 64);
+ offset_flags = ntohl(*((uint32_t *) (decode + 4)));
if (n == 0) /* mask out version number for the first entry */
offset_flags &= 0xFFFF;
else {
- uint32_t offset_high = ntohl(*((uint32_t *) data));
+ uint32_t offset_high = ntohl(*((uint32_t *) decode));
offset_flags |= ((uint64_t) offset_high) << 32;
}
- comp_len = ntohl(*((uint32_t *) (data + 8)));
- uncomp_len = ntohl(*((uint32_t *) (data + 12)));
- base_rev = ntohl(*((uint32_t *) (data + 16)));
- link_rev = ntohl(*((uint32_t *) (data + 20)));
- parent_1 = ntohl(*((uint32_t *) (data + 24)));
- parent_2 = ntohl(*((uint32_t *) (data + 28)));
- c_node_id = data + 32;
+ comp_len = ntohl(*((uint32_t *) (decode + 8)));
+ uncomp_len = ntohl(*((uint32_t *) (decode + 12)));
+ base_rev = ntohl(*((uint32_t *) (decode + 16)));
+ link_rev = ntohl(*((uint32_t *) (decode + 20)));
+ parent_1 = ntohl(*((uint32_t *) (decode + 24)));
+ parent_2 = ntohl(*((uint32_t *) (decode + 28)));
+ c_node_id = decode + 32;
entry = _build_idx_entry(nodemap, n, offset_flags,
comp_len, uncomp_len, base_rev,
--- a/tests/run-tests.py Sun Oct 19 20:17:06 2008 +0200
+++ b/tests/run-tests.py Sun Oct 19 20:29:41 2008 +0200
@@ -205,6 +205,18 @@
global hgpkg
hgpkg = _hgpath()
+ vlog("# Installing dummy diffstat")
+ f = open(os.path.join(BINDIR, 'diffstat'), 'w')
+ f.write('#!' + sys.executable + '\n'
+ 'import sys\n'
+ 'files = 0\n'
+ 'for line in sys.stdin:\n'
+ ' if line.startswith("diff "):\n'
+ ' files += 1\n'
+ 'sys.stdout.write("files patched: %d\\n" % files)\n')
+ f.close()
+ os.chmod(os.path.join(BINDIR, 'diffstat'), 0700)
+
if coverage:
vlog("# Installing coverage wrapper")
os.environ['COVERAGE_FILE'] = COVERAGE_FILE
--- a/tests/test-bundle-type Sun Oct 19 20:17:06 2008 +0200
+++ b/tests/test-bundle-type Sun Oct 19 20:29:41 2008 +0200
@@ -20,7 +20,7 @@
hg init t$t
cd t1
hg bundle -t $t ../b$t ../t$t
- head -n 1 ../b$t | cut -b 1-6
+ cut -b 1-6 ../b$t | head -n 1
cd ../t$t
hg pull ../b$t
hg up
--- a/tests/test-convert.out Sun Oct 19 20:17:06 2008 +0200
+++ b/tests/test-convert.out Sun Oct 19 20:29:41 2008 +0200
@@ -94,7 +94,7 @@
individual commits to CVS and merge them into changesets. CVS
source uses its internal changeset merging code by default but can
be configured to call the external 'cvsps' program by setting:
- --config convert.cvsps=cvsps -A -u --cvs-direct -q
+ --config convert.cvsps='cvsps -A -u --cvs-direct -q'
This is a legacy option and may be removed in future.
The options shown are the defaults.
--- a/tests/test-notify Sun Oct 19 20:17:06 2008 +0200
+++ b/tests/test-notify Sun Oct 19 20:29:41 2008 +0200
@@ -83,5 +83,4 @@
hg --cwd b rollback
hg --traceback --cwd b pull ../a 2>&1 | sed -e 's/\(Message-Id:\).*/\1/' \
-e 's/changeset \([0-9a-f]*\) in .*/changeset \1/' \
- -e 's/^Date:.*/Date:/' \
- -e 's/^1 files changed/1 file changed/'
+ -e 's/^Date:.*/Date:/'
--- a/tests/test-notify.out Sun Oct 19 20:17:06 2008 +0200
+++ b/tests/test-notify.out Sun Oct 19 20:29:41 2008 +0200
@@ -150,8 +150,7 @@
b
diffstat:
-1 file changed, 1 insertion(+)
-a | 1 +
+files patched: 1
diffs (6 lines):