2014-01-11 15:19:38 +01:00
|
|
|
% How to submit a Rust bug report
|
2013-12-22 20:21:45 -06:00
|
|
|
|
|
|
|
# I think I found a bug in the compiler!
|
|
|
|
|
2014-11-25 13:20:47 +01:00
|
|
|
If you see this message: `error: internal compiler error: unexpected panic`,
|
2013-12-22 20:21:45 -06:00
|
|
|
then you have definitely found a bug in the compiler. It's also possible that
|
|
|
|
your code is not well-typed, but if you saw this message, it's still a bug in
|
|
|
|
error reporting.
|
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
If you see a message about an LLVM assertion failure, then you have also
|
2013-12-22 20:21:45 -06:00
|
|
|
definitely found a bug in the compiler. In both of these cases, it's not your
|
|
|
|
fault and you should report a bug!
|
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
If you see a compiler error message that you think is meant for users to see,
|
2013-12-22 20:21:45 -06:00
|
|
|
but it confuses you, *that's a bug too*. If it wasn't clear to you, then it's
|
|
|
|
an error message we want to improve, so please report it so that we can try
|
|
|
|
to make it better.
|
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
# How do I know the bug I found isn't a bug that already exists in the issue tracker?
|
2013-12-22 20:21:45 -06:00
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
If you don't have enough time for a search, then don't worry about that. Just submit
|
|
|
|
the bug. If it's a duplicate, somebody will notice that and close it during triage.
|
2013-12-22 20:21:45 -06:00
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
If you have the time for it, it would be useful to type the text of the error
|
2014-06-16 16:07:34 -07:00
|
|
|
message you got [into the issue tracker search box](https://github.com/rust-lang/rust/issues)
|
2013-12-22 20:21:45 -06:00
|
|
|
to see if there's an existing bug that resembles your problem. If there is,
|
2014-01-11 15:19:38 +01:00
|
|
|
and it's an open bug, you can comment on that issue and say you are also affected.
|
|
|
|
This will encourage the devs to fix it. But again, don't let this stop you from
|
2013-12-22 20:21:45 -06:00
|
|
|
submitting a bug. We'd rather have to do the work of closing duplicates than
|
|
|
|
miss out on valid bug reports.
|
|
|
|
|
|
|
|
# What information should I include in a bug report?
|
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
It generally helps our diagnosis to include your specific OS (for example: Mac OS X 10.8.3,
|
|
|
|
Windows 7, Ubuntu 12.04) and your hardware architecture (for example: i686, x86_64).
|
2014-10-22 12:17:50 +13:00
|
|
|
It's also helpful to provide the exact version and host by copying the output of
|
2014-12-22 19:43:57 -05:00
|
|
|
re-running the erroneous rustc command with the `--version --verbose` flags, which will
|
2014-10-22 12:17:50 +13:00
|
|
|
produce something like this:
|
|
|
|
|
2014-12-11 11:47:16 -05:00
|
|
|
```text
|
2014-10-22 12:17:50 +13:00
|
|
|
rustc 0.12.0 (ba4081a5a 2014-10-07 13:44:41 -0700)
|
|
|
|
binary: rustc
|
|
|
|
commit-hash: ba4081a5a8573875fed17545846f6f6902c8ba8d
|
|
|
|
commit-date: 2014-10-07 13:44:41 -0700
|
|
|
|
host: i686-apple-darwin
|
|
|
|
release: 0.12.0
|
|
|
|
```
|
|
|
|
|
2014-12-11 11:47:16 -05:00
|
|
|
Finally, if you can also provide a backtrace, that'd be great. You can get a
|
|
|
|
backtrace by setting the `RUST_BACKTRACE` environment variable to `1`, like
|
|
|
|
this:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ RUST_BACKTRACE=1 rustc ...
|
|
|
|
```
|
2013-12-22 20:21:45 -06:00
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
# I submitted a bug, but nobody has commented on it!
|
2013-12-22 20:21:45 -06:00
|
|
|
|
2014-01-11 15:19:38 +01:00
|
|
|
This is sad, but does happen sometimes, since we're short-staffed. If you
|
2013-12-22 20:21:45 -06:00
|
|
|
submit a bug and you haven't received a comment on it within 3 business days,
|
|
|
|
it's entirely reasonable to either ask on the #rust IRC channel,
|
|
|
|
or post on the [rust-dev mailing list](https://mail.mozilla.org/listinfo/rust-dev)
|
|
|
|
to ask what the status of the bug is.
|