ptx_parser/parser/instruction/
madc.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::madc::section_0::*;
16
17 impl PtxParser for Hilo {
22 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
23 {
25 let saved_pos = stream.position();
26 if stream.expect_string(".hi").is_ok() {
27 return Ok(Hilo::Hi);
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(".lo").is_ok() {
36 return Ok(Hilo::Lo);
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 = &[".hi", ".lo"];
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 Type {
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(Type::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(Type::S32);
64 }
65 stream.set_position(saved_pos);
66 }
67 stream.set_position(saved_pos);
68 let saved_pos = stream.position();
69 {
71 let saved_pos = stream.position();
72 if stream.expect_string(".u64").is_ok() {
73 return Ok(Type::U64);
74 }
75 stream.set_position(saved_pos);
76 }
77 stream.set_position(saved_pos);
78 let saved_pos = stream.position();
79 {
81 let saved_pos = stream.position();
82 if stream.expect_string(".s64").is_ok() {
83 return Ok(Type::S64);
84 }
85 stream.set_position(saved_pos);
86 }
87 stream.set_position(saved_pos);
88 let span = stream.peek().map(|(_, s)| s.clone()).unwrap_or(Span { start: 0, end: 0 });
89 let expected = &[".u32", ".s32", ".u64", ".s64"];
90 let found = stream.peek().map(|(t, _)| format!("{:?}", t)).unwrap_or_else(|_| "<end of input>".to_string());
91 Err(crate::parser::unexpected_value(span, expected, found))
92 }
93 }
94
95 impl PtxParser for MadcHiloCcType {
96 fn parse(stream: &mut PtxTokenStream) -> Result<Self, PtxParseError> {
97 stream.expect_string("madc")?;
98 let hilo = Hilo::parse(stream)?;
99 stream.expect_complete()?;
100 let saved_pos = stream.position();
101 let cc = stream.expect_string(".cc").is_ok();
102 if !cc {
103 stream.set_position(saved_pos);
104 }
105 stream.expect_complete()?;
106 let type_ = Type::parse(stream)?;
107 stream.expect_complete()?;
108 let d = GeneralOperand::parse(stream)?;
109 stream.expect_complete()?;
110 stream.expect(&PtxToken::Comma)?;
111 let a = GeneralOperand::parse(stream)?;
112 stream.expect_complete()?;
113 stream.expect(&PtxToken::Comma)?;
114 let b = GeneralOperand::parse(stream)?;
115 stream.expect_complete()?;
116 stream.expect(&PtxToken::Comma)?;
117 let c = GeneralOperand::parse(stream)?;
118 stream.expect_complete()?;
119 stream.expect_complete()?;
120 stream.expect(&PtxToken::Semicolon)?;
121 Ok(MadcHiloCcType {
122 hilo,
123 cc,
124 type_,
125 d,
126 a,
127 b,
128 c,
129 })
130 }
131 }
132
133
134}
135