Glossary: Difference between revisions
|  (Added PMF) |  (→C:  Add CSS (two meanings)) | ||
| (40 intermediate revisions by 4 users not shown) | |||
| Line 4: | Line 4: | ||
| For terms and concept names in documentation and messaging, see [[Qt Terms and Concepts]]. | For terms and concept names in documentation and messaging, see [[Qt Terms and Concepts]]. | ||
| = A = | |||
| == ABI == | |||
| Application Binary Interface | |||
| The part of the Qt libraries that the linker sees. The ABI is what affects [[#BC]]. | |||
| Contrast with [[#API]]. | |||
| == API == | |||
| Application Programming Interface | |||
| The part of the Qt libraries that the compiler sees. The API is what affects [[#SC]]. | |||
| Contrast with [[#ABI]]. | |||
| = B = | = B = | ||
| Line 10: | Line 28: | ||
| Binary compatible or binary compatibility | Binary compatible or binary compatibility | ||
| See also [[#SC]] | Meaning the stability of [[#ABI]]. | ||
| See also [[#BiC]], [[#SC]], [[#API]], [[#ABI]]. | |||
| == BiC == | |||
| Binary ''in''compatible or binary ''in''compatibility. | |||
| Opposite of [[#BC]]. | |||
| == Build System == | == Build System == | ||
| Line 16: | Line 42: | ||
| There's a separate [[Qt Build System Glossary]]. | There's a separate [[Qt Build System Glossary]]. | ||
| = C = | |||
| == CSS == | |||
| Either Cascading Style Sheets (https://en.wikipedia.org/wiki/CSS) or the Caller-Supplied Storage Idiom (see e.g. https://codereview.qt-project.org/c/qt/qtbase/+/363158). | |||
| == CTAD == | |||
| The C++17 feature ''Class Template Argument Deduction'' (also sometimes misspelled as ''Constructor'' Template Argument Deduction). | |||
| See https://en.cppreference.com/w/cpp/language/class_template_argument_deduction | |||
| = D = | = D = | ||
| == Detach == | |||
| The operation of creating a unique copy from a shared state, esp. in [https://doc.qt.io/qt-6/implicit-sharing.html implicitly-shared] Qt classes. | |||
| === Hidden Detach === | |||
| The unintended and needless [[#Detach|detach]] causing a deep copy because a non-const overload of a function is called when the const overload would have sufficed. | |||
| == DRY == | == DRY == | ||
| Line 24: | Line 70: | ||
| See also [[#SCARY]]. | See also [[#SCARY]]. | ||
| = E = | |||
| == EoP == | |||
| Elements of Programming | |||
| 2009 book by Alex Stepanov (inventor of the STL) | |||
| See http://elementsofprogramming.com/ (HTTPS doesn't work at the time of writing) | |||
| = F = | |||
| == FF == | |||
| Feature Freeze | |||
| A step in the [[QtReleasing|Qt release cycle]]. See [[Qt Feature Freeze]]. | |||
| Used as a hashtag (<tt>#ff</tt>) on Gerrit to indicate that the change should be reviewed before the next FF. | |||
| == FTBFS == | |||
| Fails To Build From Source (also: Failure To Build From Source) | |||
| Sometimes used in bug report issue names, see https://bugreports.qt.io/browse/QTBUG-128574 for an example | |||
| = G = | |||
| == GUTs == | |||
| Good Unit Tests | |||
| Term coined by Kevlin Henney to subsume some principles of "good" unit tests. | |||
| See https://www.youtube.com/watch?v=azoucC_fwzw | |||
| == GoF == | |||
| Gang of Four | |||
| Referring to the 1994 book "Design Patterns - Elements of Reusable Object-Oriented Software" by Gamma, Helm, Johnson, Vlissides (the "Gang of Four"), which defined patterns such a State/Strategy, Factory, Visitor, ... | |||
| = H = | |||
| == Hinnant Criterion == | |||
| The property that move-assignment must be self-assignment-safe (only) for the moved-from state. This is equivalent to say that the class is self-swap-safe. Normally, the move-assignment operator may assume that <tt>other</tt> doesn't alias <tt>*this</tt> (so <tt>x = std::move(x)</tt> is an error and doesn't need to be supported), and assignment of a moved-from object to another object is not allowed (generic code can only assume moved-from objects are [[#Partially-Formed|partially-formed]]), but self-swap requires self-assignment of a moved-from object: | |||
| <code> | |||
| void swap(T& lhs, T& rhs) { | |||
|    T tmp = std::move(lhs); // OK, lhs is moved-from into a different object  | |||
|    lhs = std::move(rhs);   // move-assignment to moved-from object (self-assignment when lhs aliases rhs!) | |||
|    rhs = std::move(tmp);   // OK, rhs is moved-from, but assignment of a new value is supposed to work | |||
| } | |||
| T x; | |||
| swap(x, x); // self-swap | |||
| </code> | |||
| Library writers should avoid self-swap, but class authors should strive to make classes self-swap-safe (alternatively self-move-assignment-safe in the moved-from state). | |||
| = I = | |||
| == IIFE == | |||
| Immediately-Invoked Function Expression | |||
| Known in C++ as [[#IILE]]  | |||
| See [[#IILE]] | |||
| == IILE == | |||
| Immediately-Invoked Lambda Expression | |||
| Known in other languages as [[#IIFE]]  | |||
| See https://quuxplusone.github.io/blog/2019/08/02/the-tough-guide-to-cpp-acronyms/#iile | |||
| = J = | |||
| = K =  | |||
| = L = | |||
| == LGTM == | |||
| Looks Good To Me | |||
| also: Let's Get This Merged | |||
| = M = | |||
| == MOVE_AND_SWAP == | |||
| One of the two ways to implement a move-assignment operator (the other being [[#PURE_SWAP]]). | |||
| Abbreviation of the Qt implementation macro <tt>QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_MOVE_AND_SWAP</tt>. | |||
| = N = | |||
| == NRVO == | |||
| ''Named'' [[#RVO]] | |||
| In contrast to [[#RVO]], the direct construction of a local object into the caller-allocated return value object, if it is known at compile-time which local object will be returned. | |||
| [[#QoI]] in all C++ versions. Most compilers do the optimization, but virtually all require a certain structure of the function, and are quick to disable the optimization otherwise. | |||
| See https://www.fluentcpp.com/2016/11/28/return-value-optimizations/ Section "The NRVO". | |||
| == NSDMI == | |||
| Non-Static Data Member Initialization | |||
| See https://en.cppreference.com/w/cpp/language/data_members#Member_initialization Item 2 | |||
| = O = | |||
| == ODR == | |||
| One Definition Rule | |||
| An ODR-violation is [[#UB]]. | |||
| See  | |||
| # https://en.cppreference.com/w/cpp/language/definition.html for the technical definition | |||
| # https://en.wikipedia.org/wiki/One_Definition_Rule for a TL;DR: | |||
| == OOM == | |||
| Out Of Memory | |||
| See https://en.wikipedia.org/wiki/Out_of_memory | |||
| = P = | = P = | ||
| == Partially-Formed == | |||
| Term coined by Alex Stepanov in [[#EoP]]: | |||
| <blockquote> | |||
| An object is in a partially formed state if it can be assigned to or destroyed. For an object that is partially formed but not well formed, the effect of any procedure other than assignment (only on the left side) and destruction is not defined. | |||
| '''Lemma 1.3''' A well-formed object is partially formed. | |||
| </blockquote> | |||
| One of two natural states of a moved-from object (the other being default-constructed). | |||
| See | |||
| # https://www.youtube.com/watch?v=9OQKZl7ha7g | |||
| # https://www.kdab.com/stepanov-regularity-partially-formed-objects-vs-c-value-types/ | |||
| == Pit Of Success == | |||
| (Falling into the Pit Of Success) | |||
| Here: designing APIs such that users do the right thing without thinking | |||
| See https://english.stackexchange.com/questions/77535/what-does-falling-into-the-pit-of-success-mean | |||
| == PMF == | == PMF == | ||
| Pointer-to-Member Function, e.g. &foo::bar where foo is a class and bar() a member function. | Pointer-to-Member Function, e.g. &foo::bar where foo is a class and bar() a member function. | ||
| == Premature Pessimization == | |||
| Term coined by Scott Meyers in contrast to Premature Optimization. | |||
| Avoiding premature pessimization means to choose among equally-readable options that which is more efficient. The idiomatic example is using post-increment when pre-increment suffices: <tt>for (...; it++)</tt> -> <tt>for (...; ++it)</tt>. | |||
| See <tbd> | |||
| == PURE_SWAP == | |||
| One of the two ways to implement a move-assignment operator (the other being [[#MOVE_AND_SWAP]]).  Only permissible when the class holds no resources other than memory. | |||
| Abbreviation of the Qt implementation macro <tt>QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_PURE_SWAP</tt>. | |||
| = Q = | = Q = | ||
| == QoI == | |||
| Quality of Implementation | |||
| E.g. about an optimization that the C++ standard doesn't require, but users expect of their C++  implementation. Such as | |||
| * That std::copy over pointers and built-in types becomes no more than memmove/memcpy. | |||
| * That the compiler implements [[#NRVO]]. | |||
| * That the std library doesn't call swap() when LHS and RHS alias each other. | |||
| == qsb == | == qsb == | ||
| Line 38: | Line 265: | ||
| == QtCS == | == QtCS == | ||
| [[:Category:Contributors Summit|Qt Contributors' Summit]] | [[:Category:Contributors Summit|Qt Contributors' Summit]] | ||
| == QUIP == | |||
| Qt User-submitted Improvement Proposal | |||
| See [https://contribute.qt-project.org/quips/ QUIP Index] and [https://contribute.qt-project.org/quips/1 QUIP Purpose and Guidelines]. | |||
| = R = | |||
| == RAII == | |||
| Resource Acquisition Is Initialization | |||
| See https://en.cppreference.com/w/cpp/language/raii.html | |||
| == RVO == | |||
| Return-Value Optimization | |||
| In contrast to [[#NRVO]], the direct construction of a ''temporary'' argument of the <tt>return</tt> expression into the caller-allocated return value object. | |||
| [[#QoI]] up to C++14, mandated from C++17 onwards. | |||
| See https://en.wikipedia.org/wiki/Copy_elision#RVO | |||
| = S = | = S = | ||
| Line 44: | Line 295: | ||
| Source compatible or source compatibility | Source compatible or source compatibility | ||
| See also [[#BC]] | Meaning the stability of the [[#API]]. | ||
| See also [[#SiC]], [[#BC]], [[#API]], [[#ABI]]. | |||
| == SCARY == | == SCARY == | ||
| Line 64: | Line 317: | ||
| == SFINAE == | == SFINAE == | ||
| Substitution Failure  | Substitution Failure Is Not An Error | ||
| For details, see | |||
| # https://en.cppreference.com/w/cpp/language/sfinae | |||
| # https://quuxplusone.github.io/blog/2019/08/02/the-tough-guide-to-cpp-acronyms/#sfinae | |||
| == SiC == | |||
| Source ''in''compatible or source ''in''compatibility. | |||
| Opposite of [[#SC]]. | |||
| === SiC Type A/B === | |||
| Acceptable (type A) or unacceptable (type B) [[#SiC]], as per [https://contribute.qt-project.org/quips/6 QUIP-6]. | |||
| == SIMD == | |||
| Single Instruction, Multiple Data | |||
| See https://en.wikipedia.org/wiki/Single_instruction,_multiple_data | |||
| == SMF == | == SMF == | ||
| Special Member Functions  | Special Member Functions | ||
| See https://en.cppreference.com/w/cpp/language/member_functions#Special_member_functions | |||
| = T = | = T = | ||
| ==  | == TLC == | ||
| Tender Loving Care (https://www.oxfordlearnersdictionaries.com/definition/english/tlc?q=TLC) | |||
| Used to group a set of smaller unrelated changes to a piece of code together in order to bring it up to current (Qt) standards. | |||
| Examples: https://codereview.qt-project.org/q/message:TLC | |||
| == TOCTOU == | |||
| [https://en.wikipedia.org/wiki/Time-of-check_to_time-of-use Time of Check / Time of Use] | |||
| A class of bugs involving race conditions. | |||
| The classic example is finding a filename that matches some condition and | |||
| passing this name to some other code that then accesses it, | |||
| by which time the filename may no longer meet the condition. | |||
| Passing an open file handle, obtained in the process of finding and checking the condition, | |||
| is the usual solution in this case. | |||
| == TQtC == | |||
| The Qt Company | The Qt Company | ||
| == TTLOFIR == | == TTLOFIR == | ||
| [[Things To Look Out For In Reviews]] | [[Things To Look Out For In Reviews]] | ||
| = U = | |||
| == UB == | |||
| Undefined Behaviour. | |||
| This is presumptively a bug, absent some very compelling evidence. | |||
| In principle, a compiler is at liberty to compile code that exercises UB into anything it likes, | |||
| including an executable that'll wipe your hard drive when run. | |||
| Just because your compiler does what you hoped for, that doesn't mean any other shall. | |||
| In practice, the compiler's optimizer will assume that UB cannot happen, and mark any code leading up to UB as dead code, and remove it. This is why UB's effects are said to travel in time. | |||
| = V = | |||
| = W = | |||
| = X = | |||
| = Y = | |||
| = Z = | |||
Latest revision as of 11:30, 18 October 2025
This is a glossary of terms used in Qt discussions, code comments or commit messages. Feel free to add a stub entry if you run into one you can't make sense of, in hopes of someone else filling it in here.
For terms and concept names in documentation and messaging, see Qt Terms and Concepts.
A
ABI
Application Binary Interface
The part of the Qt libraries that the linker sees. The ABI is what affects #BC.
Contrast with #API.
API
Application Programming Interface
The part of the Qt libraries that the compiler sees. The API is what affects #SC.
Contrast with #ABI.
B
BC
Binary compatible or binary compatibility
Meaning the stability of #ABI.
See also #BiC, #SC, #API, #ABI.
BiC
Binary incompatible or binary incompatibility.
Opposite of #BC.
Build System
The set of project files and tools that are used to build Qt.
There's a separate Qt Build System Glossary.
C
CSS
Either Cascading Style Sheets (https://en.wikipedia.org/wiki/CSS) or the Caller-Supplied Storage Idiom (see e.g. https://codereview.qt-project.org/c/qt/qtbase/+/363158).
CTAD
The C++17 feature Class Template Argument Deduction (also sometimes misspelled as Constructor Template Argument Deduction).
See https://en.cppreference.com/w/cpp/language/class_template_argument_deduction
D
Detach
The operation of creating a unique copy from a shared state, esp. in implicitly-shared Qt classes.
Hidden Detach
The unintended and needless detach causing a deep copy because a non-const overload of a function is called when the const overload would have sufficed.
DRY
Don't Repeat Yourself. Cf. https://en.wikipedia.org/wiki/Don%27t_repeat_yourself
See also #SCARY.
E
EoP
Elements of Programming
2009 book by Alex Stepanov (inventor of the STL)
See http://elementsofprogramming.com/ (HTTPS doesn't work at the time of writing)
F
FF
Feature Freeze
A step in the Qt release cycle. See Qt Feature Freeze.
Used as a hashtag (#ff) on Gerrit to indicate that the change should be reviewed before the next FF.
FTBFS
Fails To Build From Source (also: Failure To Build From Source)
Sometimes used in bug report issue names, see https://bugreports.qt.io/browse/QTBUG-128574 for an example
G
GUTs
Good Unit Tests
Term coined by Kevlin Henney to subsume some principles of "good" unit tests.
See https://www.youtube.com/watch?v=azoucC_fwzw
GoF
Gang of Four
Referring to the 1994 book "Design Patterns - Elements of Reusable Object-Oriented Software" by Gamma, Helm, Johnson, Vlissides (the "Gang of Four"), which defined patterns such a State/Strategy, Factory, Visitor, ...
H
Hinnant Criterion
The property that move-assignment must be self-assignment-safe (only) for the moved-from state. This is equivalent to say that the class is self-swap-safe. Normally, the move-assignment operator may assume that other doesn't alias *this (so x = std::move(x) is an error and doesn't need to be supported), and assignment of a moved-from object to another object is not allowed (generic code can only assume moved-from objects are partially-formed), but self-swap requires self-assignment of a moved-from object:
void swap(T& lhs, T& rhs) {
   T tmp = std::move(lhs); // OK, lhs is moved-from into a different object 
   lhs = std::move(rhs);   // move-assignment to moved-from object (self-assignment when lhs aliases rhs!)
   rhs = std::move(tmp);   // OK, rhs is moved-from, but assignment of a new value is supposed to work
}
T x;
swap(x, x); // self-swap
Library writers should avoid self-swap, but class authors should strive to make classes self-swap-safe (alternatively self-move-assignment-safe in the moved-from state).
I
IIFE
Immediately-Invoked Function Expression
Known in C++ as #IILE
See #IILE
IILE
Immediately-Invoked Lambda Expression
Known in other languages as #IIFE
See https://quuxplusone.github.io/blog/2019/08/02/the-tough-guide-to-cpp-acronyms/#iile
J
K
L
LGTM
Looks Good To Me
also: Let's Get This Merged
M
MOVE_AND_SWAP
One of the two ways to implement a move-assignment operator (the other being #PURE_SWAP).
Abbreviation of the Qt implementation macro QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_MOVE_AND_SWAP.
N
NRVO
Named #RVO
In contrast to #RVO, the direct construction of a local object into the caller-allocated return value object, if it is known at compile-time which local object will be returned.
#QoI in all C++ versions. Most compilers do the optimization, but virtually all require a certain structure of the function, and are quick to disable the optimization otherwise.
See https://www.fluentcpp.com/2016/11/28/return-value-optimizations/ Section "The NRVO".
NSDMI
Non-Static Data Member Initialization
See https://en.cppreference.com/w/cpp/language/data_members#Member_initialization Item 2
O
ODR
One Definition Rule
An ODR-violation is #UB.
See
- https://en.cppreference.com/w/cpp/language/definition.html for the technical definition
- https://en.wikipedia.org/wiki/One_Definition_Rule for a TL;DR:
OOM
Out Of Memory
See https://en.wikipedia.org/wiki/Out_of_memory
P
Partially-Formed
Term coined by Alex Stepanov in #EoP:
An object is in a partially formed state if it can be assigned to or destroyed. For an object that is partially formed but not well formed, the effect of any procedure other than assignment (only on the left side) and destruction is not defined.
Lemma 1.3 A well-formed object is partially formed.
One of two natural states of a moved-from object (the other being default-constructed).
See
- https://www.youtube.com/watch?v=9OQKZl7ha7g
- https://www.kdab.com/stepanov-regularity-partially-formed-objects-vs-c-value-types/
Pit Of Success
(Falling into the Pit Of Success)
Here: designing APIs such that users do the right thing without thinking
See https://english.stackexchange.com/questions/77535/what-does-falling-into-the-pit-of-success-mean
PMF
Pointer-to-Member Function, e.g. &foo::bar where foo is a class and bar() a member function.
Premature Pessimization
Term coined by Scott Meyers in contrast to Premature Optimization.
Avoiding premature pessimization means to choose among equally-readable options that which is more efficient. The idiomatic example is using post-increment when pre-increment suffices: for (...; it++) -> for (...; ++it).
See <tbd>
PURE_SWAP
One of the two ways to implement a move-assignment operator (the other being #MOVE_AND_SWAP). Only permissible when the class holds no resources other than memory.
Abbreviation of the Qt implementation macro QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_PURE_SWAP.
Q
QoI
Quality of Implementation
E.g. about an optimization that the C++ standard doesn't require, but users expect of their C++ implementation. Such as
- That std::copy over pointers and built-in types becomes no more than memmove/memcpy.
- That the compiler implements #NRVO.
- That the std library doesn't call swap() when LHS and RHS alias each other.
qsb
Qt Shader Baker https://doc.qt.io/qt-6/qtshadertools-qsb.html
QtCS
QUIP
Qt User-submitted Improvement Proposal
See QUIP Index and QUIP Purpose and Guidelines.
R
RAII
Resource Acquisition Is Initialization
See https://en.cppreference.com/w/cpp/language/raii.html
RVO
Return-Value Optimization
In contrast to #NRVO, the direct construction of a temporary argument of the return expression into the caller-allocated return value object.
#QoI up to C++14, mandated from C++17 onwards.
See https://en.wikipedia.org/wiki/Copy_elision#RVO
S
SC
Source compatible or source compatibility
Meaning the stability of the #API.
See also #SiC, #BC, #API, #ABI.
SCARY
No-one can remember what the acronym stands for, not without googling, and even then it doesn't tell you much. Making a class or function template SCARY means to separate all that depends on the template arguments from all that doesn't depend on (some) template arguments, ensuring that identical code doesn't get recompiled over and over again for every instantiation of the template.
Cf. https://quuxplusone.github.io/blog/2019/08/02/the-tough-guide-to-cpp-acronyms/#scary-iterators
Originally merely coined for nested types like std::vector<T, A>::iterator (which never depends on A), it has come into use for other in-kind transformations, too, often being a special case of Extract Method or Extract Baseclass.
See also #DRY.
SEP
Someone else's problem. From Douglas Adam's Hitchhiker's Guide.
Cf. https://en.wikipedia.org/wiki/Somebody_else%27s_problem
SFINAE
Substitution Failure Is Not An Error
For details, see
- https://en.cppreference.com/w/cpp/language/sfinae
- https://quuxplusone.github.io/blog/2019/08/02/the-tough-guide-to-cpp-acronyms/#sfinae
SiC
Source incompatible or source incompatibility.
Opposite of #SC.
SiC Type A/B
Acceptable (type A) or unacceptable (type B) #SiC, as per QUIP-6.
SIMD
Single Instruction, Multiple Data
See https://en.wikipedia.org/wiki/Single_instruction,_multiple_data
SMF
Special Member Functions
See https://en.cppreference.com/w/cpp/language/member_functions#Special_member_functions
T
TLC
Tender Loving Care (https://www.oxfordlearnersdictionaries.com/definition/english/tlc?q=TLC)
Used to group a set of smaller unrelated changes to a piece of code together in order to bring it up to current (Qt) standards.
Examples: https://codereview.qt-project.org/q/message:TLC
TOCTOU
A class of bugs involving race conditions. The classic example is finding a filename that matches some condition and passing this name to some other code that then accesses it, by which time the filename may no longer meet the condition. Passing an open file handle, obtained in the process of finding and checking the condition, is the usual solution in this case.
TQtC
The Qt Company
TTLOFIR
Things To Look Out For In Reviews
U
UB
Undefined Behaviour.
This is presumptively a bug, absent some very compelling evidence. In principle, a compiler is at liberty to compile code that exercises UB into anything it likes, including an executable that'll wipe your hard drive when run.
Just because your compiler does what you hoped for, that doesn't mean any other shall.
In practice, the compiler's optimizer will assume that UB cannot happen, and mark any code leading up to UB as dead code, and remove it. This is why UB's effects are said to travel in time.