nesper VS godot-nim

Compare nesper vs godot-nim and see what are their differences.

nesper

Program the ESP32 with Nim! Wrappers around ESP-IDF API's. (by elcritch)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
nesper godot-nim
9 16
179 494
- 0.8%
2.8 0.0
about 2 months ago over 1 year ago
C Nim
Apache License 2.0 GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

nesper

Posts with mentions or reviews of nesper. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-08.
  • Show HN: Program ESP32s in Nim
    1 project | news.ycombinator.com | 30 Sep 2023
  • Microsoft DeviceScript – TypeScript for Tiny IoT Devices
    9 projects | news.ycombinator.com | 8 Jun 2023
    I use Nim on embedded precisely for that reason: https://github.com/elcritch/nesper

    I wtapped much of zephyr as well but that ones less used: https://github.com/embeddednim/nephyr

  • Nim 2.0.0 RC2
    10 projects | news.ycombinator.com | 31 Mar 2023
    Nim supports both since it compiles with pretty much any C89 C compiler. Also https://github.com/elcritch/nesper :)
  • Introduction to Embedded Systems Programming (Ada)
    3 projects | news.ycombinator.com | 22 Nov 2022
    Checkout Nim! I've used it to great effect for embedded programming. It has memory management system based on non-atomic reference counting (arc) so its fast and deterministic. It has optional cycle collection too (orc). Its easy to mixin manual memory as well.

    I used F# a bit and learned a lot from it, and the same with Elixir. Nim is procedural it has an "enlightened procedural" take that feels like functional programming in some ways. Partly thats due to the very powerful type system - for example Nim lets you define custom distinct (not aliased) number types just like F#. Nim also inherits a fair bit from Pascal and so shares points with Ada like ints with custom ranges. Theres some rough points, but largely its made me enjoy programming again.

    The esp32 is a good route since they're easy to setup. I wrote a wrapper for esp-idf which is used in production in at least two embedded shops: https://github.com/elcritch/nesper

    You can run it on Arduinos as well. Theres a pure Nim setup called Ratel and a rp2040 wrapper too. :)

  • Ask HN: Who is using C++ as the main language for new project?
    26 projects | news.ycombinator.com | 12 Aug 2022
    You should checkout Nim! I use it extensively on embedded. Nim is fantastic to program in if you're an experienced C/C++ developer. Its safer and smarter but not not pedantic about it.

    Nim compiles to C or C++ so its easy to use on any embedded platform and compiler suite. Thats still huge for embedded. Rust forces a type-trait centric programming style which makes interfacing hardware/embedded harder as you have to make type heavy HALs everywhere -- hence the lack of rtos & library support despite its relative popularity).

    Its pretty trivial to re-use any C/C++ libraries which gives a big boost to the native ecosystem. I wrapped most of the esp32 idf in a few weeks: https://github.com/elcritch/nesper

    The new GC (ARC) is basically a built in `shared_ptr` or `Rc`. You can also do stack-based programming too and the compiler enforces a safe memory accesses. The performance is great and can match or beat C/C++ if you do a few hours of tuning. Though its easy kill performance if you're lazy (e.g. parse json into a bunch of heaps objects), but that can have its place.

  • Launching the 2021 Nim Community Survey
    3 projects | news.ycombinator.com | 22 Nov 2021
    I would really like to see more work on improving the use of Nim for programming microcontrollers. I stumbled on to https://github.com/elcritch/nesper recently and it looks neat, but I had issues getting my code to compile. Improved support for other MCUs like the esp8266 and atmega32u4 would be really cool and useful. It would be nice to have Nim as a higher level alternative to micropython or lua in the embedded world (your only other real alternatives being C/C++ or Rust).

    I also found this https://disconnected.systems/blog/nim-on-adruino

  • Nim Version 1.6 Released
    37 projects | news.ycombinator.com | 19 Oct 2021
    Well no language is perfect, but Nim can be used in almost every domain because of it's compilation targets(C, C++, JS) and it's fast compile times(who needs interpretation when compile times are that fast!):

    * Shell scripting, I still assume most people will just use Bash tho: https://github.com/Vindaar/shell

    * Frontend: https://github.com/karaxnim/karax or you could bind to an existing JS library.

    * Backend: For something Flask-like: https://github.com/dom96/jester or something with more defaults https://github.com/planety/prologue

    * Scientific computing: the wonderful SciNim https://github.com/SciNim

    * Blockchain: Status has some of the biggest Nim codebases currently in production https://github.com/status-im?q=&type=&language=nim&sort=

    * Gamedev: Also used in production: https://github.com/pragmagic/godot-nim and due to easy C and C++ interop, you get access to a lot of gamedev libraries!

    * Embedded: this is a domain I know very little about but for example https://github.com/elcritch/nesper or https://github.com/PMunch/badger for fun Nim+embedded stuff!

    Most of the disadvantages come from tooling and lack of $$$ support.

  • Why doesn’t V8 fit on my microcontroller?
    9 projects | news.ycombinator.com | 1 Jun 2021
    Not quite sure if I follow what you're saying. As in Tasmota/Berry do or do not do more than provide I2C/SPI?

    > If one wants to do serious stuff they would use an appropriate RTOS and program it in C.

    It's unfortunate, but still largely appears to be the case. I find C very time consuming to program, so I ported Nim to FreeRTOS [1]. It's _very_ nice being able to go from writing highly optimized ISR functions to high level JSON parsing in one language. Add in defaulting to memory safety but with no pause-the-world GC. I tried Rust but it seems more difficult to integrate into existing world RTOS'es, flashers, Swagger debuggers, etc.

    Though, I've been curious what running a WASM VM would be like? One could integrate any language: C++, C, Nim, Rust, etc. Would be interesting.

    > MongooseOS does more than this if we're talking ESP32, also other devices, Javascript, C, C++, commercial support, cloud based OTA upgrades and integration with AWS, Azure, Google and IBM Watson IoT cloud services.

    MongooseOS does seem interesting, but very targeting a niche market with prebuilt needs? For future RTOS'es I think ZephyrOS [2] has a lot of potential given it's now supported by NXP [3], TI, and others but is independent of any given (cloud) vendors or other IoT companies. Some might not like the CMake based build system, but in my view all the RTOS build systems are terrible in their own special way.

    1: https://github.com/elcritch/nesper

  • uLisp
    18 projects | news.ycombinator.com | 4 May 2021

