Hello Allistair I have used Slang only once and it was generating code that was indeed readbale but my aim is for more finer control over the output. Lets say I want import a specific C header file or I want a string to map to custom C type I created etc. So yes Slang is by no mean a bad tool at all its just is not designed with making source output that is undetectable as autogenerated by a human. But I will have to give it a more serious try because it may be closer than I initially thought.
I am not against the usage of pragmas, and indeed are an excellent way to annotate stuff , my only concern is when I may want to annotate in place for some weird reason , but that may be doable with pragmas as well too. Smalltalk code that is 100% smalltalk should be able to execute , you mention however the execution of external C functions , problem is that in my case that code does not live in DLLs but in an executable so no I am not amaing to that level of execution. Also I have an easier solution for this too, when I made the CPPBridge, which is a Pharo library that allows the usage of C++ libraries from Pharo, I used a shared memory bridge to communicate back to Pharo giving the ability of both function calls and callbacks. If I really want to capture execution I can do it like this which is the exact opposite of what you do, instead of the VM capturing the executable it will be the executable capturing the VM if that makes any sense. This makes things far easier. As a matter of fact not only my CPPBridge does this it also allows to extend the pharo image file because it uses memory mapped files for the shared memory which like pharo image files are memory dumps. So there is a lot potential in that department. However my main goal is to use Smalltalk code execution to make sure the prototype works on a basic level, there will be a C cide in this project obviously which will act like a runtime that will provide live coding features. This is also a library I made in C that does this through the usage of DLLs that rebuilds and reloads dynamically. So I dont really need the VM to execute my code to check that is working cause the C compiler and the live coding runtime can handle this. I could even hook in the Pharo debugger, I have done this with my Atlas library that allows to use Python library from Pharo by sending the python error back to Pharo debugger where it triggers an error and the debugger pops to allow you to do your usual live coding magic and basically resends the code back to python. Because of my C livecoding library I can do this with C too. My only concern is how the C/C++ compiler reports errors because obviously it known that it kinda sucks on this. But hey I cannot make C better :D Generally speaking the tools I am making are not designed for general consuption but designed to solve my own problems. Of course I like to share them because there is always the chance for someone to find them useful as it has happened with Atlas for example. Plus as happened with Atlas one can take my code and adjust it to his or her personal needs. On Wed, Oct 17, 2018 at 1:04 PM Alistair Grant <akgrant0...@gmail.com> wrote: > Hi Dimitris, > > As someone currently learning to use Slang (i.e. not an expert), I've > added my 2c below... > > On Wed, 17 Oct 2018 at 11:06, Dimitris Chloupis <kilon.al...@gmail.com> > wrote: > > > > Thierry you have done it !!! you just gave a very easy solution to my > problems. > > > > Yeap Slang is quite close to what I am thinking, unfortunately Clement > told me to stay away from it because the code is ugly and specially used > for VM only. If I remember also correctly it does not generate readable C > code either. But the idea as a concept is very close to what I imagine. > > I've found the C code produced to be quite readable, but that is > probably influenced by the fact that I have read the slang first. > > > > As a matter of fact you mentioning Slang made I have an epiphany that I > dont have to create a new syntax at all, instead I could use specific > variables or methods to provide type annotation. Thus like Slang I can use > regular Smalltalk code that avoids changing types but without the need for > type inference (although I am not excluding this either). > > > > So yes I am definetly want to move to the direction that Slang goes so I > can fully utilise the Pharo IDE and minise code that I have to write. > > > > So basically I am thinking write code as you always write in Pharo and > either > > a) Have special dictionary variables in each method that provide static > type annotations for the arguments of the methods, its return type and > local variables > > Slang uses method pragmas to define the variables types. This seems > to work quite well. > > > > b) Have special methods that provide such dictionaries seperately. > > > > Or probably both. This way I can write 100% Smalltalk code and use a > very small compiler to read those dictionary variables for the type of the > variables and functions/structs (essentially a class will be output for a C > struct with pointers to functions for methods and variables for instance > variables). Why invent a whole new language when everything I need already > Pharo provides ? > > I could also use special variable dictionaries for all sort of things > like generation of header files, generation of CMake files for automatic > building. > > > > Also I like to use the way UFFI is doing C function signatures by using > symbol arrays. > > > > So thank you all for inspiration it looks like all I need is Pharo AST > methods (which I can from the AST packages) and SmaCC. > > So yeap looks like Magnatar will be a new Slang afterall, I will keep > you posted. > > > > Also this also opens the possibility of autowrapping the generated c > code back to Pharo through UFFI, so one can use C code as if its Pharo > code. I can leverage the TalkFFI project that does this already. Seems all > the pieces have fallen in their place. > > > > Keep the suggestions and advice coming, you guys are inspirational :D > > Do you intend that the Smalltalk code can be executed? This will > likely increase the complexity quite a bit. In the VM simulation we > end up creating a XSimulation subclass that provides the framework for > executing the smalltalk code, e.g simulating functions that are only > in C. > > There is also the problem of platform differences. Slang doesn't > really handle them well (pragmas can be used to indicated that methods > should only be compiled on certain platforms, and #ifdef type code can > be used, but it isn't enough). It would be nice to have a class that > provides cross platform functionality, and then platform specific > classes as required. > > HTH, > Alistair > >