www.digitalmars.com         C & C++   DMDScript  

digitalmars.D.learn - Kotlin Meta and CT programming vs D

reply Jo Blow <JoBlow dot.com> writes:
I used to program in D heavily many years ago then stopped 
because, basically, the D ecosystem sucks. Amazing language but 
getting anything significant done was a PITA.

Anyways, I moved to Kotlin/android to write some apps about 2 
months ago and made great progress(I did more in 2 weeks than 
I've done in a year of D programming and this includes learning 
the language, the IDE, etc). Everything just worked as expected 
and was simple to use. Maybe the biggest issue was figuring out 
all the Gradle BS but I eventually got the hang of it. I was able 
to get a simple app to view PDF, play audio, jni(using FFPEG), 
etc within about a week. This is unlike D where basically you 
have 3 different packages you have to use, hope they work, and 
then figure out how to get them to work in the system. With 
android basically it just works and all the boilerplate crap is 
basically abstracted out(it's designed for a modern system rather 
than some console based system that D was). The IDE is pretty 
nice too since it works well with the language.

In any case, it was a great experience for the first month or so 
but then when I started looking for more complicated "D like" 
features such as CT/meta programming they don't seem to actually 
exist... at least not in the way one thinks and seems to be quite 
limited.

It has runtime reflection which, for the most part, is your 
standard introspection on types. It's not as robust as D's 
reflection and not compile time but there are some nice features 
that work well for basic stuff.

But there have been several cases when I have asked others about 
trying to do certain "compile time" things in Kotlin that say it 
can't be done. It seems that there is actually no compile time 
programming in Kotlin(and I guess Java too?)? That at best one 
has to work in some DSL like thing that uses a "plugin" but 
things that make D shine because you can just get shit done, 
usually several ways, doesn't exist. Things like string mixins, 
CTFE, etc. D would be an amazing language to use if it was 
integrated into android studio like Kotlin.

Anyways, the entire point of this point is to ask this question: 
Is anyone who is pretty familiar with Kotlin and it's compile 
time programming willing to explain what the heck is really going 
on with it and why it seems so different to D's?

The way I see D's metal language was that essentially anything 
that was "defined at compile time" could be treated as a program 
at compile time and all the compile time information would be 
filled in as such since it could. If code could be determined to 
be completely well-defined at compilation then it could simply be 
"executed"(evaluated) at compile time(in a first pass). Kotlin 
doesn't seem to have anything like this. It doesn't even have 
string mixins or eval without including a kotlin compiler inside 
the language.

I'm wondering if it would be worth the effort to try to get D to 
work with android studio since it can compile to all those. E.g., 
write the jetpack compose code in kotlin and hook up the business 
in with D somehow. If it wasn't too much trouble and worked well 
then this might give one the best of both worlds. JNI is a bit of 
a PIA when trying to call java from C because one has to use 
reflection for every aspect and it is very long winded. This 
probably could be simplified greatly with some D meta programming.
Dec 18
next sibling parent zjh <fqbqrr 163.com> writes:
On Thursday, 19 December 2024 at 06:04:33 UTC, Jo Blow wrote:
 I used to program in D heavily many years ago then stopped 
 because, basically, the D ecosystem sucks. Amazing language but 
 getting anything significant done was a PITA.
D is a better version of `C++`.
Dec 18
prev sibling next sibling parent reply "H. S. Teoh" <hsteoh qfbox.info> writes:
On Thu, Dec 19, 2024 at 06:04:33AM +0000, Jo Blow via Digitalmars-d-learn wrote:
[...]
 I'm wondering if it would be worth the effort to try to get D to work
 with android studio since it can compile to all those. E.g., write the
 jetpack compose code in kotlin and hook up the business in with D
 somehow. If it wasn't too much trouble and worked well then this might
 give one the best of both worlds. JNI is a bit of a PIA when trying to
 call java from C because one has to use reflection for every aspect
 and it is very long winded. This probably could be simplified greatly
 with some D meta programming.
