-
Notifications
You must be signed in to change notification settings - Fork 63
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
Support for C++20 ranges #48
Comments
Looks like you are using Arduino-esp32 core version 2.0.14, which is based on ESP-IDF v4.x, which uses GCC 8.4.x for its toolchain. Newer IDF versions are already using the newer versions of GCC (12.2, 13.2). The upcoming Arduino-esp32 v3.0.0 release will be based on IDF v5.1.x, so the functionality you are looking for will be available there. Here is the project which tracks the 3.0.0 release of Arduino-esp32 core: https://github.com/orgs/espressif/projects/3/views/14 |
Thank you for the very quick and helpful reply! Whoa, that's quite a jump in the GCC versions. I gather that pre-releases of version 3.0.0 are available here: https://github.com/espressif/arduino-esp32/releases Do you know whether it would be possible to change my setup to use that? |
Platformio does not yet have support for arduino-esp32 v3.0.0 pre-releases, however there is a fork maintained by Tasmota which already supports this version: https://github.com/Jason2866/platform-espressif32. Perhaps you can try it and see if that works. |
Alright, that sounds great, I'll give it a try! Thanks for pointing me in the right direction. I suppose we can close this issue then :) |
I just crashed into this hard. I was questioning my sanity because I "knew" that the latest updates used IDF 5.1 and IDF 5.1 used GCC13 and I'd recently confirmed that my g++ brothers are indeed gcc13 with a correspondingly recent libstdc++. I even knew that I don't even know where it's finding that: .espressif/tools/xtensa-esp-elf/esp-13.2.0_20230928/xtensa-esp-elf/bin/xtensa-esp32s3-elf-g++ [ hammer drops ] $ find .platformio -name xtensa-esp32s3-elf-g++ .platformio/packages/[email protected]+2021r2-patch5/bin/xtensa-esp32s3-elf-g++ It's in $HOME and hidden, so it doesn't show up in finder or locate. Awesome...and it's not been updated since 2018, which explains why {fmt} and ranges and such are problematic. I didn't understand that a project linking a compatibility shim with AVR would hold back the toolchain like this. That's pretty wild. The second line of https://github.com/platformio/platform-espressif32/releases says "updated to IDF 5.2.1" and that doc says "This has now been upgraded to GCC 13.2.0 " ... but it seems to still be using a 6 y/o g++ behind the covers. It still claims pretty modern C++23 support in https://docs.espressif.com/projects/esp-idf/en/v5.1.3/esp32/api-guides/cplusplus.html#cplusplus-limitations https://blog.espressif.com/announcing-the-arduino-esp32-core-version-3-0-0-3bf9f24e20d4 shows the 3.0 transition for that package should have embraced IDF 5.1 months ago and https://github.com/orgs/espressif/projects/3/views/14 looks more empty than not. I've updated every IDF and PIO package I can find. I feel like I'm missing a joke somewhere in all the layers of abstraction. I have a g++ in my path that's not being used. It reports framework-arduinoespressif32 version 3.2. Is there some cached value or .ini tweak I need to make to get it to really match what esp-idf/export.sh is reporting? I know this is an older (and closed) report, but is the current advice for anyone needing a g++ from the last six years still to go to another toolchain? Sorry if I'm sounding cranky but all these independently maintained layers hiding the details of the other layers, but missing six years worth of language updates is pretty frustrating. (We experience UNIX dudes tend to always sound cranky at all this stuff in the way of our Makefiles. :-) ) Updating IDF to 5.1.3, pio upgrade 6.1.5, and all the pio pkg updates doesn't seem to be updating the right things. Something between ESP_IDF and this pio wrapper that seems to be sticking on old versions or I've missed a config change. How did you get back to an actively maintaned chain, @LeCyberDucky ? Thanx! |
@robertlipe I agree that it's very frustrating to deal with these layers upon layers of abstractions. I have not had the time to look at this for a little while now, so I'm a bit out of the loop and therefore not sure of how much help I can be. As I recall, however, I ended up making use of this: platformio/platform-espressif32#1281, which let me compile the stuff I wanted to compile. Is that of any help? My very cluttered platformio.ini kinda documents what I've been through, in case that is of any interest:
|
Thanx for the helpful reply. That was the nudge I needed. As you saw, I ran into other issues caused by a bump in the 3.0 RC, but am now moving forward. Incidentally, I saw your name in other LED strip and S3 projects in recent days, so we're running in similar circles. I'm very much with you on the layering issues. It's a huge mess...and it's clear that at least some of the problems holding back progress on 3.0 aren't all technical. I appreciate the hand! |
Hey there!
Long story short, I'm looking for C++20 ranges support when programming my ESP32-S3 with the Arduino framework.
I'm working on a project for an ESP32-S3-based board (the LilyGo T-Display-S3), and, when trying to use the C++20 ranges library, I run into the error:
fatal error: ranges: No such file or directory
I'm using PlatformIO to develop this project. An initial question in the PlatformIO forum, lead me to the ESP32 Arduino forum, which has subsequently lead me to this place.
Along this adventure, I have come across this seemingly similar issue about support for C++20 chrono: espressif/esp-idf#12914 (comment)
It is mentioned that this will be supported starting with GCC14. A quick look at https://en.cppreference.com/w/cpp/compiler_support reveals that "The One Ranges Proposal" should be supported from GCC10. And I can see that the latest release in this repository upgrades the GCC version to 13.2.0. So, I should be able to use ranges, no?
All of this has me quite confused, especially considering that I'm simply trying to port a project that works on an ESP8266. Could somebody explain to me what is going wrong, and if there's anything I can do to fix it?
It is not quite obvious to me which compiler I'm actually using.
My PlatformIO.ini looks like this:
With that, I get the following information when trying to build my project:
Kind regards
The text was updated successfully, but these errors were encountered: