michaelplatings added a comment.

> Could be worth adding a design principles section at the end

That was a very helpful suggestion, thank you. Writing them out helped me 
examine the compatibility story more carefully. Consequently I added a 
requirement for a "minimumClangVersion" property, although I haven't 
implemented that in the other patches yet.

> May be worth a quick description of how we might model some awkward cases

Not done yet. This certainly can be modelled but I agree an example would be 
helpful to provide.



================
Comment at: clang/docs/Multilib.rst:105
+
+This decision is hard-coded per ToolChain subclass.
+
----------------
peter.smith wrote:
> Considering the BareMetal ToolChain is used by RISC-V, Arm and AArch64 is 
> there scope for a different choice per toolchain. I guess that we could put a 
> predicate function for the ToolChain that could change due to architecture.
For the BareMetal ToolChain the only one RISC-V multilibs can ever match a 
given set of command line options so this isn't a problem in practice.


================
Comment at: clang/docs/Multilib.rst:122
+``-fno-exceptions`` multilib variant need only contain C++ libraries.
+
+Stability
----------------
peter.smith wrote:
> Although it can be worked out by looking at the example, which I think is 
> your intention from the comment. It may be worth a section on Syntax that 
> extracts some of these.
> ```
> Syntax of multilib.yaml
> ===============
> ```
> Some suggestions/questions:
> * Does the file have to contain both variants: and flagmap: are either of 
> them optional?
> * Do variants have to come before flagmap, or is order not important.
> * Will be worth highlighting that the order of the variants may be 
> significant depending on the toolchain.
> * Each variant is made up of dir: (path added to sysroot?), flags: [comma 
> separated list of flags] and printArgs: [comma separated list of command line 
> options for -print-multi-lib and -print-multi-directory, but not important 
> for multilib selection]
> * Each flagmap is made up of a POSIX extended syntax regex: that matches a 
> flag, and (one of?) matchFlags/noMatchFlags which either adds or removes 
> respecively a [comma separated list of flags] 
I opted to keep the spec, such as it is, in the example, but I've expanded it 
to answer your questions, unless it's implicit in it being YAML (e.g. lists 
//can// be comma separated but there are other ways to express them in YAML).


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D143587/new/

https://reviews.llvm.org/D143587

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to