diff options
author | Michael[tm] Smith <mike@w3.org> | 2015-07-22 23:16:20 +0900 |
---|---|---|
committer | Michael[tm] Smith <mike@w3.org> | 2015-07-27 14:15:09 +0900 |
commit | 1b12fe496bb457950944782f133f547cee3cef56 (patch) | |
tree | 15313ed84cd6fdaf292567e9bbef3d2886faf480 /httpd/cgi-bin/check | |
parent | 4a5a0bd321aead5f01a7ad3decd33e1ebd0576ba (diff) | |
download | markup-validator-origin/sideshowbarker/html5-updates.zip markup-validator-origin/sideshowbarker/html5-updates.tar.gz markup-validator-origin/sideshowbarker/html5-updates.tar.bz2 |
Further refinements to checking of HTML5 documentsorigin/sideshowbarker/html5-updates
Tested and found to be working as expected.
This causes all validation requests for HTML5 documents to just get
re-posted as-is to https://validator.w3.org/nu/ using an HTTP 307
"Temporary Redirect".* —with the exception of any requests that have
`output=soap12` or `output=ucn` parameters.
The reason for making temporary exceptions for those soap12/ucn cases is that
some existing tools such as Dreamweaver apparently have integrated support
for HTML checking that relies on calling https://validator.w3.org/ to do
the validation, and that expects the results in the `output=soap12` format.
Other than those exceptions, this change properly 307-redirects all requests
for checking of HTML5 documents to https://validator.w3.org/nu/ (that
includes file-upload requests as well direct-input requests and URL-input
GET requests, and any `output=json` requests regardless of method).
*Note: Using a 307 gives the meaning "I'm redirecting this particular
request to https://validator.w3.org/nu/ but that doesn't imply you should
necessarily use https://validator.w3.org/nu/ for any further requests",
which seems like the right meaning for this particular case.
Diffstat (limited to 'httpd/cgi-bin/check')
-rwxr-xr-x | httpd/cgi-bin/check | 56 |
1 files changed, 28 insertions, 28 deletions
diff --git a/httpd/cgi-bin/check b/httpd/cgi-bin/check index 99d97db..2ec6825 100755 --- a/httpd/cgi-bin/check +++ b/httpd/cgi-bin/check @@ -28,7 +28,6 @@ use 5.008; use strict; use warnings; use utf8; -use MIME::Base64 (); package W3C::Validator::MarkupValidator; @@ -622,12 +621,6 @@ $File->{WF_Errors} = []; if (($File->{DOCTYPE} eq "HTML5") or ($File->{DOCTYPE} eq "XHTML5")) { if ($CFG->{External}->{HTML5}) { $File = &html5_validate($File); - &add_warning( - 'W00', - { W00_experimental_name => "HTML5 Conformance Checker", - W00_experimental_URI => "feedback.html" - } - ); } else { $File->{'Error Flagged'} = TRUE; @@ -644,12 +637,6 @@ elsif (($File->{DOCTYPE} eq '') and # namespaces found, to a different engine. WARNING this is experimental. if ($CFG->{External}->{CompoundXML}) { $File = &compoundxml_validate($File); - &add_warning( - 'W00', - { W00_experimental_name => "validator.nu Conformance Checker", - W00_experimental_URI => "feedback.html" - } - ); } } else { @@ -1098,21 +1085,8 @@ sub html5_validate (\$) $req->header('Accept-Encoding', 'identity'); } - my $source_option = $File->{Opt}->{'Show Source'} ? "&showsource=yes" : ""; - my $outline_option = $File->{Opt}->{Outline} ? "&showoutline=yes" : ""; - my $output_option = $File->{Opt}->{Output} eq 'json' ? "&out=json" : ""; - my $uri = uri_escape($File->{'URI'}); - if ($File->{'Direct Input'}) { - # if $req isn't actually encoded, this decode() call does nothing - $req->decode("gzip"); - $uri = "data:text/html;charset=utf-8;base64," . - uri_escape(MIME::Base64::encode_base64($req->content)); - } - if (!$File->{'Is Upload'}) { - print redirect - 'https://validator.w3.org/nu/?doc=' . $uri . - $source_option . $outline_option . $output_option; - } + redirect_html5_requests(); + my $res = $ua->request($req); if (!$res->is_success()) { $File->{'Error Flagged'} = TRUE; @@ -1457,6 +1431,10 @@ sub prep_template ($$) my $T = shift; # + # URL for Nu Html Checker + $T->param(htmlchecker_url => $CFG->{External}->{HTML5}); + + # # XML mode... $T->param(is_xml => &is_xml($File)); @@ -1591,6 +1569,9 @@ sub fin_template ($$) } my ($num_errors, $num_warnings, $num_info, $reported_errors) = &report_errors($File); + if ($File->{Version} eq "HTML5") { + $num_warnings++; + } if ($num_errors + $num_warnings > 0) { $T->param(has_errors => 1); } @@ -3378,6 +3359,25 @@ sub self_url_file return $thispage; } +sub redirect_html5_requests +{ + return if ($File->{Opt}->{Output} eq 'soap12'); + return if ($File->{Opt}->{Output} eq 'ucn'); + return if not($CFG->{External}->{HTML5}); + if ($File->{'Direct Input'} || $File->{'Is Upload'}) { + my $hash = $File->{'Direct Input'} ? "#textarea" : "#file"; + print redirect( + -uri => $CFG->{External}->{HTML5} . $hash, + -status => '307 Temporary Redirect'); + } + my $source_option = $File->{Opt}->{'Show Source'} ? "&showsource=yes" : ""; + my $outline_option = $File->{Opt}->{Outline} ? "&showoutline=yes" : ""; + my $output_option = $File->{Opt}->{Output} eq 'json' ? "&out=json" : ""; + print redirect + $CFG->{External}->{HTML5} . '?doc=' . uri_escape($File->{'URI'}) . + $source_option . $outline_option . $output_option; +} + ##### package W3C::Validator::EventHandler; |