ptx_parser/parser/instruction/
isspacep.rs1#![allow(unused)]
7
8use crate::lexer::PtxToken;
9use crate::parser::{PtxParseError, PtxParser, PtxTokenStream, Span};
10use crate::r#type::common::*;
11
12pub mod section_0 {
13 use super::*;
14 use crate::r#type::instruction::isspacep::section_0::*;
15
16 impl PtxParser for Space {
21 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
22 {
24 let saved_pos = stream.position();
25 if stream.expect_string(".shared::cluster").is_ok() {
26 return Ok(Space::SharedCluster);
27 }
28 stream.set_position(saved_pos);
29 }
30 let saved_pos = stream.position();
31 {
33 let saved_pos = stream.position();
34 if stream.expect_string(".param::entry").is_ok() {
35 return Ok(Space::ParamEntry);
36 }
37 stream.set_position(saved_pos);
38 }
39 stream.set_position(saved_pos);
40 let saved_pos = stream.position();
41 {
43 let saved_pos = stream.position();
44 if stream.expect_string(".shared::cta").is_ok() {
45 return Ok(Space::SharedCta);
46 }
47 stream.set_position(saved_pos);
48 }
49 stream.set_position(saved_pos);
50 let saved_pos = stream.position();
51 {
53 let saved_pos = stream.position();
54 if stream.expect_string(".global").is_ok() {
55 return Ok(Space::Global);
56 }
57 stream.set_position(saved_pos);
58 }
59 stream.set_position(saved_pos);
60 let saved_pos = stream.position();
61 {
63 let saved_pos = stream.position();
64 if stream.expect_string(".shared").is_ok() {
65 return Ok(Space::Shared);
66 }
67 stream.set_position(saved_pos);
68 }
69 stream.set_position(saved_pos);
70 let saved_pos = stream.position();
71 {
73 let saved_pos = stream.position();
74 if stream.expect_string(".const").is_ok() {
75 return Ok(Space::Const);
76 }
77 stream.set_position(saved_pos);
78 }
79 stream.set_position(saved_pos);
80 let saved_pos = stream.position();
81 {
83 let saved_pos = stream.position();
84 if stream.expect_string(".local").is_ok() {
85 return Ok(Space::Local);
86 }
87 stream.set_position(saved_pos);
88 }
89 stream.set_position(saved_pos);
90 let saved_pos = stream.position();
91 {
93 let saved_pos = stream.position();
94 if stream.expect_string(".param").is_ok() {
95 return Ok(Space::Param);
96 }
97 stream.set_position(saved_pos);
98 }
99 stream.set_position(saved_pos);
100 let span = stream.peek().map(|(_, s)| s.clone()).unwrap_or(Span { start: 0, end: 0 });
101 let expected = &[".shared::cluster", ".param::entry", ".shared::cta", ".global", ".shared", ".const", ".local", ".param"];
102 let found = stream.peek().map(|(t, _)| format!("{:?}", t)).unwrap_or_else(|_| "<end of input>".to_string());
103 Err(crate::parser::unexpected_value(span, expected, found))
104 }
105 }
106
107 impl PtxParser for IsspacepSpace {
108 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
109 stream.expect_string("isspacep")?;
110 let space = Space::parse(stream)?;
111 stream.expect_complete()?;
112 let p = GeneralOperand::parse(stream)?;
113 stream.expect_complete()?;
114 stream.expect(&PtxToken::Comma)?;
115 let a = GeneralOperand::parse(stream)?;
116 stream.expect_complete()?;
117 stream.expect_complete()?;
118 stream.expect(&PtxToken::Semicolon)?;
119 Ok(IsspacepSpace {
120 space,
121 p,
122 a,
123 })
124 }
125 }
126
127
128}
129