From 60d64d1aeffe6020eb591eca4be7ae672e45edc0 Mon Sep 17 00:00:00 2001 From: Andreas Rumpf <rumpf_a@web.de> Date: Thu, 3 Oct 2019 16:46:09 +0200 Subject: use system.move instead of system.shallowCopy if the GC mode requires it --- lib/packages/docutils/rstgen.nim | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) (limited to 'lib/packages') diff --git a/lib/packages/docutils/rstgen.nim b/lib/packages/docutils/rstgen.nim index b75ff3ea1..e5536868b 100644 --- a/lib/packages/docutils/rstgen.nim +++ b/lib/packages/docutils/rstgen.nim @@ -399,11 +399,14 @@ proc hash(x: IndexEntry): Hash = result = result !& x.linkDesc.hash result = !$result -proc `<-`(a: var IndexEntry, b: IndexEntry) = - shallowCopy a.keyword, b.keyword - shallowCopy a.link, b.link - shallowCopy a.linkTitle, b.linkTitle - shallowCopy a.linkDesc, b.linkDesc +when defined(gcDestructors): + template `<-`(a, b: var IndexEntry) = a = move(b) +else: + proc `<-`(a: var IndexEntry, b: IndexEntry) = + shallowCopy a.keyword, b.keyword + shallowCopy a.link, b.link + shallowCopy a.linkTitle, b.linkTitle + shallowCopy a.linkDesc, b.linkDesc proc sortIndex(a: var openArray[IndexEntry]) = # we use shellsort here; fast and simple -- cgit 1.4.1-2-gfad0