$ git clone git://git.cypherpunks.ru/goredo.git
$ cd goredo
- $ git tag -v v0.4.1
+ $ git tag -v v0.5.0
$ git clone git://git.cypherpunks.ru/gorecfile.git
$ ( cd gorecfile ; git tag -v v0.3.0 )
$ echo "replace go.cypherpunks.ru/recfile => `pwd`/gorecfile" >> go.mod
file, but it does not play any role later. It is stayed just for
compatibility.
- Removed .do can lead to permanent errors of its non existence~
-
-That is true, because dependency on it was recorded previously. Is it
-safe to assume that .do-less target now is an ordinary source-file? I
-have no confidence in such behaviour. So it is user's decision how to
-deal with it, probably it was just his inaccuracy mistake. If you really
-want to get rid of that dependency knowledge for foo/bar target, then
-just remove foo/.redo/bar.dep.
+ Can removed .do lead to permanent errors of its non existence?~
+
+Yes, because dependency on it was recorded previously. Is it safe to
+assume that .do-less target now is an ordinary source-file? I have no
+confidence in such behaviour. So it is user's decision how to deal with
+it, probably it was just his inaccuracy mistake. If you really want to
+get rid of that dependency knowledge for foo/bar target, then just
+remove foo/.redo/bar.dep.
+
+ Does redo-always always rebuilds target?~
+
+goredo, together with apenwarr/redo, rebuilds target once per run.
+Always rebuilds during every redo invocation, but only once during it
+building. http://news.dieweltistgarnichtso.net/bin/redo-sh.html#why-built-twice
+has other opinion, that is why its redo-sh.tests/always_rebuild_1 will
+fail. Rebuilding of always-ed targets even during the same build process
+ruins any redo's usability in practice.
+
+For example if my .h file contains source code's version number, that is
+git-describe's output and all my other files depends on that header,
+then any redo-ifchange of .o will lead to git-describe execution, that
+is rather heavy. Of course, because of either hashing or possible
+redo-stamp-ing its dependants won't be rebuilt further, but build time
+will be already ruined. If you need to rebuild TeX documents (case
+mentioned in redo-sh's FAQ) until all references and numbers are ready,
+then you must simply explicitly use while cycle in your .do, as
+apenwarr/redo already suggests.
STATE *goredo-state*
--- /dev/null
+tests=redo-sh.tests
+[ -e $tests ] || {
+ cat >&2 <<EOF
+No $tests found. Provide them manually, for example with:
+ $ git clone http://news.dieweltistgarnichtso.net/bin.git
+ $ cd bin
+ $ git checkout 6e45ad16ad0513d1a6a4a0539a9d01d39d3e7490
+ $ ln -s `pwd`/redo-sh.tests /path/to/goredo/t/redo.sh.tests
+EOF
+ exit 1
+}
+( cd $tests ; ls ) | while read testname ; do
+ ln -s runner.rc ${testname}.t
+done
+
+echo Skipping parallel_2.t, that assumes --jobs option availability >&2
+rm parallel_2.t