The compile_fail flag ensures that the given code blocks don't compile. As simple as that. It's mostly used when you're showing bad code and demonstrating why it is bad. For example:
/// ```compile_fail /// let x = 0; /// x += 2; // Damn! `x` isn't mutable so you cannot update it... /// ```
Then you just write a small explanation about what went wrong and show a working example. It's very common in tutorials, to help users understand why it's wrong and how to fix it.
In addition to this, please note that there will be a graphical indication that this block is supposed to fail at compilation:
data:image/s3,"s3://crabby-images/c55a1/c55a1732316ea03bd923e8d0e7fd7e9ff49614c7" alt=""
Figure 10.8
And when you hover over the sign:
data:image/s3,"s3://crabby-images/14fb9/14fb9d9b3f3986d6edbd6210db2fb46ff72a8ea8" alt=""
Figure 10.9
Let's continue with no_run!