[prev in list] [next in list] [prev in thread] [next in thread]
List: kde-buildsystem
Subject: Re: Is ECM a good place for implementing Nim support in CMake?
From: Alexander Neundorf <neundorf () kde ! org>
Date: 2024-04-28 19:58:26
Message-ID: 1975769.yKVeVyVuyW () unknownc4d9870202f1
[Download RAW message or body]
On Sonntag, 28. April 2024 12:50:06 CEST Albert Astals Cid wrote:
> El divendres, 19 d'abril del 2024, a les 11:17:09 (CEST), Anna (cybertailor)
> Vyalkova va escriure:
> > Hi,
> >
> > I'd like to develop Nim applications (with possible GUI support via
> > nimqt) but this language lacks support for any standard build system.
> >
> > So that's the thing I'm focused on right now (just happened to also be
> > my favorite thing).
> >
> > Alternatives I considered:
> >
> > 1. Procedure described in "CMakeAddNewLanguage.txt". First of all,
> > that's scary and second it doesn't cover my use case: Nim is not a
> > compiler but rather a transpiler. It compiles Nim code into C/C++/JS
> > code and then calls system compiler to get native binaries. These steps
> > could be separated.
> >
> > 2. Going with my own "nim-for-cmake" module library. That's possible but
> > requires lots of boilerplate code that can be avoided if these modules
> > become part of ECM.
> >
> > I've implemented an alternative build system for Nim's "nimble" packages
> > before so I know the necessary steps: 1) find the compiler, 2) find the
> > deps, 3) generate a json-script, 4) extract the depfiles, 5) execute the
> > script.
> >
> > Can I start making such ECM module or should it be a separate CMake
> > module library?
>
> You will probably find more people that know about ECM in kde frameworks
> devel mailing list than here, this list is nowadays pretty dormant.
>
> My suggetsion would be, talk to the cmake folks, they are a relatively open
> bunch of people that like their build system to support as many things
> possible and what you really want is to have support in cmake itself, not
> having to include some extra stuff to make it work.
yes, right here, probably the "Development" channel:
https://discourse.cmake.org/[1]
Alex
--------
[1] https://discourse.cmake.org/
[Attachment #3 (unknown)]
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
</head>
<body><p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">On \
Sonntag, 28. April 2024 12:50:06 CEST Albert Astals Cid wrote:</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> El divendres, \
19 d'abril del 2024, a les 11:17:09 (CEST), Anna (cybertailor)</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> Vyalkova va \
escriure:</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> Hi,</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> </p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> I'd like to develop Nim applications (with possible GUI support via</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > nimqt) \
but this language lacks support for any standard build system.</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > </p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > So \
that's the thing I'm focused on right now (just happened to also be</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > my \
favorite thing).</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > </p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > \
Alternatives I considered:</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > </p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > 1. \
Procedure described in "CMakeAddNewLanguage.txt". First of all,</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > that's \
scary and second it doesn't cover my use case: Nim is not a</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > compiler \
but rather a transpiler. It compiles Nim code into C/C++/JS</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > code and \
then calls system compiler to get native binaries. These steps</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > could be \
separated.</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> </p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> 2. Going with my own "nim-for-cmake" module library. That's possible \
but</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> requires lots of boilerplate code that can be avoided if these modules</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > become \
part of ECM.</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> </p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> I've implemented an alternative build system for Nim's "nimble" \
packages</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> before so I know the necessary steps: 1) find the compiler, 2) find the</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > deps, 3) \
generate a json-script, 4) extract the depfiles, 5) execute the</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > \
script.</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> </p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
> Can I start making such ECM module or should it be a separate CMake</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> > module \
library?</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> \
</p> <p style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> You \
will probably find more people that know about ECM in kde frameworks</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> devel mailing \
list than here, this list is nowadays pretty dormant.</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> </p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> My suggetsion \
would be, talk to the cmake folks, they are a relatively open</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> bunch of \
people that like their build system to support as many things</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> possible and \
what you really want is to have support in cmake itself, not</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">> having to \
include some extra stuff to make it work.</p> <br /><p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">yes, right here, \
probably the "Development" channel:</p> <p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;"><a \
href="https://discourse.cmake.org/">https://discourse.cmake.org/</a></p> <br /><p \
style="margin-top:0;margin-bottom:0;margin-left:0;margin-right:0;">Alex</p> <br /><br \
/><br /></body> </html>
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic