-
Notifications
You must be signed in to change notification settings - Fork 42
CPP semantics guidelines and ideas
Temporary stuff. Should be eventually moved into docs/
- when finished. Feel free to edit.
Currently, we are targetting C++20 using the most recent versions of the drafts (see draft/papers). However, previously we were targetting C++14, and so most of the references to the standard that do not explicitly mention the document number refer to N4296. We should make that explicit.
Some references are bound to a single rule, some to group of rules, some to constructor...
Example of a reference:
// N4296 3.2/3
// N4778 6.2/8
// <quote>
// [...] A destructor for a class is odr-used if it is potentially invoked.
// </quote>
rule <k> potentiallyInvokeDestructor(_ :: Class(_, X::CId, _) #as C::Class) => makeOdrUsed(Base) ...</k>
<curr-tu> Tu::String </curr-tu>
<tu-id> Tu </tu-id>
<class-id> C </class-id>
<cenv>... DestructorId(X) |-> (_ |-> envEntry(... base: Base::SymBase)) ...</cenv>
// N4296 12.4/11
// N4778 10.3.6/12
// <quote>
// A destructor is potentially invoked if it is invoked or as specified in [...]
// </quote>
rule invokeDestructor(C::Class) => potentiallyInvokeDestructor(C)
Rules spanning multiple lines need to be surrounded with empty lines.
No trailing spaces.
- self - for module
M
, importM-SYNTAX
- empty line
- all the remote modules
Can we do some namespacing? What about this?
module CLASS-SORTS
syntax Class
endmodule
module CLASS-SYNTAX
imports CLASS-SORTS
syntax KItem ::= Class.generateDestructor(Class)
endmodule
module CLASS
imports CLASS-SYNTAX
// just normal code
rule <k> Class.generateDestructor(C::Class) => doSomething ...</k>
endmodule
module CLASS-IMPORTED-SYNTAX
imports CLASS-SORTS
// syntactic sugar
syntax KItem ::= generateDestructor(Class) [function]
endmodule
module CLASS-IMPORTED
imports CLASS-IMPORTED-SYNTAX
imports CLASS-SYNTAX
// desugaring rules
rule generateDestructor(C::Class) => Class.generateDestructor(C)
endmodule
This way, modules working only remotely with classes, could simply import CLASS-SYNTAX
and use the prefixed variants. But if some module uses classes heavily, it may import CLASS-IMPORTED-SYNTAX
and use the shorter variant. The problem with the above implementation is that the CLASS
module needs to use the prefixed variants, too. Maybe we can use the same KLabels...?
TODO let Jenkins auto build only PRs that do not have a particular label (do-not-build-yet
).