Event page
Slides repository
Allegro Means Both Fast and Happy. Coincidence?
Andrei Alexandrescu
Sorting and searching. Two fundamental tasks in Computer Science, and definitely among the most studied. Efficient algorithms for sorting and searching are now taught in core undergraduate classes. Are they at their best, or is there more blood to squeeze from that stone? This talk will explore a few less known – but more allegro! – variants of classic algorithms.
Keynote [ENG], 90 minutes
Concepts in C++20: A Revolution
Rainer Grimm
The key idea of generic programming with templates is it to define functions and classes which
can be used with various types. Often it happens that you instantiate a template with the wrong
type. The result is typically a few pages of cryptic error messages. This sad story ends with
concepts. Concepts empower you to write requirements for your templates which can be
checked by the compiler. Concepts revolutionise the way, we think about and write generic
code. Here is why:
- Requirements for templates are part of the interface.
- The overloading of functions or specialisation of class templates can be based on concepts.
- We get improved error message because the compiler compares the requirements of the template parameter with the actual template arguments.
However, this is not the end of the story.
- You can use predefined concepts or define your own.
- The usage of auto and concepts is unified. Instead of auto, you can use a concept.
- If a function declaration uses a concept, it automatically becomes a function template. Writing function templates is, therefore, as easy as writing a function.
Talk [ENG], 50 minutes
The joys and trials of writing cross-platform C++ code – let tools help!
Marc Goodner
Writing high-quality error-free C++ code is a challenging task, let alone when having to juggle multiple platforms at the same time! In this session we will be exploring the many challenges in cross-platform C++ development and how tools can help. What options do I have if my production environment is different than my dev-box? Can I be as productive when working with remote Linux machines? How can I efficiently build and debug CMake projects and how can I acquire open-source libraries? Come see what Visual Studio 2019, Visual Studio Code, CMake, WSL, Vcpkg and more have to offer to make your C++ development much easier in this demo-heavy talk.
Talk [ENG], 50 minutes
Vector++ 17
Davide Bianchi
Let’s see how to build a modern vector that can serve as the pillar for any geometrical library
using a little of metaprogramming and the new c++17 language feature: fold expressions.
What we aim to achieve is a Vector<T, N> of type T and with N dimensions that behaves like
any other scalar type in scalar conditions, but that is capable to behave correctly when the
geometrical operations on vectors are invoked.
In particular, we would like to be able to:
- sum vectors of the same order, with different types and get, as a result, a vector which has the type according to the performed operation (for instance, float + int = float, then veci + vecf = vecf);
- invoke cmath functions using as arguments either scalar or other vectors (e.g. pow(vec3f, float) = vec3d, but also pow(vec3f, vec3i) = vec3d);
- have an easy-to-extend and “soft-typed” code base of vector functions;
- take advantage of any possible implicit conversion that would be legal with scalars on vectors;
- be able to almost effortlessly enable/disable the possibility to allow implicit conversion and narrow conversion on vectors.
All this reducing the syntactic noise to its minimum and letting the possibility to extend the library
in a clear and easy-to-understand way.
As a plus we would like to take advantage of swizzlers like the common shader languages does.
Short Talk [ENG], 30 minutes
Optimizing after the optimizer: Link Time and Profile Guided Optimization
Nicolò Valigi
Link Time Optimization (LTO) and Profile Guided Optimization (PGO) are two complementary techniques for improving the performance of C++ code beyond what’s normally achieved by optimizing compilers. In most projects, optimization and inlining opportunities are limited because C++ inherits the concept of independent translation units from C. LTO sidesteps this issue by deferring emission of the final binary code to the linker. After turning on LTO, Firefox saw 5% and up improvements in some benchmarks. PGO uses profiling data collected at runtime to optimize decisions made by the compiler, like branch predictions and code placement. This talk will explore LTO and PGO as implemented by clang. We’ll show how to enable these features in an example project, and dissect the generated code to understand how they work.
Short Talk [ENG], 30 minutes
Custom tooling for frameworks, libraries and projects using Clang – getting Clazy
James Turner
Each programming framework or API we use typically brings with it its own history, best-practices and pitfalls. Whether through documentation, trial-and-error or searching Stack Overflow, we eventually figure out the most efficient, performant and correct way to use our frameworks. But like many problems, better tooling can remove much of the pain. In this session we’ll look at a specific example of using the Clang compiler framework to detect outdated practices, inefficient choice of APIs and good old fashioned typos, and even provide automatic fixes to problems when requested.
Besides looking at the specific example, we’ll consider how to apply this concept to any large C++ project, to develop your own checks and automated refactorings. We’ll examine the models of your code which Clang builds internally, and how we introspect and modify those to reason about code, while preserving structure, formatting and comments.
Talk [ENG], 50 minutes
The Future of C++ with Modules
Dmitry Kozhevnikov
Modules are probably the most anticipated as well as the most controversial feature proposed for the upcoming C++20. It might be viewed as the most revolutionary change in the language ever, affecting the way we structure, write and build our programs.
The work that’s going on around this feature is very related to the problems we have as IDE developers, so I’m following it very closely and very carefully.
In this talk, I’m going to talk about:
- How modules would work for the end user, and how are they implemented in the compiler
- What are the expected benefits of modules (i.e. “How exacly would they help with build times?”)
- What are the common misconceptions and misunderstanding about the scope of the modules (i.e. “Modules are supposed to solve package management problem, right?”)
- What is the history of the current proposal and why it takes so long to get in the standard
Also, by the time of the talk the fate of Modules in C++20 would be decided – they’ll either be
accepter, so I’ll cover what it means for the rest of the world, or they’ll be postponed for C++23,
in this case I’ll describe what were the concerns and unsolved problems.
Talk [ENG], 50 minutes
ABI compatibility is not a MAJOR problem
Javier Garcia Sogo
Too often, C++ developers tend to ignore ABI compatibility problems and think that incompatibilities are limited to changes in the interface of the library motivated by new features or bugs. However, the ABI can also be affected by the context of the compilation (architecture, compiler, C++ runtime, …) and even by the libraries that we are consuming. Using semantic versioning is not enough.
In this presentation, Javier intends to make clear the difference between API and ABI, source and binary compatibility. He’ll point out the extreme relevance that ABI compatibility has for library developers and give examples of things that affect the ABI and some techniques to minimize that pain. Taking care of ABI stability can become very important when libraries can’t be built always from sources due to very long compilation times, licensing issues or closed source components.
In the last part of the talk Javier will introduce Conan (https://conan.io) as the right tool to address this problem. He’ll show how many different binaries can be generated by one simple library taking into account some settings (OS, compiler) and options (shared, static), and how the problem becomes more and more complex when the graph of dependencies of your project grows. Conan has some useful tools to help you know and handle the ABI compatibility problem.
Talk [ENG], 50 minutes
Coroutines in practice
Alberto Barbati
Coroutines have been voted into C++20 and at least two major compilers already support them to some extent. They will eventually be available to the main public, but you can experiment with them right today! In this practical talk we’ll see how to write an IPC facility with named pipes on Windows, using coroutines to implement cooperative multitasking in a single-thread application.
Talk [ENG], 50 minutes
Clean(er) Code for Large Scale Legacy Applications
Arne Mertz
Due to the complexity of the language and the presence of some low-level language features, “Clean C++” seems to be an oxymoron for many developers. Especially in enterprise land, C++ applications tend to have large code bases grown over several years. Those legacy code bases tend to suffer from underdeveloped or missing unit and integration tests. Development teams maintaining such code bases resign over time and adopt “don’t touch it, you’ll break it” policies.
Nevertheless, it is possible to write clean C++, to refactor even large code bases as needed and cover critical parts with automated tests. The key elements to successfully regain control over code quality are a dedicated team and a set of properly sized and prioritized steps towards that goal.
In this talk, we’ll touch a few important topics about cleaning up a code base. This includes
knowing when and where to do the refactoring, what strategies to use, and to bring the team on the same page.
In the end, there is the question of tooling or its absence. Especially when a C++ code base is tied to an old compiler and IDE for some reason, there still are ways to let the compiler and other tools help us.
Talk [ENG], 50 minutes
ECS back and forth
Michele Caini
The first time I heard of the entity component system architectural pattern, I searched on the web for more information. Sadly, I didn’t find many details on the topic nor a single source where the different approaches were described along with their pros and cons, so as to guide the reader from OOP to component-based models.
In this talk I’ll try to introduce the topic and to explore briefly a few implementations I’ve seen so far.
Talk [ENG], 50 minutes