5 use Data::Dump qw(dump);
7 # ./vlan-ports.pl ./log/*sw-{dpc,e300}*vlan* | less
9 my $debug = $ENV{DEBUG} || 1;
12 @logs = glob('./log/*vlan*') unless @logs;
16 foreach my $log ( @logs ) {
17 warn "###< $log\n" if $debug;
18 open(my $log_fh, '-|', "./table2tab.pl '$log'");
19 my $sw = $log; $sw =~ s/^.*?_//; $sw =~ s/_.*$//;
23 my ($vlan,$name,$ports,$type,$authorization);
25 my @v = split(/\t/, $_);
28 ($vlan,$name,$ports,$type,$authorization) = @v;
29 } elsif ( $#v == 3 ) {
30 ($vlan,$name,$ports,$type) = @v;
31 } elsif ( $#v == 5 ) {
32 ($vlan,$name,$ports,undef,$type) = @v;
34 warn "ERROR: ", scalar(@v), " elements in [$_]" if $#v != 4;
37 $ports =~ s{(Po|Gi\d/\d/|Te\d/\d/)}{}gi;
39 warn "$sw $vlan $name $ports $type\n";
40 $stat->{$sw}->{_vlan_count}->{$vlan}++;
42 while ( $ports =~ s/(ch\([^\)]+\))// ) {
43 warn "# removed [$1] from ports\n";
46 while ( $ports =~ s/(\d+)-(\d+)// ) {
47 foreach my $port ( $1 .. $2 ) {
48 push @{ $stat->{$sw}->{port_vlan}->{$port} }, $vlan;
49 push @{ $stat->{$sw}->{vlan_port}->{$vlan} }, $port;
52 while ( $ports =~ s/(\d+)// ) {
54 push @{ $stat->{$sw}->{port_vlan}->{$port} }, $vlan;
55 push @{ $stat->{$sw}->{vlan_port}->{$vlan} }, $port;
57 #warn "# ports left:[$ports] stat = ",dump($stat);
59 warn "INGORED [$_]\n";
67 foreach my $sw ( sort keys %$stat ) {
68 my @ports = sort { $a <=> $b } keys %{ $stat->{$sw}->{port_vlan} };
69 #warn "# ports = ",dump( \@ports );
70 printf( "%-11s %-5s %s\n", ('-' x 11), ('-' x 5), join(' ', map { sprintf("%-2s", $_) } ( 1 .. $ports[-1] )) );
71 foreach my $vlan ( sort { $a <=> $b } keys %{ $stat->{$sw}->{vlan_port} } ) {
72 my @p = ( '.' ) x ( $ports[-1] + 1 );
73 foreach my $port ( @{ $stat->{$sw}->{vlan_port}->{$vlan} } ) {
76 shift @p; # skip port 0
77 #warn "# $sw $vlan p = ",dump( \@p );
78 printf( "%-11s %-5d %s\n", $sw, $vlan, join(' ', map { sprintf("%-2s", $_) } @p) );