Check out Adam Ruppe's jni.d. It just about eliminates JNI verbosity and makes working with Java actually temptingly pleasant. Only caveat is that Adam has left mainline D and is maintaining his own fork, so jni.d may or may not work with upstream D in its present form. (Pre-fork versions of jni.d would work with a compatible upstream D, though.) T -- All problems are easy in retrospect.
Dec 19
parent reply Jo Blow <JoBlow dot.com> writes:
On Thursday, 19 December 2024 at 10:31:54 UTC, H. S. Teoh wrote:
 On Thu, Dec 19, 2024 at 06:04:33AM +0000, Jo Blow via 
 Digitalmars-d-learn wrote: [...]
 I'm wondering if it would be worth the effort to try to get D 
 to work with android studio since it can compile to all those. 
 E.g., write the jetpack compose code in kotlin and hook up the 
 business in with D somehow. If it wasn't too much trouble and 
 worked well then this might give one the best of both worlds. 
 JNI is a bit of a PIA when trying to call java from C because 
 one has to use reflection for every aspect and it is very long 
 winded. This probably could be simplified greatly with some D 
 meta programming.
Check out Adam Ruppe's jni.d. It just about eliminates JNI verbosity and makes working with Java actually temptingly pleasant. Only caveat is that Adam has left mainline D and is maintaining his own fork, so jni.d may or may not work with upstream D in its present form. (Pre-fork versions of jni.d would work with a compatible upstream D, though.) T
Ok, I'll try it if I ever get the urge to try to get D to work(maybe a different project). I want to start using multiplatform projects and maybe I'll try there once I get this one project done. If I could essentially use D as a replacement for Kotlin I might jump back into D. Kotlin has a few very nice language features that D doesn't have that I'll miss but it's not really that relevant. Although, I think I might still prefer Kotlin because I doubt the IDE will work well with D. There really should be some push to get D integrated into some major platform. Maybe D could be the "JNI language" for the Android platform?
Dec 21
parent reply "H. S. Teoh" <hsteoh qfbox.info> writes:
On Sat, Dec 21, 2024 at 07:06:12PM +0000, Jo Blow via Digitalmars-d-learn wrote:
[...]
 There really should be some push to get D integrated into some major
 platform. Maybe D could be the "JNI language" for the Android
 platform?
This is the difference between a corporate-backed and funded project vs. a project mostly driven by volunteers. D doesn't have the financial clout to be able to push for things to happen on Android, for example. Sure, someone *could* create a system that lets D work smoothly on Android, but it's highly unlikely Google would adopt it. Unless it somehow manages to spread like wildfire in a grassroots fashion among the Android developer base. I'm not holding my breath, though, much as I'd like to see it happen. T -- Winners never quit, quitters never win. But those who never quit AND never win are idiots.
Dec 21
parent Jo Blow <JoBlow dot.com> writes:
On Sunday, 22 December 2024 at 00:00:05 UTC, H. S. Teoh wrote:
 On Sat, Dec 21, 2024 at 07:06:12PM +0000, Jo Blow via 
 Digitalmars-d-learn wrote: [...]
 There really should be some push to get D integrated into some 
 major platform. Maybe D could be the "JNI language" for the 
 Android platform?
This is the difference between a corporate-backed and funded project vs. a project mostly driven by volunteers. D doesn't have the financial clout to be able to push for things to happen on Android, for example. Sure, someone *could* create a system that lets D work smoothly on Android, but it's highly unlikely Google would adopt it. Unless it somehow manages to spread like wildfire in a grassroots fashion among the Android developer base. I'm not holding my breath, though, much as I'd like to see it happen. T
It would at least take people who actually are heavily into D to actually go talk to google and show them the benefits it would have. It would require people to actually essentially petition google. It likely would take some work to get a prototype going to at least demonstrate it. Although one could argue why D and not something like Haskell. Given all the insanity in the world now though it is very unlikely to happen. Humanity is going into a very dark time which will slow things down significantly and likely lead to some major catastrophic events that might make all this moot. The lunatics run the asylum and they like to play with consequences that they don't understand the ramification and the only way out of such things is for them to destroy everything including themselves. I'm pretty sure Pandora's box has been opened. In any case, Just an idea, Since D has an llvm version could that be leveraged in any way to have it output Java IR or Kotlin code. The idea would mainly be not to have the full functionality of D(such as all the libraries) but to have it's meta programming features. Basically use it for the business end design and have the D compiler resolve all the compile time stuff but then output the results into Kotlin(or whatever). Since at the end of the day the compile time stuff is going to basically just be type relations and object manipulation there would essentially be a 1 to 1 connection(one could likely even translate some runtime reflection stuff).
Dec 21
prev sibling next sibling parent reply =?UTF-8?B?SsO8cmdlbg==?= Reichmann <jr rdvsb.de> writes:
Hi Jo,

