diff options
author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2022-02-17 17:02:43 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-02-17 17:02:43 +0000 |
commit | 9fb06d66cef70584e7aa2fa3a6ad22ef7def6b84 (patch) | |
tree | d8ed1ea0d957afd906556ae89e8622f79c4690f1 /gcc/rust/ast/rust-path.h | |
parent | 752bf6c80a922e09edf5bcb53e15e08e83057a7f (diff) | |
parent | 37415eec77438bba2fc61df3e9a396c1e2cbaca8 (diff) | |
download | gcc-9fb06d66cef70584e7aa2fa3a6ad22ef7def6b84.zip gcc-9fb06d66cef70584e7aa2fa3a6ad22ef7def6b84.tar.gz gcc-9fb06d66cef70584e7aa2fa3a6ad22ef7def6b84.tar.bz2 |
Merge #938
938: First pass at declarative macro expansion r=philberty a=philberty
This does not support repetition matchers but it supports simple
declarative macros and transcribes them. The approach taken here is that
we reuse our existing parser to call the apropriate functions as specified
as part of the MacroFragmentType enum if the parser does not have errors
parsing that item then it must be a match.
Then once we match a rule we have a map of the token begin/end offsets
for each fragment match, this is then used to adjust and create a new token
stream for the macro rule definition so that when we feed it to the parser
the tokens are already substituted. The resulting expression or item is
then attached to the respective macro invocation and this is then name
resolved and used for hir lowering.
Fixes #17 #22
Addresses #573
Co-authored-by: Philip Herron <philip.herron@embecosm.com>
Diffstat (limited to 'gcc/rust/ast/rust-path.h')
0 files changed, 0 insertions, 0 deletions