diff options
author | Michael Vogt <egon@bottom> | 2006-05-08 22:33:59 +0200 |
---|---|---|
committer | Michael Vogt <egon@bottom> | 2006-05-08 22:33:59 +0200 |
commit | b28ae1f7fcad711deb5ed4fbe42e195bf125b10c (patch) | |
tree | d9f860754661ff27e4a5d081988375406f2ff5bd /apt-pkg/deb/debversion.cc | |
parent | cfde4904a7b61e2a3c75322a08a6fac3c062d65d (diff) | |
parent | 9373b9752db017bc8458720f330dc9594ac8de17 (diff) |
* merged the zero epoch handling patch
Diffstat (limited to 'apt-pkg/deb/debversion.cc')
-rw-r--r-- | apt-pkg/deb/debversion.cc | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/apt-pkg/deb/debversion.cc b/apt-pkg/deb/debversion.cc index aeee61929..064d8fa5b 100644 --- a/apt-pkg/deb/debversion.cc +++ b/apt-pkg/deb/debversion.cc @@ -59,7 +59,7 @@ int debVersioningSystem::CmpFragment(const char *A,const char *AEnd, } /* Iterate over the whole string - What this does is to spilt the whole string into groups of + What this does is to split the whole string into groups of numeric and non numeric portions. For instance: a67bhgs89 Has 4 portions 'a', '67', 'bhgs', '89'. A more normal: @@ -140,6 +140,27 @@ int debVersioningSystem::DoCmpVersion(const char *A,const char *AEnd, if (rhs == BEnd) rhs = B; + // Special case: a zero epoch is the same as no epoch, + // so remove it. + if (lhs != A) + { + for (; *A == '0'; ++A); + if (A == lhs) + { + ++A; + ++lhs; + } + } + if (rhs != B) + { + for (; *B == '0'; ++B); + if (B == rhs) + { + ++B; + ++rhs; + } + } + // Compare the epoch int Res = CmpFragment(A,lhs,B,rhs); if (Res != 0) |