Commit 06c5d264 by Eric Botcazou Committed by Eric Botcazou

gcc-dg.exp (cleanup-ada-spec): New procedure.

	* lib/gcc-dg.exp (cleanup-ada-spec): New procedure.
	* lib/scanasm.exp (get_ada_spec_filename): Likewise.
	(scan-ada-spec): Likewise.
	(scan-ada-spec-not): Likewise.
	* gcc.dg/dump-ada-spec-1.c: New test.
	* g++.dg/other/dump-ada-spec-1.C: Likewise.

From-SVN: r192106
parent 6b3aed13
2012-10-04 Eric Botcazou <ebotcazou@adacore.com> 2012-10-04 Eric Botcazou <ebotcazou@adacore.com>
* lib/gcc-dg.exp (cleanup-ada-spec): New procedure.
* lib/scanasm.exp (get_ada_spec_filename): Likewise.
(scan-ada-spec): Likewise.
(scan-ada-spec-not): Likewise.
* gcc.dg/dump-ada-spec-1.c: New test.
* g++.dg/other/dump-ada-spec-1.C: Likewise.
2012-10-04 Eric Botcazou <ebotcazou@adacore.com>
* gcc.dg/lto/20120723_0.c: Skip on SPARC 32-bit. * gcc.dg/lto/20120723_0.c: Skip on SPARC 32-bit.
2012-10-04 Florian Weimer <fweimer@redhat.com> 2012-10-04 Florian Weimer <fweimer@redhat.com>
......
/* { dg-do compile } */
/* { dg-options "-fdump-ada-spec" } */
struct S
{
int i;
};
/* { dg-final { scan-ada-spec "type S is record" } } */
/* { dg-final { cleanup-ada-spec } } */
/* { dg-do compile } */
/* { dg-options "-fdump-ada-spec" } */
struct S
{
int i;
};
/* { dg-final { scan-ada-spec "type S is record" } } */
/* { dg-final { cleanup-ada-spec } } */
...@@ -503,6 +503,19 @@ proc cleanup-stack-usage { } { ...@@ -503,6 +503,19 @@ proc cleanup-stack-usage { } {
} }
} }
# Remove an Ada spec file for the current test.
proc cleanup-ada-spec { } {
set testcase [testname-for-summary]
remove-build-file "[get_ada_spec_filename $testcase]"
# Clean up files for additional source files.
if [info exists additional_sources] {
foreach srcfile $additional_sources {
remove-build-file "[get_ada_spec_filename $srcfile]"
}
}
}
# Remove all dump files with the provided suffix. # Remove all dump files with the provided suffix.
proc cleanup-dump { suffix } { proc cleanup-dump { suffix } {
set testcase [testname-for-summary] set testcase [testname-for-summary]
......
...@@ -184,6 +184,38 @@ proc scan-stack-usage-not { args } { ...@@ -184,6 +184,38 @@ proc scan-stack-usage-not { args } {
dg-scan "scan-file-not" 0 $testcase $output_file $args dg-scan "scan-file-not" 0 $testcase $output_file $args
} }
# Return the filename of the Ada spec corresponding to the argument.
proc get_ada_spec_filename { testcase } {
# The name might include a list of options; extract the file name.
set filename [lindex $testcase 0]
set tailname [file tail $filename]
set extension [string trimleft [file extension $tailname] {.}]
set rootname [regsub -all {\-} [file rootname $tailname] {_}]
return [string tolower "${rootname}_${extension}.ads"]
}
# Look for a pattern in the .ads file produced by the compiler. See
# dg-scan for details.
proc scan-ada-spec { args } {
set testcase [testname-for-summary]
set output_file "[get_ada_spec_filename $testcase]"
dg-scan "scan-file" 1 $testcase $output_file $args
}
# Check that a pattern is not present in the .ads file produced by the
# compiler. See dg-scan for details.
proc scan-ada-spec-not { args } {
set testcase [testname-for-summary]
set output_file "[get_ada_spec_filename $testcase]"
dg-scan "scan-file-not" 0 $testcase $output_file $args
}
# Call pass if pattern is present given number of times, otherwise fail. # Call pass if pattern is present given number of times, otherwise fail.
proc scan-assembler-times { args } { proc scan-assembler-times { args } {
if { [llength $args] < 2 } { if { [llength $args] < 2 } {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment