0xV3NOMx
Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64



Your IP : 3.15.1.23


Current Path : /proc/thread-self/root/usr/bin/
Upload File :
Current File : //proc/thread-self/root/usr/bin/texloganalyser

#!/usr/bin/env perl
# This is texloganalyser, for parsing of TeX logs
# Copyright (c) 2006-2014 Thomas van Oudenhove
# All rights reserved

# README - important notice:
# you should feed the first line with the path of your Perl executable
# (on *nix systems, the output of 'which perl')
#
# (this program works at least with perl 5.8.8)
# Getopt::Long MUST be installed on your system for this program to work

# License:
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
#    notice, this list of conditions and the following disclaimer in the
#    documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS''
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
# PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
# OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.

use warnings;
use strict;
use Getopt::Long;
Getopt::Long::Configure ("bundling");

my $version = "0.9";
my $copyright = "2006-2014";
my $opt = {
    help => '',
    version => '',
    last => '',
    a => '',
    h => '',
    o => '',
    u => '',
    v => '',
    p => '',
    f => '',
    w => '',
    e => '',
    i => '',
    s => '',
    r => '',
    t => '',
    n => '',
};

GetOptions(
    'help' => \$opt->{help},
    'version' => \$opt->{version},
    'last' => \$opt->{last},
    'a' => \$opt->{a},
    'h' => \$opt->{h},
    'o' => \$opt->{o},
    'u' => \$opt->{u},
    'v' => \$opt->{v},
    'p' => \$opt->{p},
    'f' => \$opt->{f},
    'w' => \$opt->{w},
    'e' => \$opt->{e},
    'i' => \$opt->{i},
    't' => \$opt->{t},
    's' => \$opt->{s},
    'r' => \$opt->{r},
    'n' => \$opt->{n},
);

my $abstract = {
    warnings => 0,
    badboxes => 0,
};

my $texlog = $ARGV[-1];

die "Usage: $0 ".options()." <TeX log>\n"
    if (not defined $texlog and
        (not $opt->{help} and not $opt->{version}));

if ($opt->{help}) {
    printhelp();
    exit();
}

if ($opt->{version}) {
    printversion();
    exit();
}

analyze();

sub analyze {
    my $line;
    my $output;
    my $test = 0;

    open my $source, "<", $texlog;
    while (defined ($line = <$source>)) {
        undef $output;
        # default: display summary
        summary($line);
        #          and page numbers ('n' option)
        pagenumber($line) if $opt->{n};

        if ($opt->{e}) {
            if ($line =~ m/Here is how much/) {
                $test = 1;
                $output = "\n";
            }
            $output .= $line if $test;
        }
        # look for boxes warnings
        if ($opt->{o} and $opt->{h}) {
            $output = $line if ($line =~ m/\\hbox/ and
                $line =~ m/Overfull/);
        } elsif ($opt->{u} and $opt->{h}) {
            $output = $line if ($line =~ m/\\hbox/ and
                $line =~ m/Underfull/);
        } elsif ($opt->{o} and $opt->{v}) {
            $output = $line if ($line =~ m/\\vbox/ and
                $line =~ m/Overfull/);
        } elsif ($opt->{u} and $opt->{v}) {
            $output = $line if ($line =~ m/\\vbox/ and
                $line =~ m/Underfull/);
        } elsif ($opt->{h} and $opt->{v}) {
            $output = $line if ($line =~ m/\\vbox/ or
                $line =~ m/\\hbox/);
        } elsif ($opt->{o} and $opt->{u}) {
            $output = $line if ($line =~ m/Underfull/ or
                $line =~ m/Overfull/);
        } elsif ($opt->{h}) {
            $output = $line if ($line =~ m/\\hbox/);
        } elsif ($opt->{v}) {
            $output = $line if ($line =~ m/\\vbox/);
        } elsif ($opt->{o}) {
            $output = $line if ($line =~ m/Overfull/);
            $abstract->{badboxes} += 1;
        } elsif ($opt->{u}) {
            $output = $line if ($line =~ m/Underfull/);
            $abstract->{badboxes} += 1;
        }
        # look for LaTeX Font Info
        if ($opt->{f}) {
            $output = $line if ($line =~ m/Font Info/);
        }
        # packages infos
        if ($opt->{p}) {
            $output = $line if ($line =~ m/Package/);
        }
        # references warnings
        if ($opt->{r}) {
            $output = $line if ($line =~ m/Reference/ or
                $line =~ m/Label(.*)/ and $1 =~ m/multiply defined/);
        }
        # TeX files used
        if ($opt->{t}) {
            scannedtexfiles($line, "tex");
        }
        # sty and cls files used
        if ($opt->{s}) {
            scannedfiles($line, "sty");
            scannedfiles($line, "cls");
        }
        # images (pdf, ps, jpg, png)
        if ($opt->{i}) {
            foreach my $t ('pdf', 'eps', 'ps', 'png', 'jpg') {
                scannedfiles($line, $t);
            }
        }
        # display all warnings
        if ($opt->{w}) {
            $output = $line if ($line =~ m/Warning/);
        }
        # if 'last' option, let's flush data
        if ($opt->{last} and $line =~ m/^This is .*TeX, Version 3\.14159/) {
            # Flush.
            $output = '';
            $abstract->{warnings} = 0;
        }

        print "$output" if defined $output;
    }
    print "\n";
    print_abstract();
    close $source;
}

sub pagenumber {
    my $logline = shift;
    if ($logline =~ m/.*(\[[0-9]+)/) {
        print $1."]";
    }
}

sub scannedfiles {
    my ($logline, $filetype) = @_;
    if ($logline =~ m/^\((.*\.$filetype)/i) {
        print "(".$1.")";
    }
}

sub scannedtexfiles {
    my ($logline, $filetype) = @_;
    if ($logline =~ m/\((.*\.$filetype)/i) {
        print "(".$1.")";
    }
}

sub summary {
    my $line = shift;
    # prints log summary ()
    $abstract->{warnings} += 1 if ($line =~ m/Warning/);
}

sub options {
    my $stropts = "[";
    my $multopt = '';
    foreach my $k (sort keys %{$opt}) {
        if ($k eq 'version') {
            $stropts .= "--version|";
        } elsif ($k eq 'help') {
            $stropts .= "--help|";
        } else {
            $multopt .= $k;
        }
    }
    $stropts .= '-'.$multopt.']';
    return $stropts;
}

sub print_abstract {
    print "The log contained ".$abstract->{warnings}." warnings";
    print " and $abstract->{badboxes} bad boxes" if $opt->{a}; 
    print ".\n";    
}

sub printversion {
    print "This is texloganalyser, version $version\n";
    print "\t Copyright $copyright Thomas van Oudenhove\n";
}

sub printhelp {
    printversion();
    print "Usage: texloganalyser ".options()." <TeX log>\n";
    print "\t Displays selective infos of LaTeX logs\n";
    print "These flags may be used:\n";
    print "\t a: displays number of warnings about bad boxes\n";
    print "\t e: displays the end of the log\n";
    print "\t f: outputs the LaTeX Font Infos\n";
    print "\t h: outputs only warnings about horizontal boxes\n";
    print "\t i: displays 'images' (pdf, [e]ps, png, jpg) used\n";
    print "\t n: displays page numbers\n";    
    print "\t o: outputs only warnings about overfull boxes\n";
    print "\t p: outputs the LaTeX Packages infos\n";
    print "\t r: displays warnings about references\n";
    print "\t s: displays .sty and .cls files used\n";
    print "\t t: displays .tex files used\n";
    print "\t u: outputs only warnings about underfull boxes\n";
    print "\t v: outputs only warnings about vertical boxes\n";
    print "\t w: displays all Warnings\n";
    print "You may want to have a look at `perldoc texloganalyser`.\n";
}

__END__


=pod

=head1 texloganalyser Documentation

=head2 NAME

texloganalyser -- displays selective infos from TeX log files

=head2 SYNOPSIS

texloganalyser [-aefhinoprstuvw] tex_log_file

texloganalyser [--version]

texloganalyser [--help]

=head2 DESCRIPTION

Various options may be used to select which information from the TeX log you want to see/analyze (see next section). The default is to display only warnings number.

=head2 OPTIONS

=over 1

=item B<--version>: displays version information.

=item B<--help>: displays help as a summary of options.

=item B<--last>: the Log file may content several logs; in this case, consider only the last one.

=item B<-a>: counts number of badboxes.

=item B<-e>: displays the end of the log, about the TeX's memory.

=item B<-f>: outputs the LaTeX Font Infos warnings and calculations.

=item B<-h>: outputs only warnings about horizontal boxes.

=item B<-i>: displays 'images' (pdf, [e]ps, png, jpg) used.

=item B<-n>: displays page numbers.

=item B<-o>: outputs only warnings about overfull boxes.

=item B<-p>: outputs the LaTeX Packages infos and warnings.

=item B<-r>: displays warnings about references (missing or multiply-defined).

=item B<-s>: displays .sty and .cls files used.

=item B<-t>: displays .tex files used. This option is B<very> useful when you parse logs of master files, to know in which file to look to correct errors/warnings.

=item B<-u>: outputs only warnings about underfull boxes.

=item B<-v>: outputs only warnings about vertical boxes.

=item B<-w>: displays all TeX, LaTeX and font Warnings.

=back

=head2 BUGS

None yet identified. However, the display should be improved...

=head2 HISTORY

This program was first released in 2006. Its purpose was to display selective information of my PhD's TeX log.

Markus Hennig submitted some new options (-a and -n) at the end of 2009.

Akim Demaille submitted a patch for 'last' option, June 2012.

=head3 Changelog

=over

=item v0.9: added option --last, if log file contains several compilations (Akim Demaille's patch).

=item v0.8: added options for page and bad boxes number (Markus Hennig's patch).

=item v0.7: bug patch for .tex files (-t option)

=item v0.6: default displays number of warnings (and page numbers).

  added option: references and label warnings

=item v0.5: use of GetOpt::Long and code cleaning

  added options: display of files used
  improved documentation

=item v0.4: added features and bugs corrections (options h, v, o and u)

=item v0.3: display of Warnings and last lines of the log

=item v0.2: display of "Font Info" and "Packages" added

=item v0.1: first version, displays only warnings about boxes

=back

=head2 AUTHORS

I<texloganalyser> is a program by Thomas van Oudenhove (L<thomasvo+tex_AT_thomasvo.net>). Feel free to contact him for features requests or bugs.

Markus Hennig submitted a patch, many thanks to him :).

June 2012, Akim Demaille submitted the 'last' option patch, many thanks to him :).

=cut