Rollup merge of #71428 - tromey:gdb-10-parsing, r=tromey
Let compiletest recognize gdb 10.x git gdb has moved to version 10. My build prints this as its --version: GNU gdb (GDB) 10.0.50.20200420-git Unfortunately this conflicts with this comment in compiletest: // We limit major to 1 digit, otherwise, on openSUSE, we parse the openSUSE version This patch changes the version parsing to follow the GNU coding standard, which accounts for both the openSUSE case as well as handling gdb 10. My debuginfo test run now says: NOTE: compiletest thinks it is using GDB with native rust support NOTE: compiletest thinks it is using GDB version 10000050 ... where previously it failed to find that gdb 10 had rust support.
This commit is contained in:
commit
715948eb51
@ -831,12 +831,28 @@ fn extract_gdb_version(full_version_line: &str) -> Option<u32> {
|
|||||||
// GDB versions look like this: "major.minor.patch?.yyyymmdd?", with both
|
// GDB versions look like this: "major.minor.patch?.yyyymmdd?", with both
|
||||||
// of the ? sections being optional
|
// of the ? sections being optional
|
||||||
|
|
||||||
// We will parse up to 3 digits for minor and patch, ignoring the date
|
// We will parse up to 3 digits for each component, ignoring the date
|
||||||
// We limit major to 1 digit, otherwise, on openSUSE, we parse the openSUSE version
|
|
||||||
|
// We skip text in parentheses. This avoids accidentally parsing
|
||||||
|
// the openSUSE version, which looks like:
|
||||||
|
// GNU gdb (GDB; openSUSE Leap 15.0) 8.1
|
||||||
|
// This particular form is documented in the GNU coding standards:
|
||||||
|
// https://www.gnu.org/prep/standards/html_node/_002d_002dversion.html#g_t_002d_002dversion
|
||||||
|
|
||||||
// don't start parsing in the middle of a number
|
// don't start parsing in the middle of a number
|
||||||
let mut prev_was_digit = false;
|
let mut prev_was_digit = false;
|
||||||
|
let mut in_parens = false;
|
||||||
for (pos, c) in full_version_line.char_indices() {
|
for (pos, c) in full_version_line.char_indices() {
|
||||||
|
if in_parens {
|
||||||
|
if c == ')' {
|
||||||
|
in_parens = false;
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
} else if c == '(' {
|
||||||
|
in_parens = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if prev_was_digit || !c.is_digit(10) {
|
if prev_was_digit || !c.is_digit(10) {
|
||||||
prev_was_digit = c.is_digit(10);
|
prev_was_digit = c.is_digit(10);
|
||||||
continue;
|
continue;
|
||||||
@ -876,7 +892,7 @@ fn extract_gdb_version(full_version_line: &str) -> Option<u32> {
|
|||||||
None => (line, None),
|
None => (line, None),
|
||||||
};
|
};
|
||||||
|
|
||||||
if major.len() != 1 || minor.is_empty() {
|
if minor.is_empty() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,9 +7,9 @@ fn test_extract_gdb_version() {
|
|||||||
)*}}}
|
)*}}}
|
||||||
|
|
||||||
test! {
|
test! {
|
||||||
7000001: "GNU gdb (GDB) CentOS (7.0.1-45.el5.centos)",
|
7000001: "GNU gdb (GDB) CentOS 7.0.1-45.el5.centos",
|
||||||
|
|
||||||
7002000: "GNU gdb (GDB) Red Hat Enterprise Linux (7.2-90.el6)",
|
7002000: "GNU gdb (GDB) Red Hat Enterprise Linux 7.2-90.el6",
|
||||||
|
|
||||||
7004000: "GNU gdb (Ubuntu/Linaro 7.4-2012.04-0ubuntu2.1) 7.4-2012.04",
|
7004000: "GNU gdb (Ubuntu/Linaro 7.4-2012.04-0ubuntu2.1) 7.4-2012.04",
|
||||||
7004001: "GNU gdb (GDB) 7.4.1-debian",
|
7004001: "GNU gdb (GDB) 7.4.1-debian",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user