Finish Tcl/Tk documentation

pull/337/merge
Thibaut Courouble 9 years ago
parent 63c77322d3
commit 23ebf25bcb

Binary file not shown.

Before

Width:  |  Height:  |  Size: 36 KiB

After

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 95 KiB

After

Width:  |  Height:  |  Size: 96 KiB

@ -1,5 +1,8 @@
[ [
[ [
"2016-01-31",
"New documentation: <a href=\"/tcl_tk/\">Tcl/Tk</a>"
], [
"2016-01-24", "2016-01-24",
"&ldquo;Multi-version support&rdquo; has landed!\nClick <a href=\"#\" data-pick-docs>Select documentation</a> to pick which versions to use. More versions will be added in the coming weeks.\nIf you notice any bugs, please report them on <a href=\"https://github.com/Thibaut/devdocs/issues\" target=\"_blank\">GitHub</a>." "&ldquo;Multi-version support&rdquo; has landed!\nClick <a href=\"#\" data-pick-docs>Select documentation</a> to pick which versions to use. More versions will be added in the coming weeks.\nIf you notice any bugs, please report them on <a href=\"https://github.com/Thibaut/devdocs/issues\" target=\"_blank\">GitHub</a>."
], [ ], [

@ -384,6 +384,11 @@ credits = [
'2004-2016 Fabien Potencier', '2004-2016 Fabien Potencier',
'MIT', 'MIT',
'http://symfony.com/doc/current/contributing/code/license.html' 'http://symfony.com/doc/current/contributing/code/license.html'
], [
'Tcl/Tk',
'The Regents of the University of California, Sun Microsystems, Inc., Scriptics Corporation, and other parties',
'Tcl/Tk',
'http://tcl.tk/software/tcltk/license.html'
], [ ], [
'Underscore.js', 'Underscore.js',
'2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors', '2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors',

@ -4,7 +4,7 @@
width: 1rem; width: 1rem;
height: 1rem; height: 1rem;
background-image: image-url('icons.png'); background-image: image-url('icons.png');
background-size: 10rem 10rem; background-size: 10rem 11rem;
} }
@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { @media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {
@ -122,3 +122,4 @@
._icon-flow:before { background-position: -7rem -9rem; } ._icon-flow:before { background-position: -7rem -9rem; }
._icon-relay:before { background-position: -8rem -9rem; } ._icon-relay:before { background-position: -8rem -9rem; }
._icon-phoenix:before { background-position: -9rem -9rem; } ._icon-phoenix:before { background-position: -9rem -9rem; }
._icon-tcl_tk:before { background-position: 0 -10rem; }

@ -1,19 +1,5 @@
._tcl_tk { ._tcl_tk {
/* make content listing more compact */ @extend %simple;
.description {
margin: 0; dl { margin: .5em 0; }
> dd {
margin: 0;
}
}
dl {
margin: 0;
}
.copy {
/* per page copyright */
white-space: pre;
font-size: 80%;
border-top: 1px solid #6A6A6A;
margin-top: 2em;
}
} }

@ -2,48 +2,38 @@ module Docs
class TclTk class TclTk
class CleanHtmlFilter < Filter class CleanHtmlFilter < Filter
def call def call
# Page Title css('h2').remove # Page Title
css('h2').remove css('h3:first-child').remove # Navigation
# Navigation
css('h3:first-child').remove css('div.copy').each do |node|
# restore breaks in copyright node['class'] = '_attribution'
txt = at_css('div.copy').content node.inner_html = %(<p class="_attribution-p">#{node.inner_html.gsub(' Copyright', '<br>\0')}</p>)
at_css('div.copy').content = txt.gsub! /.Copyright/, "\n\\0" end
file = result[:path].split('/')[-1]
re = Regexp.new('^' + Regexp.escape(file) + '(#.*)$')
css('a[name]').each do |node| css('a[name]').each do |node|
if node['href'] then node.parent['id'] = node['name']
# useless name node.before(node.children).remove unless node['href']
node.remove_attribute 'name'
# make fragments relativ
if node['href'].match re then
node['href'] = node['href'].sub re, '\\1'
end
else
# move name to id
node.parent['id'] = node['name']
node.parent.content = node.content
end
end end
# remove keywords headline css('h3').each do |node|
css('h3').each do |node| if node.content == 'KEYWORDS'
if node.content == 'KEYWORDS' then node['id'] = 'tmp__'
node.remove css('#tmp__ ~ a[href*="Keywords"]').each do |link|
end link.next.remove if link.next.content == ', '
end link.remove
# remove keywords links
css('a').each do |node|
attr = node.attribute('href')
if attr && attr.value.match(/\/Keywords\//) then
# the ','
if node.next_sibling then
node.next_sibling.remove
end end
node.remove node.remove
next
end end
end
node.name = 'h2'
node.content = node.content.capitalize
end
css('h4').each do |node|
node.name = 'h3'
node.content = node.content.capitalize
end
doc doc
end end

@ -1,56 +1,43 @@
module Docs module Docs
class TclTk class TclTk
class EntriesFilter < Docs::EntriesFilter class EntriesFilter < Docs::EntriesFilter
#def additional_entries
# type = nil
#end
def split_slug
slug.sub! /\.html?/, ''
return *slug.split('/')
end
TYPE_MAP = { TYPE_MAP = {
'UserCmd' => 'Applications',
'TclCmd' => 'Tcl', 'TclCmd' => 'Tcl',
'TkCmd' => 'Tk', 'TkCmd' => 'Tk',
'ItclCmd' => 'incr', 'ItclCmd' => '[incr Tcl]',
'SqliteCmd' => 'tdbc', 'SqliteCmd' => 'TDBC',
'TdbcCmd' => 'tdbc', 'TdbcCmd' => 'TDBC',
'TdbcmysqlCmd' => 'tdbc', 'TdbcmysqlCmd' => 'TDBC',
'TdbcodbcCmd' => 'tdbc', 'TdbcodbcCmd' => 'TDBC',
'TdbcpostgresCmd' => 'tdbc', 'TdbcpostgresCmd' => 'TDBC',
'TdbcsqliteCmd' => 'tdbc', 'TdbcsqliteCmd' => 'TDBC',
'ThreadCmd' => 'Thread', 'ThreadCmd' => 'Thread'
'UserCmd' => 'App'
} }
def get_type def get_name
type, name = split_slug if slug == 'contents.htm'
type = TYPE_MAP[type] || type TYPE_MAP[slug.split('/').first]
if name == 'contents' then else
type = nil slug.split('/').last.remove('.htm')
end end
type
end end
def get_name def get_type
type, name = split_slug return nil if name == 'contents'
name TYPE_MAP.fetch(slug.split('/').first)
end end
def additional_entries def additional_entries
type, name = split_slug css('> dl.command > dt > a[name]:not([href])', '> dl.commands > dt > a[name]:not([href])').each_with_object [] do |node, entries|
if type != 'TclCmd' || name != 'library' then name = node.at_xpath("./b[not(text()='#{self.name}')]").try(:content)
return [] next unless name
end name.strip!
# special rule for library page which contains multiple commands at once name.remove! %r{\A:+}
entries = [] name.prepend "#{self.name}: " unless name =~ /#{self.name}[:\s]/ || name =~ /#{self.name.gsub('_', '::')}[:\s]/
css('a > b').each do |node| next if entries.any? { |entry| entry[0] == name }
text = node.content.strip entries << [name, node['name']]
id = node.parent['href'].sub /^.*#(.*)$/, '\\1'
entries << [text, id, TYPE_MAP[type]]
end end
return entries
end end
end end
end end

@ -2,41 +2,28 @@ module Docs
class TclTk < UrlScraper class TclTk < UrlScraper
self.name = 'Tcl/Tk' self.name = 'Tcl/Tk'
self.type = 'tcl_tk' self.type = 'tcl_tk'
self.slug = 'tcl' self.slug = 'tcl_tk'
self.version = '8.6' self.release = '8.6'
# test URL: self.base_url = 'https://www.tcl.tk/man/tcl/'
self.base_url = 'http://localhost/tcl/'
# real URL:
#self.base_url = 'http://www.tcl.tk/man/tcl/'
self.root_path = 'contents.htm' self.root_path = 'contents.htm'
html_filters.push 'tcl_tk/clean_html', 'tcl_tk/entries' html_filters.push 'tcl_tk/entries', 'tcl_tk/clean_html', 'title'
options[:skip_links] = false
options[:root_title] = 'Tcl/Tk Documentation'
options[:trailing_slash] = false options[:trailing_slash] = false
options[:skip] = ['siteinfo.htm'] options[:skip] = %w(siteinfo.htm)
options[:skip_patterns] = [ options[:skip_patterns] = [
# ignore keyword list pages # ignore keyword list pages
/^Keywords\//, /\AKeywords\//,
# ignore C-API, only required for extension developers # ignore C-API, only required for extension developers
/^TclLib\//, /\ATclLib\//,
/^TkLib\//, /\ATkLib\//,
/^ItclLib\//, /\AItclLib\//,
/^TdbcLib\// /\ATdbcLib\//
] ]
# TODO can't figure out howto convert .htm => .html in filenames
# to save as "xyz.html" instead of "xyz.htm.html"
#options[:fix_urls] = ->(url) do
# url.sub! /\.htm($|#)/, '.html\\1'
# url
#end
# Each Page contains a specific list of copyrights, only add the
# overall license link
options[:attribution] = <<-HTML options[:attribution] = <<-HTML
Licensed under <a href="http://tcl.tk/software/tcltk/license.html">Tcl/Tk Terms</a> Licensed under <a href="http://tcl.tk/software/tcltk/license.html">Tcl/Tk terms</a>
HTML HTML
end end
end end

Binary file not shown.

Before

Width:  |  Height:  |  Size: 444 B

After

Width:  |  Height:  |  Size: 387 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 992 B

After

Width:  |  Height:  |  Size: 853 B

Loading…
Cancel
Save