Sometimes an application provides a script to initialize its build
environment, and it may be required to patch such a script before running
it (typical case is hardcoding developer's local paths). More generally,
"declaritive" ways of changing code (e.g., forceversion, patch, etc.)
should be preferred to prebuild, which should be used as the last resort
(as it is too generic and thus verbose). So, it's right ordering in that
respect either.
This reverts commit 998d42fd4e84afa09a2803dc25d61437d042a6d5. There
doesn't seem to be any point in patching this:
a) It's already been in the repo a long time
b) If we issue another version of a package, with the exact same
version name and code, how is anybody supposed to know which is which?
(I realise in this case it wouldn't make much difference, but the
general principle is important)
c) There is a technical problem in that if a different version of what
should be the same apk is pushed to the repo, installations will be
rejected by the client (until an update is done) because they will see
that the file they download is not what it was supposed to be.
d) The developer says he is fixing it in the next release anyway.
It's clearly not a System, that's kind of catch-all category, but anything
better fitting should be used whenever possible. It is marketed as a
collaboration tool, so might warrint Office, but on a closer look it's
actually nothing more than a networked sync app. Hence, Internet.
Unlike insertversion/insertvercode which accept pattern for old version/code,
which yet need to be prepared, then tested, and with that still named
confusingly, forceversion/forcevercode are boolean-style parameters which,
if specified for build, replace whatever version/code specified in
AndroidManifest.xml with the values from recipe.