Skip to content

Commit

Permalink
Fixed missing build prereqs
Browse files Browse the repository at this point in the history
  • Loading branch information
Pete Evstratov committed Jan 24, 2014
1 parent 60f5a16 commit ecab3ca
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 19 deletions.
10 changes: 7 additions & 3 deletions Changes
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
Revision history for Perl extension JavaScript::Minifier.

1.09 2013-01-22
1.10 2014-01-22
- Added missing test prereqs
- Fixed up wrong year in the latest versions in the change log

1.09 2014-01-22
- Made some changes to dzil plugins and added git repos for this module

1.08 2013-01-19
1.08 2014-01-19
- Fixed RT#76800 (preserve "\n" at the end of file)

1.07 2013-01-19
1.07 2014-01-19
- Fixed license issue (RT#92298)
- Converted to Dist::Zilla for packaging

Expand Down
9 changes: 6 additions & 3 deletions dist.ini
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,18 @@ name = JavaScript-Minifier
author = Zoffix Znet <cpan@zoffix.com>
license = Perl_5
copyright_holder = Peter Michaux <petermichaux@gmail.com>

[@Basic]

[Prereqs]
Exporter = 5.64_03

[Prereqs / TestRequires]
Test::More = 0.88

[Git::NextVersion]
first_version = 1.09
version_regexp = ^(.+)$
version_regexp = ^(.+)$

[MetaResources]
repository.type = git
Expand Down
26 changes: 13 additions & 13 deletions lib/JavaScript/Minifier.pm
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ require Exporter;
our @ISA = qw(Exporter);
our @EXPORT = qw(minify);

our $VERSION = '1.09';
our $VERSION = '1.10';

#return true if the character is allowed in identifier.
sub isAlphanum {
Expand Down Expand Up @@ -43,7 +43,7 @@ sub isPostfix {

sub _get {
my $s = shift;

if ($s->{inputType} eq 'file') {
my $char = getc($s->{input});
$s->{last_read_char} = $char
Expand Down Expand Up @@ -89,7 +89,7 @@ sub _put {
sub action1 {
my $s = shift;
if (!isWhitespace($s->{a})) {
$s->{lastnws} = $s->{a};
$s->{lastnws} = $s->{a};
}
$s->{last} = $s->{a};
action2($s);
Expand Down Expand Up @@ -136,8 +136,8 @@ sub putLiteral {
action1($s);
do {
while (defined($s->{a}) && $s->{a} eq '\\') { # escape character only escapes only the next one character
action1($s);
action1($s);
action1($s);
action1($s);
}
action1($s);
} until ($s->{last} eq $delimiter || !defined($s->{a}));
Expand Down Expand Up @@ -232,11 +232,11 @@ sub minify {
my $ccFlag; # marks if a comment is an Internet Explorer conditional comment and should be printed to output

while (defined($s->{a})) { # on this line $s->{a} should always be a non-whitespace character or undef (i.e. end of file)

if (isWhitespace($s->{a})) { # check that this program is running correctly
die 'minifier bug: minify while loop starting with whitespace, stopped';
}

# Each branch handles trailing whitespace and ensures $s->{a} is on non-whitespace or undef when branch finishes
if ($s->{a} eq '/') { # a division, comment, or regexp literal
if (defined($s->{b}) && $s->{b} eq '/') { # slash-slash comment
Expand All @@ -253,7 +253,7 @@ sub minify {
preserveEndspace($s);
}
else {
skipWhitespace($s);
skipWhitespace($s);
}
}
}
Expand All @@ -273,7 +273,7 @@ sub minify {
action3($s); # the *
$s->{a} = ' '; # the /
collapseWhitespace($s);
if (defined($s->{last}) && defined($s->{b}) &&
if (defined($s->{last}) && defined($s->{b}) &&
((isAlphanum($s->{last}) && (isAlphanum($s->{b})||$s->{b} eq '.')) ||
($s->{last} eq '+' && $s->{b} eq '+') || ($s->{last} eq '-' && $s->{b} eq '-'))) { # for a situation like 5-/**/-2 or a/**/a
# When entering this block $s->{a} is whitespace.
Expand Down Expand Up @@ -341,15 +341,15 @@ sub minify {
skipWhitespace($s);
}
}

if ( $s->{last_read_char} =~ /\n/ ) {
_put($s, "\n");
}

if (!defined($s->{outfile})) {
return $s->{output};
}

} # minify()

1;
Expand All @@ -375,7 +375,7 @@ To minify a JavaScript file and have the output written directly to another file
To minify a JavaScript string literal. Note that by omitting the outfile parameter a the minified code is returned as a string.
my minifiedJavaScript = minify(input => 'var x = 2;');
To include a copyright comment at the top of the minified code.
minify(input => 'var x = 2;', copyright => 'BSD License');
Expand Down

0 comments on commit ecab3ca

Please sign in to comment.