> On 15 Jun 2018, at 08:11, Norbert Hartl <norb...@hartl.name> wrote:
> 
> 
> 
> Am 14.06.2018 um 13:12 schrieb Thierry Goubier <thierry.goub...@gmail.com 
> <mailto:thierry.goub...@gmail.com>>:
> 
>> Hi Norbert, Tim,
>> 
>> 2018-06-14 11:33 GMT+02:00 Norbert Hartl <norb...@hartl.name 
>> <mailto:norb...@hartl.name>>:
>> 
>> 
>>> Am 14.06.2018 um 10:30 schrieb Tim Mackinnon <tim@testit.works 
>>> <mailto:tim@testit.works>>:
>>> 
>>> Hi - yes I’m pleased you check out the entire tree, although currently it’s 
>>> a bit confusing that you do (fortunately this does give the possibility 
>>> that we can checkout images and other resources that an Pharo application 
>>> might rely on - without having to resort to the Seaside FileLibrary trick).
>>> 
>>> However my concrete case was that I have a gitlab ci pipeline and next to 
>>> my src directory in my project I have a config directory that has some 
>>> Nginx config for my teapot app. If I add a teapot route, I also need to 
>>> adjust that config and check both changes in together. I can’t easily do 
>>> that now?
>>> 
>>> I can modify /config/app.nginx either in another app (intellij) or even in 
>>> the simple Pharo text editor, and the I can add my new route in my 
>>> DemoApp>>createRoutes method but how do I check them in together so my 
>>> pipeline will build atomically?
>>> 
>>> Iceberg hasn’t written out the changes yet, so IntelliJ can’t see them to 
>>> do a commit, and iceberg ignores the parallel /config directory (that it 
>>> checked out). So it’s a catch 22.
>>> 
>>> This is why I suggested maybe we could specify safer (textual) directories 
>>> that iceberg might also checkin? OR we have a Stage command in iceberg that 
>>> does everything that commit does up to the point of actually writing to the 
>>> repo - then I could jump to IntelliJ and do the final commit there and use 
>>> its tools to manage non Pharo stuff (until we can build more)?
>>> 
>>> Does this make sense?
>>> 
>> I don’t understand why you are so eager to have everything into one commit. 
>> Usually the tension is rather have small commits. What is the problem of 
>> having two commits for this?
>> 
>> A single commit allow one to make sure that both the smalltalk code and the 
>> external resource are well in sync, and that you may not ending up in a 
>> situation were at commit j has data format v1 and smalltalk code for format 
>> v2, because it is in commit j+1 that you rewrote the data in format v2.
>> 
> Yes, sure but that is only a problem if you lost control over which commit 
> goes into action. I think the problem is in the deployment then. Putting 
> integrity constraints on commits is IMHO the wrong level deployment 
> granularity

+1
git favours many small commits.

Esteban

