Use str.len-1 rather than -1

This commit is contained in:
Jean Cavallo 2015-03-31 12:21:22 +02:00
commit 4a56ac60d9
5 changed files with 9 additions and 8 deletions

View file

@ -171,7 +171,8 @@ proc parseCmdLine(): Options =
# Parse pkg@verRange
if '@' in key:
let i = find(key, '@')
let pkgTup = (key[0 .. i-1], key[i+1 .. ^1].parseVersionRange())
let pkgTup = (key[0 .. i-1],
key[i+1 .. key.len-1].parseVersionRange())
result.action.packages.add(pkgTup)
else:
result.action.packages.add((key, VersionRange(kind: verAny)))

View file

@ -104,7 +104,7 @@ proc getTagsListRemote*(url: string, meth: DownloadMethod): seq[string] =
for i in output.splitLines():
if i == "": continue
let start = i.find("refs/tags/")+"refs/tags/".len
let tag = i[start .. ^1]
let tag = i[start .. i.len-1]
if not tag.endswith("^{}"): result.add(tag)
of DownloadMethod.hg:
@ -118,7 +118,7 @@ proc getVersionList*(tags: seq[string]): Table[Version, string] =
if tag != "":
let i = skipUntil(tag, Digits) # skip any chars before the version
# TODO: Better checking, tags can have any names. Add warnings and such.
result[newVersion(tag[i .. ^1])] = tag
result[newVersion(tag[i .. tag.len-1])] = tag
proc getDownloadMethod*(meth: string): DownloadMethod =
case meth

View file

@ -88,11 +88,11 @@ proc parseRequires(req: string): PkgTuple =
if ' ' in req:
var i = skipUntil(req, Whitespace)
result.name = req[0 .. i].strip
result.ver = parseVersionRange(req[i .. ^1])
result.ver = parseVersionRange(req[i .. req.len-1])
elif '#' in req:
var i = skipUntil(req, {'#'})
result.name = req[0 .. i-1]
result.ver = parseVersionRange(req[i .. ^1])
result.ver = parseVersionRange(req[i .. req.len-1])
else:
result.name = req.strip
result.ver = VersionRange(kind: verAny)
@ -339,7 +339,7 @@ proc getNameVersion*(pkgpath: string): tuple[name, version: string] =
for i in countdown(tail.len-1, 0):
if tail[i] == '-':
result.name = tail[0 .. i-1]
result.version = tail[i+1 .. ^1]
result.version = tail[i+1 .. tail.len-1]
break
proc echoPackage*(pkg: Package) =

View file

@ -62,7 +62,7 @@ proc changeRoot*(origRoot, newRoot, path: string): string =
## path: /home/dom/bar/blah/2/foo.txt
## Return value -> /home/test/bar/blah/2/foo.txt
if path.startsWith(origRoot):
return newRoot / path[origRoot.len .. ^1]
return newRoot / path[origRoot.len .. path.len-1]
else:
raise newException(ValueError,
"Cannot change root of path: Path does not begin with original root.")

View file

@ -139,7 +139,7 @@ proc parseVersionRange*(s: string): VersionRange =
new(result)
if s[0] == '#':
result.kind = verSpecial
result.spe = s[1 .. ^1].Special
result.spe = s[1 .. s.len-1].Special
return
var i = 0