[Pharo-dev] [squeak-dev] The .changes file should be bound to a
single image
John Pfersich
smalltalker2 at mac.com
Fri Jul 1 04:44:03 UTC 2016
Sounds like a better idea to me, but I don't think it would solve the problem of multiple images almost simultaneously attempting to update themselves (as in a classroom)
Sent from my iPad
> On Jun 30, 2016, at 13:31, Chris Muller <asqueaker at gmail.com> wrote:
>
> Another thought...
>
> Upon launching of the image, start a, temporary changes file,
> [image-name]-[some UUID].changes.
>
> Upon image save, append the temp changes file to the main changes
> file, but in an atomic way (first do the append as a new unique
> filename, then rename it to the original changes file name).
>
> Hmm, but then we would have to check two changes files when accessing sources..
>
> On Thu, Jun 30, 2016 at 3:10 PM, Chris Muller <asqueaker at gmail.com> wrote:
>>>> In practice, this is not an issue that either Chris or I have noticed,
>>>> probably because we are not doing software development (saving method
>>>> changes) at the same time that we are running RemoteTask and similar.
>>>> But I can certainly see how it might be a problem if, for example, I
>>>> had a bunch of students running the same image from a network shared
>>>> folder.
>>>
>>> Maybe its time to consider a fundamental change in how method-sources
>>> are referred to.
>>> Taking inspiration from git... A content addressable key-value file
>>> store might solve concurrent access. Each CompiledMethod gets written
>>> to a file named for the hash of its contents, which is the only
>>> reference the Image getsto a method's source. Each such file would
>>
>> It sounds like a lot of files.. so how would I move an image to
>> another computer? I gotta know which files go with which image?
>>
>> Plus, it doesn't really solve the fundamental problem of two images
>> writing to the same file. Mutliple images could still change the same
>> method to the same contents at the same time. You may have made the
>> problem less-likely, except for when you have your first
>> hash-collision of *different* sources (it COULD happen), in which case
>> it wouldn't even require the changes to occur at the same time.
>>
>> I guess it would also lose the order-sequence of the change log too...
>> unless you were to try to use the underlying filesystem's timestamps
>> on each file but... it wouldn't work after I've copied all the files
>> via scp and because they all get new timestamps...
>>
>> Might be better to teach the class, who are learning about Smalltalk
>> anyway, about the nature of the changes file..?
>
More information about the Squeak-dev
mailing list
|