> 
> Norbert
> 
>> I had that issue recently with a Pharo / FPGA project with a Pharo package 
>> generating state machines to be integrated in a Verilog FPGA design with C 
>> code for the drivers, the softcore in the FPGA, and test programs, and both 
>> Pharo and the C/FPGA working out of the same test data... And that whole 
>> thing getting regularly out of sync.
>> 
>> IMHO: I'd model a concept of "multi-lingual projet" for that sort of things, 
>> where one can list, in Pharo, Monticello packages and external files or 
>> directories. Whatever the technology you use (OSProcess, libgit, 
>> whatever...) it is easy then to commit all this in a single pass. On a 
>> per-package basis, I'd see the package manifest as a suitable place for 
>> listing external resources. On a per-project basis, a possible place could 
>> be the manifest for the BaselineOf the project.
>> 
>> Thierry
>>  
>> 
>> Norbert
>> 
>>> As an aside - I’d really like to checkin in the play-xxx directories (the 
>>> .ph files) as there is often useful playground stuff I’d like to access on 
>>> my home computer. We can’t do that easily at the moment either.
>>> 
>>> Tim
>>> 
>>> Sent from my iPhone
>>> 
>>> On 14 Jun 2018, at 09:12, Guillermo Polito <guillermopol...@gmail.com 
>>> <mailto:guillermopol...@gmail.com>> wrote:
>>> 
>>>> Just to complement Esteban's answer:
>>>> 
>>>> - Iceberg checks out in disk more than the src directory because you 
>>>> **may** want to edit files from the command line, and after long 
>>>> discussions we did not want to forbid that.
>>>> Actually, just to put everybody in perspective, at first the idea was to 
>>>> not have a working copy in disk at all, but just hit to the blob.
>>>> Imagine is nowadays we are a bit alien, that would have been worst :)
>>>> 
>>>> - About checking in files. I'd like to understand what you mean exactly.
>>>>   - Do you want to load them into memory?
>>>>     This would be the "more consistent" way to do it, following the "the 
>>>> image it its own working copy" metaphore.
>>>>     This would allow us to, for example, share an image and transparently 
>>>> share resources with it (without requiring to clone).
>>>>     But this would have some impact in memory consumption and add stress 
>>>> to the GC, right?
>>>> 
>>>>   - Or do you mean to ask like any other Git client and show you the file 
>>>> differences between the working copy and the git index?
>>>>     The problem with this approach is that we will have some treatment for 
>>>> pharo code and some different treatment for non-code...
>>>>     If I do a change to a class, the change is kept in the image. But if I 
>>>> do a change to a file, that change is not kept in the image!
>>>> 
>>>> Also, as Esteban says, having an IDE with support for files would mean 
>>>> that we would need good tools to edit in-memory files (not only text 
>>>> files, right? but also any kind of binary file...)
>>>> 
>>>> So far we cover the bare minimum that allows us to *not lose* changes :)
>>>> 
>>>> On Wed, Jun 13, 2018 at 11:07 PM Tim Mackinnon <tim@testit.works 
>>>> <mailto:tim@testit.works>> wrote:
>>>> 
>>>> > yeah… but is a lot of work and no time just right now.
>>>> > long term, it would be cool to manage everything from iceberg.
>>>> > but reality check, is a huge amount of work so it has to come step by 
>>>> > step.
>>>> 
>>>> Fair enough - its pretty cool we’ve got this far, and I guess the onus is 
>>>> on the rest of us to learn more about how its done and see if we can 
>>>> contribute more somehow. I really appreciate the love you’ve already put 
>>>> into this - it works far better than I think we even realised it could.
>>>> 
>>>> Tim
>>>> 
>>>> 
>>>> 
>>>> > On 13 Jun 2018, at 21:55, Esteban Lorenzano <esteba...@gmail.com 
>>>> > <mailto:esteba...@gmail.com>> wrote:
>>>> > 
>>>> > 
>>>> > 
>>>> >> On 13 Jun 2018, at 22:44, Tim Mackinnon <tim@testit.works 
>>>> >> <mailto:tim@testit.works>> wrote:
>>>> >> 
>>>> >> Esteban - so I don't then understand why iceberg (usefully in my view) 
>>>> >> checks out more than the src directory, if it’s only focusing on the 
>>>> >> Pharo blob?
>>>> >> 
>>>> >> I’m guessing that by knowing where the src is, you are just committing 
>>>> >> that part of the tree with libgit?
>>>> >> 
>>>> >> Perhaps from a pragmatic first step you might consider letting us add a 
>>>> >> second safe resources directory that you could check in atomically as 
>>>> >> well (on the understanding all bets are off if it goes wrong?)
>>>> >> 
>>>> >> OR could we have a check in mode does all the add/remove operations and 
>>>> >> writes to disk but then let’s you drop to the command line/other tool 
>>>> >> to add any other files and do the final commit?
>>>> >> 
>>>> >> I just feel like you/we are so close to something that works a bit more 
>>>> >> broadly and embrace the wider world.?
>>>> > 
>>>> > yeah… but is a lot of work and no time just right now.
>>>> > long term, it would be cool to manage everything from iceberg.
>>>> > but reality check, is a huge amount of work so it has to come step by 
>>>> > step.
>>>> > 
>>>> >> 
>>>> >> Tim
>>>> >> 
>>>> >> Sent from my iPhone
>>>> >> 
>>>> >>> On 13 Jun 2018, at 21:28, Esteban Lorenzano <esteba...@gmail.com 
>>>> >>> <mailto:esteba...@gmail.com>> wrote:
>>>> >>> 
>>>> >>> hi,
>>>> >>> 
>>>> >>> 
>>>> >>>> On 13 Jun 2018, at 16:50, Tim Mackinnon <tim@testit.works 
>>>> >>>> <mailto:tim@testit.works>> wrote:
>>>> >>>> 
>>>> >>>> Hi - my second attempt at using Pharo with Git has proven very 
>>>> >>>> satisfying (I saw the potential in phase 1, but it was often 
>>>> >>>> difficult to understand what was happening and the workflow to use).
>>>> >>>> 
>>>> >>>> One thing that has come up a few times for me however - and its 
>>>> >>>> something that using git nicely highlights, there are many 
>>>> >>>> non-smalltalk assets in my project that don’t need to live in the 
>>>> >>>> image (like Seaside FileLibraries were trying to do) but do need to 
>>>> >>>> be versioned and be part of my project. Common examples are server 
>>>> >>>> config files, images and even the playground history files that are 
>>>> >>>> useful to pull up when on another computer.
>>>> >>>> 
>>>> >>>> It seems that while Iceberg does check out a full project, if I 
>>>> >>>> change any of the files outside of the src directory (like edit a 
>>>> >>>> .txt file using the crude Pharo file editor), those changes don’t get 
>>>> >>>> committed when I do a checkin? Is this on purpose? It makes the 
>>>> >>>> workflow a bit trickier to do an atomic commit of a piece of work - 
>>>> >>>> and I’m not clear whether this is a conscious thing, or an MVP thing 
>>>> >>>> (and it will come later).
>>>> >>> 
>>>> >>> workflow is tricker because you are expecting iceberg to talk with the 
>>>> >>> local working copy and to handle that WC.
>>>> >>> what happens in fact is different: iceberg treats the image as a 
>>>> >>> working copy itself (it has its own “stage” area) and what you have in 
>>>> >>> disk is like a separated WC. 
>>>> >>> 
>>>> >>> at least, this is the metaphor we are using now, because we cannot 
>>>> >>> realistically handle/control what is in disk since it can be anything. 
>>>> >>> So, instead having this picture in mind: 
>>>> >>> 
>>>> >>> Image -> Disk -> Git blob (database)
>>>> >>> 
>>>> >>> you need to have this other: 
>>>> >>> 
>>>> >>> Image \
>>>> >>>      Git blob (database)
>>>> >>> Disk    /
>>>> >>> 
>>>> >>> 
>>>> >>> you will see as soon as you change the mental image, your problems are 
>>>> >>> gone ;)
>>>> >>> 
>>>> >>> cheers!
>>>> >>> Esteban
>>>> >>> 
>>>> >>> ps: diagram before is not exactly as it is since the image actually 
>>>> >>> writes into disk first, but this is an implementation detail we would 
>>>> >>> like to remove in the future, even.
>>>> >>> 
>>>> >>>> 
>>>> >>>> As mentioned above, I was also thinking it would be nice if I could 
>>>> >>>> checkin some of the play-xxxx/*.sh files to essentially keep some of 
>>>> >>>> that history synced between environments (or team members?).
>>>> >>>> 
>>>> >>>> It strikes me that this is the kind of thing that git integration 
>>>> >>>> should bring to us?
>>>> >>>> 
>>>> >>>> I can overlay my copy of IntelliJ on top of my local iceberg 
>>>> >>>> directory and then use it for checkins - but then I still have the 
>>>> >>>> atomic problem, as its only when I commit that tonel files are 
>>>> >>>> written out onto the file system for me to checkin along with any 
>>>> >>>> other assets I’ve changed. Does anyone else have a good workflow for 
>>>> >>>> this? What do you guys do?
>>>> >>>> 
>>>> >>>> Tim
>>>> >>> 
>>>> >>> 
>>>> >> 
>>>> >> 
>>>> > 
>>>> > 
>>>> 
>>>> 
>>>> 
>>>> 
>>>> -- 
>>>>    
>>>> Guille Polito
>>>> Research Engineer
>>>> 
>>>> Centre de Recherche en Informatique, Signal et Automatique de Lille
>>>> CRIStAL - UMR 9189
>>>> French National Center for Scientific Research - http://www.cnrs.fr 
>>>> <http://www.cnrs.fr/>
>>>> 
>>>> Web: http://guillep.github.io <http://guillep.github.io/>
>>>> Phone: +33 06 52 70 66 13
>> 
>> 

Reply via email to