I've been thinking about a binary diff/patch route, but I'm afraid most people don't understand how that should work. Plus I haven't check yet if the whole file changes if Nenad adds something to a scene or character...
Yesterday with the help of Nenad we proved the concept on a small game. Nenad made a v1, then some small changes for a v2. In total both were around 153 MiB zipped. The first step is easy and is something more experienced users can probably do. Through checksums we figured out that most .vs -- those contain the code, music, art etc per character or scene -- stayed the same. That gave a total of 25 MiB unzipped -- about 5-10% is gained in zipping -- of changed files...
The next step is using a program which can construct a binary patch. This is a file which contains instructions on how to convert the old file into a new file. That means deletions, insertions and off course new stuff. Because the changes were small, the total patch unzipped was less then 18 KiB. However applying the patch is something programmers do regularly, but ordinary people never. It involves the BSD -- Unix variant -- program
You must be registered to see the links
for creating and bspatch for applying the patch. I used a version ported to Linux. And then we tested it with
You must be registered to see the links
which gives a Bash shell in all version of Windows. But you probably already see that it is quite a process...
May be someone can wrap it all up in a nice Windows program which uses parts of Cygwin, the bsdiff/bspatch source code and the example I created in Bash. But I'm not a real programmer so I won't burn my fingers on it
I proved it can be done, although some people are still skeptical. The Visionaire developers still think it won't work in all instances. I say bullshit. After the patch nobody can prove how this copy was made. If you think about all the steps -- zipping, uploading, virtual drives, downloading and unzipping -- a digital copy from Nenad's computer to us undergo, it is a miracle that most of the time that copy is 100%. If the bsdiff/bspatch doesn't contain bugs -- it is in use since 2003, so very, very stable -- it is just another step in creating a digital copy. Afterwards nobody can prove how the copy came to live. It is 100% the same as an original export. So every bug/glitch or other faults the original had, is reproduced. I'm confident that it will work with 99,999999% certainty. And yes not 100% but that you also don't get with a normal download -- the zip program, virtual drive or the IP protocol can have bugs -- or torrent as well. Every once in a while I've a corrupted download. That is why I want checksums -- and yes those can have bugs as well -- which most uploaders don't provide. Even this forum doesn't...
I've done the math on v020 of Willy. The complete download is 7,04 GiB. When only giving changed files -- and just copying over the old ones is not enough, you must do some renaming/deleting as well -- it is reduced to 1,05 GiB. And when I create binary patches of the changed files I estimate that the 911 MiB of changed files will be reduced to a 46 MiB binary patch. Add 163 MiB of new files -- new scenes and characters or a total of roughly 0,2 to 0,3 GiB (based on a 241 MiB scene file which was reduced to 12 MiB binary patch).
I'm not sure if the extra complexity is worth the effort. I think most people can't do it with the proof of concept I made. But maybe if someone can make it into a full proof Windows program? The same goes for the just changed/new files. That means copying/renaming and sometimes deleting. That more people can probably do, but is also a process which must be done precisely. I think this also needs a full proof Windows program.
But I now know that it can be done and that even the Visionaire developers don't understand what a 100% digital copy means. It seems to me that the more technology we have, less people really understand how things work. Am I becoming old and grumpy?