metaprogramming in Kotlin is possible by writing compiler plugins
see https://kt.academy/article/ak-compiler-plugin
or 
https://resources.jetbrains.com/storage/products/kotlinconf2018/slides/5_Writing%20Your%20First%20Kotlin%20Compiler%20Plugin.pdf

An alternative approach would be
https://www.baeldung.com/kotlin/kotlinpoet
"KotlinPoet is an open-source library that generates Kotlin 
source code."

Kind regards
Jürgen
Dec 19
parent Jo Blow <JoBlow dot.com> writes:
On Thursday, 19 December 2024 at 11:13:38 UTC, Jürgen Reichmann 
wrote:
 Hi Jo,

 metaprogramming in Kotlin is possible by writing compiler 
 plugins
 see https://kt.academy/article/ak-compiler-plugin
 or 
 https://resources.jetbrains.com/storage/products/kotlinconf2018/slides/5_Writing%20Your%20First%20Kotlin%20Compiler%20Plugin.pdf

 An alternative approach would be
 https://www.baeldung.com/kotlin/kotlinpoet
 "KotlinPoet is an open-source library that generates Kotlin 
 source code."

 Kind regards
 Jürgen
Yeah, I came across Poet when I was trying to see how to do metaprogramming. At the time I couldn't find anything and the link helps explain it but it's sorta like "whats the point". I can do that stuff just using strings. It might work out well for certain things(I imagine one can write a string mixin and stuff). When I was trying to do anything with it the problem I was really having was that I needed to either generate or rewrite code. It seems Poet can't rewrite code but it can generate. But the issue I was having was that to generate a piece of code I 1. needed to access the project code so I could "reflect" on it. 2. Add have the project then use that piece of code. To generate the code I used a build task but then then it couldn't access the project code. I'd post the build task but I can't seem to find it but basically it just ran the kotlin code I was using to generate the file but it needed a type from my project to reflect over which I couldn't figure out how to get it to be able to see. To solve that I just started calling it in my app rather than the task and essentially manually did the work(luckily I rarely have to mess with it). So basically there is a dependency issue here: To generate the code I need access to the project after it was partially built up to that point then needed to include that generated code. I thought I would try putting the dependencies part in a new module but it became a mess real quick. It might be my own ignorance of how everything works but I don't think things like KotlinPoet will solve that since they are just a structured way of building code. It will still have the problem. D just works in this case as it automatically takes care of these intra-dependencies without issue.
Dec 21
prev sibling next sibling parent reply Sergey <kornburn yandex.ru> writes:
On Thursday, 19 December 2024 at 06:04:33 UTC, Jo Blow wrote:
 In any case, it was a great experience for the first month or 
 so but then when I started looking for more complicated "D 
 like" features such as CT/meta programming they don't seem to 
 actually exist... at least not in the way one thinks and seems 
 to be quite limited.
Maybe it is also worth to check Groovy meta-programming abilities (including AST and macros).
Dec 22
parent Jo Blow <JoBlow dot.com> writes:
On Sunday, 22 December 2024 at 10:56:26 UTC, Sergey wrote:
 On Thursday, 19 December 2024 at 06:04:33 UTC, Jo Blow wrote:
 In any case, it was a great experience for the first month or 
 so but then when I started looking for more complicated "D 
 like" features such as CT/meta programming they don't seem to 
 actually exist... at least not in the way one thinks and seems 
 to be quite limited.