godot-nim

Posts with mentions or reviews of godot-nim. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-07-12.
  • Plans for Nim bindings for Godot 4
    1 project | /r/godot | 13 Jul 2022
    Since Godot 4 is gonna change their binding system the previous Nim bindings are not gonna work and the maintainers stated that they wont adapt the bindings to Godot 4.
  • Plans for Nim bindings for Godot 4?
    4 projects | /r/nim | 12 Jul 2022
    Since Godot 4 is gonna change their binding system the previous [Nim bindings](https://github.com/pragmagic/godot-nim)
  • Programming a Rogue-Like with Rust
    9 projects | news.ycombinator.com | 12 Jul 2022
    Another option is Nim. Looks and writes like Python but closer to C in performance. It also has static typing so I prefer it for scripting as well.

    People have built a few games with the Nim Godot bindings:

    https://github.com/pragmagic/godot-nim

    There’s also an interesting project to do hot reloading using dlls:

    https://github.com/geekrelief/gdnim

  • Inky: Isolation. A 90 minute game built with Enu, Nim and Godot
    3 projects | /r/nim | 3 Jun 2022
    Enu is a 3D live-programming/learning/game development environment written in Nim using Godot 3, godot-nim, and godot_voxel. I use it to run a small local coding club with a group of 12 year olds, and think it is (or at least will be) a great tool for learning to code, and for making games quickly.
  • Is Nim right for me?
    6 projects | /r/nim | 7 Mar 2022
    It uses a python-like language, is free & open-source (MIT License), has a fantastic GUI creation system, exports to all major OS's, and produces single small binaries. You could eventually incorporate Nim as well, as there are Nim bindings for Godot.
  • How can I understand what "bindings to" libraries really do?
    3 projects | /r/nim | 23 Jan 2022
  • FYI, you can use Rust as a native scripting language
    6 projects | /r/godot | 26 Nov 2021
    Ant then install the bindings. And thats where I'm a bit lost even after reading Godot docs. Not sure if I'm right, but seems to be necessary to compile Godot?
  • Nim Version 1.6 Released
    37 projects | news.ycombinator.com | 19 Oct 2021
    Well no language is perfect, but Nim can be used in almost every domain because of it's compilation targets(C, C++, JS) and it's fast compile times(who needs interpretation when compile times are that fast!):

    * Shell scripting, I still assume most people will just use Bash tho: https://github.com/Vindaar/shell

    * Frontend: https://github.com/karaxnim/karax or you could bind to an existing JS library.

    * Backend: For something Flask-like: https://github.com/dom96/jester or something with more defaults https://github.com/planety/prologue

    * Scientific computing: the wonderful SciNim https://github.com/SciNim

    * Blockchain: Status has some of the biggest Nim codebases currently in production https://github.com/status-im?q=&type=&language=nim&sort=

    * Gamedev: Also used in production: https://github.com/pragmagic/godot-nim and due to easy C and C++ interop, you get access to a lot of gamedev libraries!

    * Embedded: this is a domain I know very little about but for example https://github.com/elcritch/nesper or https://github.com/PMunch/badger for fun Nim+embedded stuff!

    Most of the disadvantages come from tooling and lack of $$$ support.

  • Frustrating ergonomics of GDNative in 3.3 -- are these addressed for 4.0?
    4 projects | /r/godot | 18 May 2021
    As for gdnim, it's my framework built on top of godot-nim. https://github.com/pragmagic/godot-nim https://github.com/pragmagic/godot-nim-stub
  • PR for cross-language script class support is testable! (`class_name` feature for GDScript, VisualScript, C#, and NativeScript)
    2 projects | /r/godot | 27 Dec 2020
    I've renewed my enjoyment of programming through game development (an area I haven't been active in before) and had a great time implementing a Quadtree in GDScript but then the other problem of raw execution speed for any script language made that a bit disappointing as well (it worked well but was only an improvement for larger numbers). So now I'm learning Nim (which has godot-nim bindings) to be able to write really performant code in an easy way.

What are some alternatives?

When comparing nesper and godot-nim you can also consider the following projects:

quickjs-esp32 - QuickJS port for ESP32

gdnim - godot-nim based bootstrapping framework supporting hot reloading

nim-esp8266-sdk - Nim wrapper for the ESP8266 NON-OS SDK

pixie - Full-featured 2d graphics library for Nim.

ecl

nvim-treesitter-textobjects

ulisp - A version of the Lisp programming language for ATmega-based Arduino boards.

nlvm - LLVM-based compiler for the Nim language

embedded-hal - A Hardware Abstraction Layer (HAL) for embedded systems

enu - A Logo-like 3D environment, implemented in Nim

Nim - Nim is a statically typed compiled systems programming language. It combines successful concepts from mature languages like Python, Ada and Modula. Its design focuses on efficiency, expressiveness, and elegance (in that order of priority).

httpbeast - A highly performant, multi-threaded HTTP 1.1 server written in Nim.