ptx_parser/parser/instruction/
dp2a.rs1#![allow(unused)]
8
9use crate::lexer::PtxToken;
10use crate::parser::{PtxParseError, PtxParser, PtxTokenStream, Span};
11use crate::r#type::common::*;
12
13pub mod section_0 {
14 use super::*;
15 use crate::r#type::instruction::dp2a::section_0::*;
16
17 impl PtxParser for Atype {
22 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
23 {
25 let saved_pos = stream.position();
26 if stream.expect_string(".u32").is_ok() {
27 return Ok(Atype::U32);
28 }
29 stream.set_position(saved_pos);
30 }
31 let saved_pos = stream.position();
32 {
34 let saved_pos = stream.position();
35 if stream.expect_string(".s32").is_ok() {
36 return Ok(Atype::S32);
37 }
38 stream.set_position(saved_pos);
39 }
40 stream.set_position(saved_pos);
41 let span = stream.peek().map(|(_, s)| s.clone()).unwrap_or(Span { start: 0, end: 0 });
42 let expected = &[".u32", ".s32"];
43 let found = stream.peek().map(|(t, _)| format!("{:?}", t)).unwrap_or_else(|_| "<end of input>".to_string());
44 Err(crate::parser::unexpected_value(span, expected, found))
45 }
46 }
47
48 impl PtxParser for Btype {
49 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
50 {
52 let saved_pos = stream.position();
53 if stream.expect_string(".u32").is_ok() {
54 return Ok(Btype::U32);
55 }
56 stream.set_position(saved_pos);
57 }
58 let saved_pos = stream.position();
59 {
61 let saved_pos = stream.position();
62 if stream.expect_string(".s32").is_ok() {
63 return Ok(Btype::S32);
64 }
65 stream.set_position(saved_pos);
66 }
67 stream.set_position(saved_pos);
68 let span = stream.peek().map(|(_, s)| s.clone()).unwrap_or(Span { start: 0, end: 0 });
69 let expected = &[".u32", ".s32"];
70 let found = stream.peek().map(|(t, _)| format!("{:?}", t)).unwrap_or_else(|_| "<end of input>".to_string());
71 Err(crate::parser::unexpected_value(span, expected, found))
72 }
73 }
74
75 impl PtxParser for Mode {
76 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
77 {
79 let saved_pos = stream.position();
80 if stream.expect_string(".lo").is_ok() {
81 return Ok(Mode::Lo);
82 }
83 stream.set_position(saved_pos);
84 }
85 let saved_pos = stream.position();
86 {
88 let saved_pos = stream.position();
89 if stream.expect_string(".hi").is_ok() {
90 return Ok(Mode::Hi);
91 }
92 stream.set_position(saved_pos);
93 }
94 stream.set_position(saved_pos);
95 let span = stream.peek().map(|(_, s)| s.clone()).unwrap_or(Span { start: 0, end: 0 });
96 let expected = &[".lo", ".hi"];
97 let found = stream.peek().map(|(t, _)| format!("{:?}", t)).unwrap_or_else(|_| "<end of input>".to_string());
98 Err(crate::parser::unexpected_value(span, expected, found))
99 }
100 }
101
102 impl PtxParser for Dp2aModeAtypeBtype {
103 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
104 stream.expect_string("dp2a")?;
105 let mode = Mode::parse(stream)?;
106 stream.expect_complete()?;
107 let atype = Atype::parse(stream)?;
108 stream.expect_complete()?;
109 let btype = Btype::parse(stream)?;
110 stream.expect_complete()?;
111 let d = GeneralOperand::parse(stream)?;
112 stream.expect_complete()?;
113 stream.expect(&PtxToken::Comma)?;
114 let a = GeneralOperand::parse(stream)?;
115 stream.expect_complete()?;
116 stream.expect(&PtxToken::Comma)?;
117 let b = GeneralOperand::parse(stream)?;
118 stream.expect_complete()?;
119 stream.expect(&PtxToken::Comma)?;
120 let c = GeneralOperand::parse(stream)?;
121 stream.expect_complete()?;
122 stream.expect_complete()?;
123 stream.expect(&PtxToken::Semicolon)?;
124 Ok(Dp2aModeAtypeBtype {
125 mode,
126 atype,
127 btype,
128 d,
129 a,
130 b,
131 c,
132 })
133 }
134 }
135
136
137}
138