--- trunk/lib/Frey/Web.pm 2008/12/16 14:10:09 857
+++ trunk/lib/Frey/Web.pm 2009/01/02 13:22:13 908
@@ -94,7 +94,7 @@
sub popup { my $self = shift; $self->popup_dropdown('popup', @_); }
sub dropdown { my $self = shift; $self->popup_dropdown('dropdown', @_); }
-our $re_html = qr{<(?:!--.+?--|(\w+).+?/\1|[^>]+/?)>}s; # relaxed html check for one semi-valid tag
+our $re_html = qr{<(?:!--|(\w+)|[^>]+)/?>}s; # relaxed html check for one semi-valid tag
sub popup_dropdown {
my ( $self, $type, $name, $content, $full ) = @_;
@@ -116,9 +116,11 @@
}
}
-sub _inline_path_size {
+sub _inline {
my ( $self, $path ) = @_;
- -s $path < $self->inline_smaller_than && -s $path;
+ return unless defined $path;
+ warn "# _inline $path";
+ -e $path && -s $path < $self->inline_smaller_than && -s $path;
}
sub _head_html {
@@ -126,13 +128,14 @@
my $out = '';
foreach my $path ( @head ) {
$path =~ s!^/!!;
- my $size = $self->_inline_path_size( $path );
if ( $path =~ m/\.js$/ ) {
- $out .= $size ?
+ my $size;
+ $out .= $size = _inline( $path ) ?
qq|| :
qq||;
} elsif ( $path =~ m/\.css$/ ) {
- $out .= $size ?
+ my $size;
+ $out .= $size = _inline( $path ) ?
qq|| :
qq||;
} elsif ( $path =~ m{<.+>}s ) {
@@ -184,18 +187,23 @@
my ( $package, $path, $line ) = caller(1);
- if ( $content =~ m{\.(js|css)} ) {
- $content = "/$content" if -e $content;
+ $content = "/$content" if -e $content;
+ if ( $content =~ $re_html ) {
+ $head = qq|
+ $content
+
+ |;
+ } elsif ( $content =~ m{^(/|https?://)} ) {
if ( $what eq 'js' ) {
$head = qq|
<$tag type="$type" src="$content">
- /* via $package at $path line $line */
+ /* $what via $package at $path line $line */
$tag>
|;
} else {
$head = qq|
-
+
|;
}
} else {
@@ -241,8 +249,6 @@
my $self = shift;
my $a = {@_};
- warn "## page ",dump($a);
-
$reload_counter++;
my $status_line = '';