[squeak-dev] Squeak and Tonel

Esteban Lorenzano estebanlm at gmail.com
Mon Feb 18 19:02:51 UTC 2019


Fair enough. 
I should not have step in this discussion.

Esteban

> On 18 Feb 2019, at 19:48, Eliot Miranda <eliot.miranda at gmail.com> wrote:
> 
> Esteban,
> 
> On Mon, Feb 18, 2019 at 10:37 AM Esteban Lorenzano <estebanlm at gmail.com <mailto:estebanlm at gmail.com>> wrote:
> Still that’s not the point. 
> Not having an agreement is very different that the behaviour you described about me (and that to justify your own actions).
> You presented my opposition as it would have been “just because” and I presented you my arguments. Even more, I *was* trying to find a solution.
> I can be right or wrong, but I’m not an idiot trying to be more than I am. 
> Honestly, discussing with you many times feels like it is “my way or the highway”, and it’s hard to follow you :(
> 
> I am not trying to force my way.  I am trying to find a way that works for me.  I asked you to support an option in Tonel.  I did not ask you8 to change they way Pharo uses Tonel. You can choose to read my request as some kind of threat, or you can choose to read it as a straightforward request.  I am not trying to get you to follow me.
> 
> I am frustrated at being mistrusted.  I have not asked you to follow me.  I have tried to work with you.  But you don't trust me.
> 
> I have done everything I can in the VM (let's ignore source code control and building for now) to support Pharo.  I have done *nothing* to interfere with Pharo's use of the VM in the code base itself.  have I?  Point to actions I have taken, code I have written to try and harm you.
> 
> We now have a situation where we support differences in the code base (FilePlugin API, command line argument parsing, version printing) that extend *those I put in at the beginning to support differences* (such as plugins.ext and plugins.int <http://plugins.int/> to allow builders to configure the VM as they choose).  Where have I tried to block Pharo?
> 
> But you left vm-dev.  You decided to stop communicating.  And now you continue to describe a straight-forward request to allow an optional behavior in  Tonel with a flat refusal, plus some BS about me trying to insist that you follow me.
> 
> I don't understand Esteban.  You and I do not communicate.  I feel that you top not want to work with me, that you dislike and distrust me.  I cannot work with you.  I have tried for years and we are still in difference and disagreement.
> 
> 
> Esteban
> 
>> On 18 Feb 2019, at 18:34, Eliot Miranda <eliot.miranda at gmail.com <mailto:eliot.miranda at gmail.com>> wrote:
>> 
>> Esteban,
>> 
>> On Mon, Feb 18, 2019 at 4:06 AM Esteban Lorenzano <estebanlm at gmail.com <mailto:estebanlm at gmail.com>> wrote:
>> Hi, 
>> 
>> I’m so not wanting to be part of this discussion, but here I am. 
>> Just because it was mentioned my name in a way I consider inaccurate. 
>> 
>>> On 17 Feb 2019, at 21:27, Eliot Miranda <eliot.miranda at gmail.com <mailto:eliot.miranda at gmail.com>> wrote:
>>> 
>>> Hi All, Hi Torsten, Hi Jakob,
>>> 
>>> On Thu, Feb 14, 2019 at 6:17 AM Torsten Bergmann <astares at gmx.de <mailto:astares at gmx.de>> wrote:
>>> Hi,
>>> 
>>> as some of you might already know "Tonel" is a file-per-class format for monticello repositories [1].
>>> 
>>> In Pharo land many projects are already converted to it - as regular "file tree" solution faces issues 
>>> with git handling due to very long file names / deep file hierarchy (often leading to trouble on Windows).
>>> 
>>> Dales's Rowan (a new project/package manager for Smalltalk) supports FileTree and also Tonel 
>>> repositories [2]. There is also a tool to convert from STORE (VisualWorks Source-Code Versioning System) 
>>> to Tonel format [3].
>>> 
>>> So I wonder about adoption of Tonel in Squeak land. 
>>> 
>>> Any status/comments?
>>> 
>>> Last year I was given contract employment by Tudor Girba's feenk which in part was to involve me porting VMMaker.oscog to Pharo in order to reap the productivity benefits of the Glamorous Toolkit when applied to VMMaker.  The major direction was to unify the opensmalltalk-vm repository with a Toned-Format repository holding the Smalltalk code.
>>> 
>>> This project, though no fault of feenk's did not go well.  A big part of it was my own emotional attachment to Squeak, my "muscle memory" with Squeak and my long experience with Smalltalk-80 derived meta programming which I make extensive use of in VMMaker.oscog.  But a key issue was that I was not prepared to *move* VMMaker.oscog to Pharo; for me it is key that it can live in both places.  In particular I will not risk VMMaker.oscog being stranded on Pharo as it moves away from the "image-based rendering model".  This is not because I don't believe in pixel-independent rendering models, but because productivity in VMMaker depends much more than on GToolkit inspection on the key architectural feature of being completely, safely simulateable (not a real English word; but meaning capable of being simulated).  As Pharo moves towards external libraries to implement its UI so the degree to which VMMaker is simulated is reduced.  Thus crashes in external code cannot be handled with the same power as with errors presented within the Smalltalk environment itself, and this (as harsh experience over thirty five years has taught me) is far more important for overall productivity than having powerful tailorable inspectors.
>>> 
>>> I therefore wanted a Tonel that could both function for Squeak's Monticello and for Pharo's Iceberg.  I had modified the Tonel serialization a little to provide well-formatted support for method timestamps, which are still a key and extremely useful part of Squeak Monticello's "blame" equivalent.  Until git author attribution can be imported into Squeak's Monticello (something I don't see happening) I wanted merely to be able to have a variant of Tonel, enabled for example by a class variable, and hence /not/ present in Pharo, that would allow VMMaker.oscog to use Tonel but still be functional inside Squeak.  I asked Esteban and was met by a flat no.  Not "OK, but this is an option only you will use", but a flat "not under any circumstance”.
>> 
>> This is textually my answer (even with the English errors): 
>> … “Anyway the answer will be no :)
>> This was considered, and even the first implementation of tonel had it. Now, this was discarded because it does not works with git (or other file backends). It was not even me who complained first (as I said, I implemented it). It was Dale and other people used to work on git. 
>> 
>> Thing is,  putting timestamps it will generate conflicts massively when there is no reason to it.
>> 
>> How can this be true? Since a method's time stamp changes only when it is modified it will only produce a change where a method is changed.  I see no problem with this.
>> 
>> I do see the possibility of a bug in Pharo when it was using Monticello and timestamps though.  There was a time when you, Esteban, were contributing to VMMaker.oscog from Pharo and often there would be many changes where just the timestamp had changed.  SO the problem seems to be not with timestamps but with mismanagement of them.
>> 
>> 
>> So, we drop it… and we add support for  the equivalent using the tool we use (iceberg gives you not just the author that modified last the method but all of them, along the history).
>> 
>> Who is we?  I ask from a different perspective.  I ask not too have Pharo use it but to allow Squeak to use it so that I can have timestamps for Squerask and still use Tonel.  But still "“Anyway the answer will be no :)".
>> 
>> So, your first statement is false.  If things are correct there will *not* be massive generation of conflicts when there is no reason.  Second, I am not asking you to change Tonel in Pharo.  i am only asking you to allow Tonel to support timestamps in systems that want to use it.
>> 
>> 
>> I hope is an understandable reason?”
>> 
>> And then in other mail of same thread I suggested an approach viable for squeak: 
>> 
>> "Now, what I’m sure is that if you are trying of using the 100% of Monticello and to use git just as another repository backend, it will not work (we already tried). It will consume far too much effort and you will finish beating the purpose of use git and a file-based-format, and you will be in the worst of two worlds :)
>> 
>> We started like that, and we ended up implementing Iceberg to take benefit of the tools we are using.
>> 
>> In the middle, there was/is gitfiletree. 
>> (I think I suggested you to look at it to adapt it for tonel and squeak).
>> 
>> Gitfiletree uses OSProcess to call git as external tool and it makes all the operations needed. “
>> 
>> 
>> Now, what I was suggesting was a way to use tonel backed with OSProcess (which works in squeak) instead backing it with libgit2 as us. 
>> Since they need the blame support, they could use OSProcess and external git for it.
>> 
>> Of course squeak (and any other dialect) are free to take tonel and adapt it to their needs (in fact, Mariano extended Tonel for VA specific things). 
>> And Pharo can read that format but it will ignore all extensions. 
>> Now, another problem is to WRITE: Pharo would write those packages in “pharo format” and that information would be lost. And in the case of VMMaker, if the idea is to be able to work on both sides, then Pharo needs to “honour” that format, it cannot just read it and ignore it later. So this creates an incompatibility that needs to be handled. 
>> 
>> Anyway, as you can see my answer was not “not under any circumstances”. Was “no, because is not convenient”.
>> 
>> It was still no.  And my request was clear.  I asked if you would allow Tonel to support timestamps, not that Pharo would use timestamps.  This avoids forking Tonel, which I see as essential (it is essential that Tonel *not* fork) for Tonel to be a format that can serve as an interchange between Squeak and Pharo.
>> 
>> 
>> Esteban
>> 
>> 
>>> 
>>> So here I am joining in this thread reluctantly.  I'm extremely frustrated by the state of Tonel in Squeak and between the two dialects.  Clément had moved his Scorch optimizer to Tonel/git and I tried to use Metacello and Jakob's Tonel code to at least allow me to load that code and try and push forward on Sista/Scorch.  The port *does not work*.  Metacello fails to load Scorch.  Neither Jakob nor Fabio, after putting in some effort, were able to fix the problem, and it is well beyond me.  So I have accepted the fact that I will have to use the Monticello repository for Scorch/Sista.
>>> 
>>> I had deep concerns that the pursuit of git integration would end up splitting the Pharo and Squeak communities and indeed this is now in progress.  I am utterly unmotivated by the lack of cooperation, the sheer arrogance and bullying of those that say "you will move to git/tonel or else", and considering leaving VMMaker altogether.  The only things that are keeping me interested are Ron Teitelbaum's Terf and me pursuing a PhD on register allocation in the context of Sista/Scorch with Robert Hirshfeld's group at HPI.
>>> 
>>> Here's the kind of crap people like Ducasse throw at me:
>>> 
>>> "Eliot 
>>> 
>>> At the end of the day I will probably ask the two phds that should work on language design to use truffle or pypy
>>> because let us face it we cannot work with the Pharo VM. Else we will simply have to fork it (because we do not want to have 
>>> to jump over cuis, newspeak, squeak code constraints and I do not what) and it will be another drama is in the pico world 
>>> of the “open” smalltalk VM. "
>>> 
>>> I am so over this crap.
>>> _,,,^..^,,,_
>>> best, Eliot
>> 
>> 
>> 
>> -- 
>> _,,,^..^,,,_
>> best, Eliot
> 
> 
> 
> -- 
> _,,,^..^,,,_
> best, Eliot

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.squeakfoundation.org/pipermail/squeak-dev/attachments/20190218/349807b2/attachment-0001.html>


More information about the Squeak-dev mailing list