@@ -138,6 +138,34 @@ impl OutputType {
138
138
}
139
139
}
140
140
141
+ fn from_shorthand ( shorthand : & str ) -> Option < Self > {
142
+ Some ( match shorthand {
143
+ "asm" => OutputType :: Assembly ,
144
+ "llvm-ir" => OutputType :: LlvmAssembly ,
145
+ "mir" => OutputType :: Mir ,
146
+ "llvm-bc" => OutputType :: Bitcode ,
147
+ "obj" => OutputType :: Object ,
148
+ "metadata" => OutputType :: Metadata ,
149
+ "link" => OutputType :: Exe ,
150
+ "dep-info" => OutputType :: DepInfo ,
151
+ _ => return None ,
152
+ } )
153
+ }
154
+
155
+ fn shorthands_display ( ) -> String {
156
+ format ! (
157
+ "`{}`, `{}`, `{}`, `{}`, `{}`, `{}`, `{}`, `{}`" ,
158
+ OutputType :: Bitcode . shorthand( ) ,
159
+ OutputType :: Assembly . shorthand( ) ,
160
+ OutputType :: LlvmAssembly . shorthand( ) ,
161
+ OutputType :: Mir . shorthand( ) ,
162
+ OutputType :: Object . shorthand( ) ,
163
+ OutputType :: Metadata . shorthand( ) ,
164
+ OutputType :: Exe . shorthand( ) ,
165
+ OutputType :: DepInfo . shorthand( ) ,
166
+ )
167
+ }
168
+
141
169
pub fn extension ( & self ) -> & ' static str {
142
170
match * self {
143
171
OutputType :: Bitcode => "bc" ,
@@ -1485,19 +1513,13 @@ pub fn build_session_options_and_crate_config(matches: &getopts::Matches)
1485
1513
for list in matches. opt_strs ( "emit" ) {
1486
1514
for output_type in list. split ( ',' ) {
1487
1515
let mut parts = output_type. splitn ( 2 , '=' ) ;
1488
- let output_type = match parts. next ( ) . unwrap ( ) {
1489
- "asm" => OutputType :: Assembly ,
1490
- "llvm-ir" => OutputType :: LlvmAssembly ,
1491
- "mir" => OutputType :: Mir ,
1492
- "llvm-bc" => OutputType :: Bitcode ,
1493
- "obj" => OutputType :: Object ,
1494
- "metadata" => OutputType :: Metadata ,
1495
- "link" => OutputType :: Exe ,
1496
- "dep-info" => OutputType :: DepInfo ,
1497
- part => {
1498
- early_error ( error_format, & format ! ( "unknown emission type: `{}`" ,
1499
- part) )
1500
- }
1516
+ let shorthand = parts. next ( ) . unwrap ( ) ;
1517
+ let output_type = match OutputType :: from_shorthand ( shorthand) {
1518
+ Some ( output_type) => output_type,
1519
+ None => early_error ( error_format, & format ! (
1520
+ "unknown emission type: `{}` - expected one of: {}" ,
1521
+ shorthand, OutputType :: shorthands_display( ) ,
1522
+ ) ) ,
1501
1523
} ;
1502
1524
let path = parts. next ( ) . map ( PathBuf :: from) ;
1503
1525
output_types. insert ( output_type, path) ;
0 commit comments