@@ -1267,6 +1267,90 @@ impl Step for Clippy {
12671267 }
12681268}
12691269
1270+ #[ derive( Debug , PartialOrd , Ord , Copy , Clone , Hash , PartialEq , Eq ) ]
1271+ pub struct Miri {
1272+ pub stage : u32 ,
1273+ pub target : Interned < String > ,
1274+ }
1275+
1276+ impl Step for Miri {
1277+ type Output = Option < PathBuf > ;
1278+ const ONLY_HOSTS : bool = true ;
1279+
1280+ fn should_run ( run : ShouldRun ) -> ShouldRun {
1281+ run. path ( "miri" )
1282+ }
1283+
1284+ fn make_run ( run : RunConfig ) {
1285+ run. builder . ensure ( Miri {
1286+ stage : run. builder . top_stage ,
1287+ target : run. target ,
1288+ } ) ;
1289+ }
1290+
1291+ fn run ( self , builder : & Builder ) -> Option < PathBuf > {
1292+ let stage = self . stage ;
1293+ let target = self . target ;
1294+ assert ! ( builder. config. extended) ;
1295+
1296+ builder. info ( & format ! ( "Dist miri stage{} ({})" , stage, target) ) ;
1297+ let src = builder. src . join ( "src/tools/miri" ) ;
1298+ let release_num = builder. release_num ( "miri" ) ;
1299+ let name = pkgname ( builder, "miri" ) ;
1300+ let version = builder. miri_info . version ( builder, & release_num) ;
1301+
1302+ let tmp = tmpdir ( builder) ;
1303+ let image = tmp. join ( "miri-image" ) ;
1304+ drop ( fs:: remove_dir_all ( & image) ) ;
1305+ builder. create_dir ( & image) ;
1306+
1307+ // Prepare the image directory
1308+ // We expect miri to build, because we've exited this step above if tool
1309+ // state for miri isn't testing.
1310+ let miri = builder. ensure ( tool:: Miri {
1311+ compiler : builder. compiler ( stage, builder. config . build ) ,
1312+ target, extra_features : Vec :: new ( )
1313+ } ) . or_else ( || { missing_tool ( "miri" , builder. build . config . missing_tools ) ; None } ) ?;
1314+ let cargomiri = builder. ensure ( tool:: CargoMiri {
1315+ compiler : builder. compiler ( stage, builder. config . build ) ,
1316+ target, extra_features : Vec :: new ( )
1317+ } ) . or_else ( || { missing_tool ( "cargo miri" , builder. build . config . missing_tools ) ; None } ) ?;
1318+
1319+ builder. install ( & miri, & image. join ( "bin" ) , 0o755 ) ;
1320+ builder. install ( & cargomiri, & image. join ( "bin" ) , 0o755 ) ;
1321+ let doc = image. join ( "share/doc/miri" ) ;
1322+ builder. install ( & src. join ( "README.md" ) , & doc, 0o644 ) ;
1323+ builder. install ( & src. join ( "LICENSE-APACHE" ) , & doc, 0o644 ) ;
1324+ builder. install ( & src. join ( "LICENSE-MIT" ) , & doc, 0o644 ) ;
1325+
1326+ // Prepare the overlay
1327+ let overlay = tmp. join ( "miri-overlay" ) ;
1328+ drop ( fs:: remove_dir_all ( & overlay) ) ;
1329+ t ! ( fs:: create_dir_all( & overlay) ) ;
1330+ builder. install ( & src. join ( "README.md" ) , & overlay, 0o644 ) ;
1331+ builder. install ( & src. join ( "LICENSE-APACHE" ) , & doc, 0o644 ) ;
1332+ builder. install ( & src. join ( "LICENSE-MIT" ) , & doc, 0o644 ) ;
1333+ builder. create ( & overlay. join ( "version" ) , & version) ;
1334+
1335+ // Generate the installer tarball
1336+ let mut cmd = rust_installer ( builder) ;
1337+ cmd. arg ( "generate" )
1338+ . arg ( "--product-name=Rust" )
1339+ . arg ( "--rel-manifest-dir=rustlib" )
1340+ . arg ( "--success-message=miri-ready-to-serve." )
1341+ . arg ( "--image-dir" ) . arg ( & image)
1342+ . arg ( "--work-dir" ) . arg ( & tmpdir ( builder) )
1343+ . arg ( "--output-dir" ) . arg ( & distdir ( builder) )
1344+ . arg ( "--non-installed-overlay" ) . arg ( & overlay)
1345+ . arg ( format ! ( "--package-name={}-{}" , name, target) )
1346+ . arg ( "--legacy-manifest-dirs=rustlib,cargo" )
1347+ . arg ( "--component-name=miri-preview" ) ;
1348+
1349+ builder. run ( & mut cmd) ;
1350+ Some ( distdir ( builder) . join ( format ! ( "{}-{}.tar.gz" , name, target) ) )
1351+ }
1352+ }
1353+
12701354#[ derive( Debug , PartialOrd , Ord , Copy , Clone , Hash , PartialEq , Eq ) ]
12711355pub struct Rustfmt {
12721356 pub stage : u32 ,
0 commit comments