C++ Modules: Getting Started Today - Andreas Weis - CppCon 2023

  Рет қаралды 24,229

CppCon

CppCon

Күн бұрын

Пікірлер: 71
@vesk4000
@vesk4000 Жыл бұрын
Awesome! I've been looking for a good first talk on modules and in particular what I can do right now. The standard is very nice, but it seems a lot of module features haven't been implemented yet, which makes it quite annoying when I watch a lot of talks, they don't take that into account.
@davidsicilia5316
@davidsicilia5316 Жыл бұрын
The best talk on modules thus far at CppCon
@christiandaley120
@christiandaley120 9 ай бұрын
Great talk, the include guard trick is genius!
@ComicSansMS
@ComicSansMS Жыл бұрын
A small error on the slides: The CMake FILE_SET for modules sources is called CXX_MODULES, not MODULES. Also, on slide #20 about interface partitions, the names of the module in the primary module interface and the partitions need to be consistent (either all 'm' or all 'mice', but not a mixture of the two).
@fzort
@fzort 5 ай бұрын
Great talk, really helpful. Thank you!
@NotherPleb
@NotherPleb Жыл бұрын
Only C++ can take a concept this simple and make it hard
@indiesigi7807
@indiesigi7807 Жыл бұрын
Contrary to pop opinion the header system is extremely good and won't be replaced any time soon.
@wumi2419
@wumi2419 Жыл бұрын
Does it mean only C++ has real world use then? Since that's one of properties of reality, it makes simple concepts hard by virtue of nuance.
@iliasalaur
@iliasalaur Жыл бұрын
What is so hard about it?
@llothar68
@llothar68 11 ай бұрын
@@indiesigi7807 I want to keep headers too, but make the classes open so i can extend them in private source files. That would be better and simpler.
@llothar68
@llothar68 11 ай бұрын
@@iliasalaur They didn't try to work against the root of all this problems. Single translation units. A 1970s concept that is so wrong. We could have so much nice things if we could get of command line compilers and obj files, instead go with a server that get feed c++ source files and spits out executables. Thats the solution for the speed problem. The better abstraction could be solved by allowing open classes. Objective-C++ is doing it very well but only for the Objective-C.object model.
@zahash1045
@zahash1045 Жыл бұрын
this reminds me of a helmet that i had that had a hammer attached to it. So everytime i want to nail something to the wall, i would wear that helmet and swing my head around to hit the nail. but sometimes i miss and i hit my head against the wall instead. So to solve that problem, i added some padding to my forehead. now everything works like a charm.
@kobe4460
@kobe4460 6 ай бұрын
Another fellow jonathan blow watcher
@christianhall3916
@christianhall3916 2 ай бұрын
C++ has always been a mess and will always be a mess, but it's a useful mess, so managing that mess better is helpful.
@MathewBensonCodes
@MathewBensonCodes 11 ай бұрын
Happy to have learnt through this talk how to export templates. I was putting the export on the function "part" and couldn't figure out why it wasn't working.
@theo-dr2dz
@theo-dr2dz 10 ай бұрын
At this time (version 17.8.6) Visual Studio can with no problem have modules that wrap header files that include the C standard library. So, no problem if you write a module that uses a C library. That's already a big deal. It won't work if you include a header that includes the C++ standard library. So if you try to wrap a C++ library that won't work because the library will include stuff from the C++ standard library and you will get name clashes. So, the solution is to have an immediate wrapper module that just includes all standard library headers that are used by the wrapped library in the bit between module; and export module x;. and then exports the library. In most cases that will probably approach most of the C++ standard library. At least it's a trick that works (I verified with a minimal example). Hopefully this issue will be resolved and the trick will no longer be needed soon.
@lucasbraune
@lucasbraune Жыл бұрын
Great talk!
@victoreijkhout7115
@victoreijkhout7115 Жыл бұрын
Is 17:53 correct? My compiler thinks that the implementaiton module is trying to import itself. Oh wait, the code is correct but the compilation order is crucial, as was not mentioned. 21:29 should the "m:" twice be "mice:"?
@ComicSansMS
@ComicSansMS 11 ай бұрын
Yes, the 'm:' on slide 20 was a typo and should be 'mice:'. Thanks for catching that!
@abdulshabazz8597
@abdulshabazz8597 11 ай бұрын
// File: my_module.p1.cpp export module mice:pinky; export void narf() {}; // File: my_module.p2.cpp export module mice:the_brain; export void take_over_the_world() {}; struct SecretMasterPlan {}; . .
@Fetrovsky
@Fetrovsky 10 ай бұрын
In my_module_p{1,2}.cpp, you have "export module m:something;"... what is m? I don't see you declaring a module called m. Should it be mice instead?
@evgenii_g
@evgenii_g 8 ай бұрын
yep, should be `mice`, not `m`. It's a compile err with `m` otherwise
@LeeJordanMusic
@LeeJordanMusic 11 ай бұрын
Great talk, thanks! Some concepts here, like "export import", "export using", and the ability to export a function returning a non-exported type, make me a bit worried for the future of C++. A lot of people already get confused with headers, and this is IMO adding a whole lot of complexity. That doesn't matter for people who know what they're doing, but this just makes it harder to convince large teams / companies to use modern C++.
@arsalananwari4377
@arsalananwari4377 4 ай бұрын
Has anyone figured out if intellisense work now with vscode + cmake + ninja? Still getting module not found errors
@kiddkai
@kiddkai Жыл бұрын
It looks so much complex than the other languages module systems...
@GregWhiteley
@GregWhiteley 11 ай бұрын
Only if you compare it with single vendor programming languages - rust, swift,... - that mandate (and provide) the build system. For those of us in embedded and system programming world we can't rely on those languages. We need C/C++ because it integrates with our systems, not finding a way to get those single vendors to care enough to support our system. Complexity is the price we pay for flexibility, but in return we can ship product.
@jawad9757
@jawad9757 10 ай бұрын
@@GregWhiteley you don't have to use cargo with rust
@milktea0001
@milktea0001 9 ай бұрын
c++ has to be complex i guess
@007LvB
@007LvB 7 ай бұрын
@@milktea0001 Unfortunately yes. But we must remember that C++ is the only language out there that does not force programmers to write their software in any specific way. All C++ does is give us a set of tools and some loose guidelines. Rust assumes programmers can't be trusted and so places as many restrictions as possible. C++ is getting better, sure, but due to legacy reasons it has a lot of "catching up" to do. Modules make C++ almost infinitely better.
@frenchmarty7446
@frenchmarty7446 6 ай бұрын
Welcome to C++.
@olafschluter706
@olafschluter706 11 ай бұрын
Aside of CMake (as of 3.28) modules support by toolchains is very lacking. Neither Apple's clang 15.0 nor gcc 13.2 provide a dependency graph for CMake. clang 17.0 works somewhat with CMake (i.e. it configures and builts everything), but then VS Code can't handle dependencies and code completion, neither with the C/C++ plugin nor the clangd plugin. So for the time being it seems we have to wait for the tools to adopt still. "Getting started today"? No way.
@abdulshabazz8597
@abdulshabazz8597 11 ай бұрын
I don't like the fact imports are dumped into the current namespace. Perhaps if it was a bit more python-y in the way of : import B; B.my_import_func(); in lieu of a using declaration would provide a much cleaner namespace .
@tomleeyrc40
@tomleeyrc40 6 ай бұрын
Namespaces help a little in foo.cpp: export module foo; namespace foo { export void fn(){} } in main.cpp import foo; int main() { foo::fn() } This interface only requires that all your modules have a namespace that is the same as the name it uses when calling export.
@chukwujiobicanon961
@chukwujiobicanon961 2 ай бұрын
With concepts, templates shouldn't be a problem yes?
@witM90
@witM90 9 ай бұрын
I'm using visual studio and start to learn modules. The thing is there is bad tutorial on the internet. I import std module to other module that is in project which compile to static library (.lib). In that project I'm only using print function from cpp23. The lib file is about 4mb of size when using imported std. If this is normal? All library contining cpp standard library is linked to my library? Second, if I will link my library with other project that make executable file (.exe) and in that project I'm using cpp standard library (import std) ofcourse I' have to use std.ifc interface again but do I have link c++ standard library (.lib) files again? This is very practical information..not only to show how "nice" is write "import std".
@liveonphoenix5045
@liveonphoenix5045 2 ай бұрын
...um @19:02, the mice!!! become m?!!!, Why?
@sjswitzer1
@sjswitzer1 10 ай бұрын
Shouldn’t CMake treat modules as libraries, or at least be able to do so? (Maybe it can and I missed it?)
@007LvB
@007LvB 7 ай бұрын
Why would this be a good idea? A module is simply a translation unit. I think the approach of linking several module interface units together into a library is a much better solution. After all, a library may be formed from just a single TU.
@Lalasoth
@Lalasoth Жыл бұрын
Hmm you must be from the future.. I cannot find a visual studio release later than 17.8.3
@ComicSansMS
@ComicSansMS 11 ай бұрын
Sorry for being imprecise there. The 19.34 is the C++ toolchain version, the number you get when running cl.exe, not the version number of the Visual Studio IDE that you get in the About... window in Visual Studio.
@Lalasoth
@Lalasoth 11 ай бұрын
@@ComicSansMS thanks for clarifying that.
@PaulMetalhero
@PaulMetalhero Жыл бұрын
So .bmi files behave like small static libraries?
@szaszm_
@szaszm_ Жыл бұрын
To me it sounds like the same thing as headers, but in binary format, for the compiler, so it's faster to parse and use.
@spaxio
@spaxio 11 ай бұрын
No, like small per-compiled headers
@007LvB
@007LvB 7 ай бұрын
Exporting from module partitions is not a standard. GCC and Clang do not support it, and Clang developers have even said that it might never be supported! I would add a BIG NOTE at slide 20.
@bobsinclair8990
@bobsinclair8990 2 ай бұрын
Been waiting for proper modules support outside MSVC for so many years now. Build tool chain environment still convoluted. State of affairs is just so sad. C++ is such a good language otherwise.
@kl6995
@kl6995 10 ай бұрын
It's too complicated. As a long term C++ dev, I really was hoping that C++ modules would ease my life and the one of my team. It's 2024 and I don't see the benefits of it so much: too verbose, error prone.. it's depressing because we had to set a new modern language in our stack because of my failure to predict what modules would end up like. My fault, but it kills me.
@007LvB
@007LvB 7 ай бұрын
It will ease your life. At least I think so. Stick to module interface units for declarations and documentation, and module implementation units for definitions. You never need to worry about inclusion hell again. I would say that's a big win.
@wrightleftify
@wrightleftify 3 ай бұрын
It makes no sense to start using modules if every other slide has, "well, there are some bugs." That's not what I want to hear when I'm picking out tools. This talk turned me off modules more than it encouraged me to try them out. I especially didn't enjoy the, "some stuff doesn't work, so make a pull request," petition. Yikes.
@lisinsignage
@lisinsignage 11 ай бұрын
Will C++ 2025 reinvent the concept of .def files fir export definitions 😂😂😂
@GuillermoH77
@GuillermoH77 11 ай бұрын
Besides complexity, nobody is using it because it is 2024… and still it is not production ready. IMHO, I think that standard body should deprecate this, and try again. Don’t force all C++ community to support yet another mistake.
@007LvB
@007LvB 7 ай бұрын
Useless perspective! Modules were introduced with C++20, and the standard library is modularized with C++23. It takes time to do this right. The modules proposals have been underway since 2012, don't kid yourself thinking this is easy or simple!
@SuganthanHarmless
@SuganthanHarmless 3 ай бұрын
Valid point ​@@007LvB
@KX36
@KX36 Жыл бұрын
Modules were such a wasted opportunity to make something good, ended up ugly and overly verbose with so many rules to remember. Nobody will use, like coroutines.
@szaszm_
@szaszm_ Жыл бұрын
Coroutines are already usable, although there are more libraries needed in the ecosystem. Asio already makes good use of them for async networking. Writing your own coroutine type is much harder, but most people don't need to do that.
@iliasalaur
@iliasalaur Жыл бұрын
Coroutines is a very different story, because there is a very small number of scenarios, where they could be handy. Modules are exactly the opposite. This is the piece of standard, that must be used everywhere. I hope that in 2-3 years more compilers will add support for them, because you know, headers - suck
@matejplch7524
@matejplch7524 Жыл бұрын
Coroutines are hard to implement, but easy to use. They are not meant to be implemented by everyone, only library implementers will need to do that, and then millions of C++ developers will be able to use them without knowing the implementation details.
@llothar68
@llothar68 11 ай бұрын
@@iliasalaur I love headers. I love them much more then all the languages that mix the implementation with the declarations.The problem is not hte header but the single translation unit compilation speed (and some better implementation hidding). All of it could have been solved much better without this module system they came up with.
@KX36
@KX36 11 ай бұрын
Coroutines have myriad possible uses. I have used coroutines in Unity for a variety of uses. Anywhere you have async code you can use coroutines and they have a simple intuitive syntax there. You shouldn't need a 3rd party library to use what was supposed to be a major feature of the C++20 standard library, but right now you do. C++20 modules tend to be discussed as a replacement for headers, but when you start using them you find that they don't fully replace headers. They seem to be more useful for joining together code at the library level, rather than at the file level. (And of course only your own new libraries because existing libraries probably don't support modules yet.) Within each library you'll probably still #include headers. I think this is hinted at around slide 29/50 when it talks about "regular files". You could use module partitions but partitions and modules in general are just a ton of header style boilerplate with no real benefit over traditional includes.
@llothar68
@llothar68 9 күн бұрын
A YEAR LATER and still no better situation then 2023. C++ toolmaker suck
@Mempler
@Mempler 9 ай бұрын
3 years and still not properly usable. Good language 👍 Gonna stick with C
@007LvB
@007LvB 7 ай бұрын
Why on earth would you stick with C? That language is close to useless for practical purposes.
@FlanPoirot
@FlanPoirot 4 ай бұрын
@@007LvB ig the whole open source stack is useless TIL lmao these absolutist takes are always the worst
@gommito
@gommito Ай бұрын
There's still Rust, which works...
If people acted like cats 🙀😹 LeoNata family #shorts
00:22
LeoNata Family
Рет қаралды 41 МЛН
Что-что Мурсдей говорит? 💭 #симбочка #симба #мурсдей
00:19
Симбочка Пимпочка
Рет қаралды 4,2 МЛН
99.9% IMPOSSIBLE
00:24
STORROR
Рет қаралды 25 МЛН
Thank you Santa
00:13
Nadir Show
Рет қаралды 59 МЛН
The Return of Procedural Programming - Richard Feldman
52:53
ChariotSolutions
Рет қаралды 28 М.
Back to Basics: C++ API Design - Jason Turner - CppCon 2022
1:00:42
CMake vs Make - A Real Life Comparison (With Actual Code)
12:16
Kea Sigma Delta
Рет қаралды 5 М.
CppCon 2014: Mike Acton "Data-Oriented Design and C++"
1:27:46
So, you want to be a programmer?
20:43
ForrestKnight
Рет қаралды 424 М.
If people acted like cats 🙀😹 LeoNata family #shorts
00:22
LeoNata Family
Рет қаралды 41 МЛН