Skip to content

Commit 6cd89f0

Browse files
committed
hygiene: Rename semi-transparent to semi-opaque
The former is just too long, see the examples in `hygiene.rs`
1 parent 2a06022 commit 6cd89f0

File tree

11 files changed

+42
-42
lines changed

11 files changed

+42
-42
lines changed

compiler/rustc_attr_parsing/src/attributes/transparency.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -20,7 +20,7 @@ impl SingleAttributeParser for TransparencyParser {
2020
fn convert(cx: &AcceptContext<'_>, args: &ArgParser<'_>) -> Option<AttributeKind> {
2121
match args.name_value().and_then(|nv| nv.value_as_str()) {
2222
Some(sym::transparent) => Some(Transparency::Transparent),
23-
Some(sym::semitransparent) => Some(Transparency::SemiTransparent),
23+
Some(sym::semiopaque | sym::semitransparent) => Some(Transparency::SemiOpaque),
2424
Some(sym::opaque) => Some(Transparency::Opaque),
2525
Some(other) => {
2626
cx.dcx().span_err(cx.attr_span, format!("unknown macro transparency: `{other}`"));

compiler/rustc_feature/src/builtin_attrs.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -752,7 +752,7 @@ pub static BUILTIN_ATTRIBUTES: &[BuiltinAttribute] = &[
752752
),
753753
rustc_attr!(
754754
rustc_macro_transparency, Normal,
755-
template!(NameValueStr: "transparent|semitransparent|opaque"), ErrorFollowing,
755+
template!(NameValueStr: "transparent|semiopaque|opaque"), ErrorFollowing,
756756
EncodeCrossCrate::Yes, "used internally for testing macro hygiene",
757757
),
758758
rustc_attr!(

compiler/rustc_resolve/src/lib.rs

+3-3
Original file line numberDiff line numberDiff line change
@@ -1998,16 +1998,16 @@ impl<'ra, 'tcx> Resolver<'ra, 'tcx> {
19981998
result,
19991999
result.map(|r| r.expn_data())
20002000
);
2001-
// Then find the last semi-transparent mark from the end if it exists.
2001+
// Then find the last semi-opaque mark from the end if it exists.
20022002
for (mark, transparency) in iter {
2003-
if transparency == Transparency::SemiTransparent {
2003+
if transparency == Transparency::SemiOpaque {
20042004
result = Some(mark);
20052005
} else {
20062006
break;
20072007
}
20082008
}
20092009
debug!(
2010-
"resolve_crate_root: found semi-transparent mark {:?} {:?}",
2010+
"resolve_crate_root: found semi-opaque mark {:?} {:?}",
20112011
result,
20122012
result.map(|r| r.expn_data())
20132013
);

compiler/rustc_span/src/hygiene.rs

+17-18
Original file line numberDiff line numberDiff line change
@@ -66,10 +66,10 @@ pub struct SyntaxContextData {
6666
outer_expn: ExpnId,
6767
outer_transparency: Transparency,
6868
parent: SyntaxContext,
69-
/// This context, but with all transparent and semi-transparent expansions filtered away.
69+
/// This context, but with all transparent and semi-opaque expansions filtered away.
7070
opaque: SyntaxContext,
7171
/// This context, but with all transparent expansions filtered away.
72-
opaque_and_semitransparent: SyntaxContext,
72+
opaque_and_semiopaque: SyntaxContext,
7373
/// Name of the crate to which `$crate` with this context would resolve.
7474
dollar_crate_name: Symbol,
7575
}
@@ -81,7 +81,7 @@ impl SyntaxContextData {
8181
outer_transparency: Transparency::Opaque,
8282
parent: SyntaxContext::root(),
8383
opaque: SyntaxContext::root(),
84-
opaque_and_semitransparent: SyntaxContext::root(),
84+
opaque_and_semiopaque: SyntaxContext::root(),
8585
dollar_crate_name: kw::DollarCrate,
8686
}
8787
}
@@ -192,21 +192,21 @@ pub enum Transparency {
192192
/// Identifier produced by a transparent expansion is always resolved at call-site.
193193
/// Call-site spans in procedural macros, hygiene opt-out in `macro` should use this.
194194
Transparent,
195-
/// Identifier produced by a semi-transparent expansion may be resolved
195+
/// Identifier produced by a semi-opaque expansion may be resolved
196196
/// either at call-site or at definition-site.
197197
/// If it's a local variable, label or `$crate` then it's resolved at def-site.
198198
/// Otherwise it's resolved at call-site.
199199
/// `macro_rules` macros behave like this, built-in macros currently behave like this too,
200200
/// but that's an implementation detail.
201-
SemiTransparent,
201+
SemiOpaque,
202202
/// Identifier produced by an opaque expansion is always resolved at definition-site.
203203
/// Def-site spans in procedural macros, identifiers from `macro` by default use this.
204204
Opaque,
205205
}
206206

207207
impl Transparency {
208208
pub fn fallback(macro_rules: bool) -> Self {
209-
if macro_rules { Transparency::SemiTransparent } else { Transparency::Opaque }
209+
if macro_rules { Transparency::SemiOpaque } else { Transparency::Opaque }
210210
}
211211
}
212212

@@ -454,7 +454,7 @@ impl HygieneData {
454454

455455
fn normalize_to_macro_rules(&self, ctxt: SyntaxContext) -> SyntaxContext {
456456
debug_assert!(!self.syntax_context_data[ctxt.0 as usize].is_decode_placeholder());
457-
self.syntax_context_data[ctxt.0 as usize].opaque_and_semitransparent
457+
self.syntax_context_data[ctxt.0 as usize].opaque_and_semiopaque
458458
}
459459

460460
fn outer_expn(&self, ctxt: SyntaxContext) -> ExpnId {
@@ -547,7 +547,7 @@ impl HygieneData {
547547
}
548548

549549
let call_site_ctxt = self.expn_data(expn_id).call_site.ctxt();
550-
let mut call_site_ctxt = if transparency == Transparency::SemiTransparent {
550+
let mut call_site_ctxt = if transparency == Transparency::SemiOpaque {
551551
self.normalize_to_macros_2_0(call_site_ctxt)
552552
} else {
553553
self.normalize_to_macro_rules(call_site_ctxt)
@@ -581,8 +581,7 @@ impl HygieneData {
581581
let syntax_context_data = &mut self.syntax_context_data;
582582
debug_assert!(!syntax_context_data[ctxt.0 as usize].is_decode_placeholder());
583583
let mut opaque = syntax_context_data[ctxt.0 as usize].opaque;
584-
let mut opaque_and_semitransparent =
585-
syntax_context_data[ctxt.0 as usize].opaque_and_semitransparent;
584+
let mut opaque_and_semiopaque = syntax_context_data[ctxt.0 as usize].opaque_and_semiopaque;
586585

587586
if transparency >= Transparency::Opaque {
588587
let parent = opaque;
@@ -596,30 +595,30 @@ impl HygieneData {
596595
outer_transparency: transparency,
597596
parent,
598597
opaque: new_opaque,
599-
opaque_and_semitransparent: new_opaque,
598+
opaque_and_semiopaque: new_opaque,
600599
dollar_crate_name: kw::DollarCrate,
601600
});
602601
new_opaque
603602
});
604603
}
605604

606-
if transparency >= Transparency::SemiTransparent {
607-
let parent = opaque_and_semitransparent;
608-
opaque_and_semitransparent = *self
605+
if transparency >= Transparency::SemiOpaque {
606+
let parent = opaque_and_semiopaque;
607+
opaque_and_semiopaque = *self
609608
.syntax_context_map
610609
.entry((parent, expn_id, transparency))
611610
.or_insert_with(|| {
612-
let new_opaque_and_semitransparent =
611+
let new_opaque_and_semiopaque =
613612
SyntaxContext::from_usize(syntax_context_data.len());
614613
syntax_context_data.push(SyntaxContextData {
615614
outer_expn: expn_id,
616615
outer_transparency: transparency,
617616
parent,
618617
opaque,
619-
opaque_and_semitransparent: new_opaque_and_semitransparent,
618+
opaque_and_semiopaque: new_opaque_and_semiopaque,
620619
dollar_crate_name: kw::DollarCrate,
621620
});
622-
new_opaque_and_semitransparent
621+
new_opaque_and_semiopaque
623622
});
624623
}
625624

@@ -630,7 +629,7 @@ impl HygieneData {
630629
outer_transparency: transparency,
631630
parent,
632631
opaque,
633-
opaque_and_semitransparent,
632+
opaque_and_semiopaque,
634633
dollar_crate_name: kw::DollarCrate,
635634
});
636635
SyntaxContext::from_usize(syntax_context_data.len() - 1)

compiler/rustc_span/src/lib.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -1112,7 +1112,7 @@ impl Span {
11121112
/// Equivalent of `Span::mixed_site` from the proc macro API,
11131113
/// except that the location is taken from the `self` span.
11141114
pub fn with_mixed_site_ctxt(self, expn_id: ExpnId) -> Span {
1115-
self.with_ctxt_from_mark(expn_id, Transparency::SemiTransparent)
1115+
self.with_ctxt_from_mark(expn_id, Transparency::SemiOpaque)
11161116
}
11171117

11181118
/// Produces a span with the same location as `self` and context produced by a macro with the

compiler/rustc_span/src/symbol.rs

+1
Original file line numberDiff line numberDiff line change
@@ -1868,6 +1868,7 @@ symbols! {
18681868
select_unpredictable,
18691869
self_in_typedefs,
18701870
self_struct_ctor,
1871+
semiopaque,
18711872
semitransparent,
18721873
sha2,
18731874
sha3,

tests/ui/hygiene/rustc-macro-transparency.rs

+6-6
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,9 @@ macro transparent() {
66
let transparent = 0;
77
}
88
#[rustc_macro_transparency = "semitransparent"]
9-
macro semitransparent() {
10-
struct SemiTransparent;
11-
let semitransparent = 0;
9+
macro semiopaque() {
10+
struct SemiOpaque;
11+
let semiopaque = 0;
1212
}
1313
#[rustc_macro_transparency = "opaque"]
1414
macro opaque() {
@@ -18,14 +18,14 @@ macro opaque() {
1818

1919
fn main() {
2020
transparent!();
21-
semitransparent!();
21+
semiopaque!();
2222
opaque!();
2323

2424
Transparent; // OK
25-
SemiTransparent; // OK
25+
SemiOpaque; // OK
2626
Opaque; //~ ERROR cannot find value `Opaque` in this scope
2727

2828
transparent; // OK
29-
semitransparent; //~ ERROR expected value, found macro `semitransparent`
29+
semiopaque; //~ ERROR expected value, found macro `semiopaque`
3030
opaque; //~ ERROR expected value, found macro `opaque`
3131
}

tests/ui/hygiene/rustc-macro-transparency.stderr

+6-6
Original file line numberDiff line numberDiff line change
@@ -4,17 +4,17 @@ error[E0425]: cannot find value `Opaque` in this scope
44
LL | Opaque;
55
| ^^^^^^ not found in this scope
66

7-
error[E0423]: expected value, found macro `semitransparent`
7+
error[E0423]: expected value, found macro `semiopaque`
88
--> $DIR/rustc-macro-transparency.rs:29:5
99
|
10-
LL | struct SemiTransparent;
11-
| ----------------------- similarly named unit struct `SemiTransparent` defined here
10+
LL | struct SemiOpaque;
11+
| ------------------ similarly named unit struct `SemiOpaque` defined here
1212
...
13-
LL | semitransparent;
14-
| ^^^^^^^^^^^^^^^
13+
LL | semiopaque;
14+
| ^^^^^^^^^^
1515
| |
1616
| not a value
17-
| help: a unit struct with a similar name exists: `SemiTransparent`
17+
| help: a unit struct with a similar name exists (notice the capitalization): `SemiOpaque`
1818

1919
error[E0423]: expected value, found macro `opaque`
2020
--> $DIR/rustc-macro-transparency.rs:30:5

tests/ui/hygiene/unpretty-debug.stdout

+1-1
Original file line numberDiff line numberDiff line change
@@ -24,5 +24,5 @@ crate0::{{expn1}}: parent: crate0::{{expn0}}, call_site_ctxt: #0, def_site_ctxt:
2424

2525
SyntaxContexts:
2626
#0: parent: #0, outer_mark: (crate0::{{expn0}}, Opaque)
27-
#1: parent: #0, outer_mark: (crate0::{{expn1}}, SemiTransparent)
27+
#1: parent: #0, outer_mark: (crate0::{{expn1}}, SemiOpaque)
2828
*/

tests/ui/proc-macro/meta-macro-hygiene.stdout

+3-3
Original file line numberDiff line numberDiff line change
@@ -60,11 +60,11 @@ SyntaxContexts:
6060
#0: parent: #0, outer_mark: (crate0::{{expn0}}, Opaque)
6161
#1: parent: #0, outer_mark: (crate0::{{expn1}}, Opaque)
6262
#2: parent: #0, outer_mark: (crate0::{{expn1}}, Transparent)
63-
#3: parent: #0, outer_mark: (crate0::{{expn2}}, SemiTransparent)
63+
#3: parent: #0, outer_mark: (crate0::{{expn2}}, SemiOpaque)
6464
#4: parent: #0, outer_mark: (crate0::{{expn3}}, Opaque)
6565
#5: parent: #3, outer_mark: (crate0::{{expn3}}, Transparent)
66-
#6: parent: #0, outer_mark: (crate0::{{expn3}}, SemiTransparent)
66+
#6: parent: #0, outer_mark: (crate0::{{expn3}}, SemiOpaque)
6767
#7: parent: #0, outer_mark: (crate0::{{expn4}}, Opaque)
6868
#8: parent: #4, outer_mark: (crate0::{{expn4}}, Transparent)
69-
#9: parent: #4, outer_mark: (crate0::{{expn4}}, SemiTransparent)
69+
#9: parent: #4, outer_mark: (crate0::{{expn4}}, SemiOpaque)
7070
*/

tests/ui/proc-macro/nonterminal-token-hygiene.stdout

+2-2
Original file line numberDiff line numberDiff line change
@@ -82,10 +82,10 @@ SyntaxContexts:
8282
#0: parent: #0, outer_mark: (crate0::{{expn0}}, Opaque)
8383
#1: parent: #0, outer_mark: (crate0::{{expn1}}, Opaque)
8484
#2: parent: #0, outer_mark: (crate0::{{expn1}}, Transparent)
85-
#3: parent: #0, outer_mark: (crate0::{{expn2}}, SemiTransparent)
85+
#3: parent: #0, outer_mark: (crate0::{{expn2}}, SemiOpaque)
8686
#4: parent: #0, outer_mark: (crate0::{{expn3}}, Opaque)
8787
#5: parent: #3, outer_mark: (crate0::{{expn3}}, Opaque)
8888
#6: parent: #0, outer_mark: (crate0::{{expn4}}, Opaque)
8989
#7: parent: #5, outer_mark: (crate0::{{expn4}}, Transparent)
90-
#8: parent: #4, outer_mark: (crate0::{{expn4}}, SemiTransparent)
90+
#8: parent: #4, outer_mark: (crate0::{{expn4}}, SemiOpaque)
9191
*/

0 commit comments

Comments
 (0)