Maybe it is also worth to check Groovy meta-programming abilities (including AST and macros).
https://www.baeldung.com/groovy-metaprogramming That does look more "D" like and if it has things like traits and string mixins then I probably could get used to it. But I doubt it can interface with or replace Kotlin? The main reason I use Kotlin is because of jetpack compose which is quite easy to use. Although I don't like the way it deals with state as it can be a PITA to figure what really is going on at times. If, say, I could write UI code in Kotlin and then business end in Groovy and the compiler or IDE takes care of hooking everything up(just as if I were to write the business end in Kotlin) then I would likely use it. That is, if I can import packages and types from one into the other implicitly then it will work.
Dec 22
prev sibling parent reply Renato Athaydes <renato athaydes.com> writes:
On Thursday, 19 December 2024 at 06:04:33 UTC, Jo Blow wrote:
 But there have been several cases when I have asked others 
 about trying to do certain "compile time" things in Kotlin that 
 say it can't be done. It seems that there is actually no 
 compile time programming in Kotlin(and I guess Java too?)? That 
 at best one has to work in some DSL like thing that uses a 
 "plugin" but things that make D shine because you can just get 
 shit done, usually several ways, doesn't exist. Things like 
 string mixins, CTFE, etc. D would be an amazing language to use 
 if it was integrated into android studio like Kotlin.
Those features are exactly what makes D such a difficult language to provide good support for in an IDE. Even things that are trivial in languages like Kotlin, like removing unused imports, can't be easily done in D (I was told that in a discussion about why that didn't work at all with D). Kotlin and Java have always taken IDE integration seriously and would not add a feature that "breaks" the IDE, even if that makes compile-time programming impossible. Reflection is heavily used by frameworks, but nearly never in application code, exactly because it makes IDE support and static analysis impossible.
 Anyways, the entire point of this point is to ask this 
 question: Is anyone who is pretty familiar with Kotlin and it's 
 compile time programming willing to explain what the heck is 
 really going on with it and why it seems so different to D's?
As someone coming the opposite way, D metaprogramming looks like pure magic. It's mind blowing (and so completely underrated, Zig is getting all the attention for having something similar but still less powerful). But yeah, the cost of those features seem to be bad IDE support, which kind of sucks, for sure. Kotlin has annotation processors, like Java, which are about the only metaprogramming you can do outside of just writing code that explicitly generates source code (which you can do easily enough with https://github.com/palantir/javapoet for Java, or the Kotlin spinoff: https://square.github.io/kotlinpoet/ This is the current Kotlin solution: https://kotlinlang.org/docs/ksp-overview.html As far as I know, almost no one uses this though. People are happy to just NOT do anything at compile-time, I guess it's hard to believe that if you come from D, but it's indeed possible.
 The way I see D's metal language was that essentially anything 
 that was "defined at compile time" could be treated as a 
 program at compile time and all the compile time information 
 would be filled in as such since it could. If code could be 
 determined to be completely well-defined at compilation then it 
 could simply be "executed"(evaluated) at compile time(in a 
 first pass). Kotlin doesn't seem to have anything like this. It 
 doesn't even have string mixins or eval without including a 
 kotlin compiler inside the language.
Correct. Kotlin and Java people would be horrified of those features, I think :D Again, because of IDE and tooling support.
 I'm wondering if it would be worth the effort to try to get D 
 to work with android studio since it can compile to all those. 
 E.g., write the jetpack compose code in kotlin and hook up the 
 business in with D somehow. If it wasn't too much trouble and 
 worked well then this might give one the best of both worlds. 
 JNI is a bit of a PIA when trying to call java from C because 
 one has to use reflection for every aspect and it is very long 
 winded. This probably could be simplified greatly with some D 
 meta programming.
You're absolutely correct that with D, you could easily generate stuff like JNI bindings. But notice that JNI is going to be replaced with a new solution: https://docs.oracle.com/en/java/javase/21/core/foreign-function-and-memory-api.html This is still in preview but you may want to look at it if you find JNI too horrible. Regarding whether D could be a good option for Android, I very much doubt it. You can't remove the nice tools people are used to in the Java/Kotlin world, if you try you will get a very large backlash... and I'm afraid D will never have as good tools even if it some day gets huge corporate backing because the language was not designed to allow that to be possible (maybe it is possible, but I doubt it's actually feasible - correct if I am wrong), from the list of features it is very clear that was absolutely never a high priority concern.
Dec 23
parent Renato Athaydes <renato athaydes.com> writes:
I forgot to mention, Kotlin also has some features that rely on 
compiler plugins, like serialization: 
https://kotlinlang.org/docs/serialization.html#formats, usually 
done via Gradle plugins.

This would normally be done via reflection, as Google's JSON 
library for Java, Gson, does. But by having a compiler plugin, 
they generate source code at "compile time" which basically looks 
at the type declaration and generates custom-made handlers that 
can parse/write JSON for them.
Dec 23