| 
									
										
										
										
											2017-04-26 15:16:04 +02:00
										 |  |  | #!/usr/bin/env perl | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  | # Copyright (C) 2013 Red Hat, Inc. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Authors: | 
					
						
							|  |  |  | #  Markus Armbruster <armbru@redhat.com> | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # This work is licensed under the terms of the GNU GPL, version 2 or | 
					
						
							|  |  |  | # later.  See the COPYING file in the top-level directory. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Usage: cleanup-trace-events.pl trace-events | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Print cleaned up trace-events to standard output. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use warnings; | 
					
						
							|  |  |  | use strict; | 
					
						
							| 
									
										
										
										
											2019-03-14 19:09:27 +01:00
										 |  |  | use File::Basename; | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-06 16:13:32 +02:00
										 |  |  | my @files = (); | 
					
						
							|  |  |  | my $events = ''; | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  | my %seen = (); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sub out { | 
					
						
							| 
									
										
										
										
											2020-08-06 16:13:32 +02:00
										 |  |  |     print sort @files; | 
					
						
							|  |  |  |     print $events; | 
					
						
							|  |  |  |     @files = (); | 
					
						
							|  |  |  |     $events = ''; | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  |     %seen = (); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-14 19:09:27 +01:00
										 |  |  | $#ARGV == 0 or die "usage: $0 FILE"; | 
					
						
							|  |  |  | my $in = $ARGV[0]; | 
					
						
							|  |  |  | my $dir = dirname($in); | 
					
						
							|  |  |  | open(IN, $in) or die "open $in: $!"; | 
					
						
							|  |  |  | chdir($dir) or die "chdir $dir: $!"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | while (<IN>) { | 
					
						
							| 
									
										
										
										
											2020-08-06 16:13:31 +02:00
										 |  |  |     if (/^(disable |(tcg) |(vcpu) )*([a-z_0-9]+)\(/i) { | 
					
						
							|  |  |  |         my $pat = "trace_$4"; | 
					
						
							|  |  |  |         $pat .= '_tcg' if defined $2; | 
					
						
							|  |  |  |         open GREP, '-|', 'git', 'grep', '-lw', | 
					
						
							|  |  |  | 	    defined $3 ? () : ('--max-depth', '1'), | 
					
						
							|  |  |  | 	    $pat | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  |             or die "run git grep: $!"; | 
					
						
							| 
									
										
										
										
											2019-03-14 19:09:27 +01:00
										 |  |  |         while (my $fname = <GREP>) { | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  |             chomp $fname; | 
					
						
							|  |  |  |             next if $seen{$fname} || $fname eq 'trace-events'; | 
					
						
							|  |  |  |             $seen{$fname} = 1; | 
					
						
							| 
									
										
										
										
											2020-08-06 16:13:32 +02:00
										 |  |  |             push @files, "# $fname\n"; | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         unless (close GREP) { | 
					
						
							|  |  |  |             die "close git grep: $!" | 
					
						
							|  |  |  |                 if $!; | 
					
						
							|  |  |  |             next; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } elsif (/^# ([^ ]*\.[ch])$/) { | 
					
						
							|  |  |  |         out; | 
					
						
							|  |  |  |         next; | 
					
						
							|  |  |  |     } elsif (!/^#|^$/) { | 
					
						
							|  |  |  |         warn "unintelligible line"; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-08-06 16:13:32 +02:00
										 |  |  |     $events .= $_; | 
					
						
							| 
									
										
										
										
											2013-06-07 12:59:17 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | out; | 
					
						
							| 
									
										
										
										
											2019-03-14 19:09:27 +01:00
										 |  |  | close(IN) or die "close $in: $!"; |