summaryrefslogtreecommitdiffstats
path: root/httpd/cgi-bin/check
diff options
context:
space:
mode:
authorMichael[tm] Smith <mike@w3.org>2015-07-22 23:16:20 +0900
committerMichael[tm] Smith <mike@w3.org>2015-07-27 14:15:09 +0900
commit1b12fe496bb457950944782f133f547cee3cef56 (patch)
tree15313ed84cd6fdaf292567e9bbef3d2886faf480 /httpd/cgi-bin/check
parent4a5a0bd321aead5f01a7ad3decd33e1ebd0576ba (diff)
downloadmarkup-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-xhttpd/cgi-bin/check56
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;