Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Looks like there is a huge overlap with MAGIC compiler? #4

Open
divs1210 opened this issue Jan 26, 2023 · 6 comments
Open

Looks like there is a huge overlap with MAGIC compiler? #4

divs1210 opened this issue Jan 26, 2023 · 6 comments

Comments

@divs1210
Copy link

Magic is another cleaner Clojure CLR implementation.

What are the similarities / differences?

How to decide which ClojureCLR implementation to use?

@dmiller
Copy link
Owner

dmiller commented Jan 26, 2023

Magic and related projects are built on top of the current ClojureCLR implementation. It is not a standalone.
With this project I hope to do a complete rewrite of ClojureCLR and incorporate all the tremendous work Ramsey Nasser has done on compiler techniques. So, eventually I hope there will be a major overlap.

As for current state, I have to defer to Ramsey on how best to use Magic.

@FalseProtagonist
Copy link

Is it best to use magic right now or original clojureclr?

@dmiller
Copy link
Owner

dmiller commented Feb 16, 2023

What are you trying to do?
I have no idea of the current capabilties of Magic+Nostrand.
I suggest you contact Ramsey Nasser.

@FalseProtagonist
Copy link

In the dream scenario I'd replace (at least most of) a C# VSTO excel add-in with a clojureCLR powerred version. Sorry if the previous was an annoying question/not your question to answer. A more concrete question would be: is ClojureCLR currently likely to be solid enough for that usecase in production? I've scoured google groups, wiki, issues etc and can see that it's been used by people but also isn't the biggest project in the world so have never gone whole-hog and tried it.

@bcalco
Copy link

bcalco commented Feb 16, 2023

In the dream scenario I'd replace (at least most of) a C# VSTO excel add-in with a clojureCLR powerred version. Sorry if the previous was an annoying question/not your question to answer. A more concrete question would be: is ClojureCLR currently likely to be solid enough for that usecase in production? I've scoured google groups, wiki, issues etc and can see that it's been used by people but also isn't the biggest project in the world so have never gone whole-hog and tried it.

It so happens we (Apex Data Solutions) are already working on ClojureCLR integration with Office as part of our commercial product, which is called Accelerate. The main goal is legacy VBA app modernization, but also alternative ways to bring LAMBDAs into Excel and leverage Office artifacts as microservices. We've already successfully integrated IronScheme into it, but are adding ClojureCLR for some things it can do on .NET that IronScheme presently cannot (like create CLR types and subtypes). if you're interested to know more about that let me know.

@nasser
Copy link
Collaborator

nasser commented Jul 12, 2024

MAGIC is built on David's ClojureCLR runtime so i would not characterize it as a "cleaner" implementation. It was started because the Arcadia project needed to run on iOS devices and to do that we needed to remove a few specific dynamic runtime components that ClojureCLR depends on. We also explored some aggressive optimizations for Unity3D/game development specific workflows, specifically local mutation of struct values for linear algebra code.

I would not recommend using MAGIC as is. It was built for a specific use case which is different from what is described here, and it is not getting any updates for the foreseeable future because my own commercial work does not involve Clojure or Unity anymore, so I cannot justify allocating my solo time to it. Further, the commercial clients that supported its development for a period are no longer able to do so.

That said it is "done" in the sense that it passed the Clojure test suite and successfully ran non-trivial Clojure programs on iOS. I think its a good object of study or something to build on, but it needs work to bring it in line with the changes in Clojure and dotnet that have happened since its last commits. Happy to offer guidance to anyone interested.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants