[devdocsgjs/main: 3/76] migrate cpp scraper from filescraper to urlscraper
- From: Andy Holmes <andyholmes src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [devdocsgjs/main: 3/76] migrate cpp scraper from filescraper to urlscraper
- Date: Fri, 15 Jul 2022 21:39:45 +0000 (UTC)
commit e17bc84ea4c2a675fb16282339610dcab1506ce0
Author: Enoc <brianhernandez222 hotmail com>
Date: Thu Sep 9 00:03:46 2021 -0600
migrate cpp scraper from filescraper to urlscraper
lib/docs/filters/cpp/entries.rb | 20 ++++-
lib/docs/filters/cpp/fix_urls.rb | 11 ---
lib/docs/filters/cpp20/clean_html.rb | 9 --
lib/docs/filters/cpp20/entries.rb | 82 ------------------
lib/docs/filters/cppref/clean_html.rb | 116 ++++++++++++++++++++++++++
lib/docs/filters/cppref/fix_code.rb | 21 +++++
lib/docs/scrapers/cpp.rb | 52 ------------
lib/docs/scrapers/{cpp20.rb => cppref/cpp.rb} | 20 +----
lib/docs/scrapers/cppref/cppref.rb | 29 +++++++
9 files changed, 189 insertions(+), 171 deletions(-)
---
diff --git a/lib/docs/filters/cpp/entries.rb b/lib/docs/filters/cpp/entries.rb
index b0700139..d13526d3 100644
--- a/lib/docs/filters/cpp/entries.rb
+++ b/lib/docs/filters/cpp/entries.rb
@@ -1,6 +1,8 @@
module Docs
class Cpp
class EntriesFilter < Docs::EntriesFilter
+ @@duplicate_names = []
+
REPLACE_NAMES = {
'Error directive' => '#error directive',
'Filename and line information' => '#line directive',
@@ -11,7 +13,8 @@ module Docs
def get_name
name = at_css('#firstHeading').content.strip
name = format_name(name)
- name.split(',').first
+ name = name.split(',').first
+ name
end
def get_type
@@ -61,6 +64,21 @@ module Docs
REPLACE_NAMES[name] || name
end
+
+ # Avoid duplicate pages, these duplicate page are the same page for
+ # multiple functions that are organized in the same page because provide
+ # similar behavior but have different name.
+ def entries
+ entries = []
+
+ if !(@@duplicate_names.include?(name))
+ @@duplicate_names.push(name)
+ entries << default_entry if root_page? || include_default_entry?
+ entries.concat(additional_entries)
+ build_entries(entries)
+ end
+ end
+
end
end
end
diff --git a/lib/docs/filters/cppref/clean_html.rb b/lib/docs/filters/cppref/clean_html.rb
new file mode 100644
index 00000000..ced30f4d
--- /dev/null
+++ b/lib/docs/filters/cppref/clean_html.rb
@@ -0,0 +1,116 @@
+module Docs
+ class Cppref
+ class CleanHtmlFilter < Filter
+ def call
+ css('h1').remove if root_page?
+
+ css('.t-dcl-rev-aux td[rowspan]').each do |node|
+ rowspan = node['rowspan'].to_i
+ node['rowspan'] = node.ancestors('tbody').css('tr').length if rowspan > 3
+ end
+
+ css('#siteSub', '#contentSub', '.printfooter', '.t-navbar', '.editsection', '#toc',
+ '.t-dsc-sep', '.t-dcl-sep', '#catlinks', '.ambox-notice', '.mw-cite-backlink',
+ '.t-sdsc-sep:first-child:last-child', '.t-example-live-link',
+ '.t-dcl-rev-num > .t-dcl-rev-aux ~ tr:not(.t-dcl-rev-aux) > td:nth-child(2)').remove
+
+ css('#bodyContent', '.mw-content-ltr', 'span[style]', 'div[class^="t-ref"]', '.t-image',
+ 'th > div', 'td > div', '.t-dsc-see', '.mainpagediv', 'code > b', 'tbody').each do |node|
+ node.before(node.children).remove
+ end
+
+ css('div > ul').each do |node|
+ node.parent.before(node.parent.children).remove
+ end
+
+ css('dl > dd:first-child:last-child > ul:first-child:last-child').each do |node|
+ dl = node.parent.parent
+ if dl.previous_element && dl.previous_element.name == 'ul'
+ dl.previous_element << node
+ dl.remove
+ else
+ dl.before(node).remove
+ end
+ end
+
+ css('dl > dd:first-child:last-child').each do |node|
+ node.parent.before(node.children).remove
+ end
+
+ css('ul').each do |node|
+ while node.next_element && node.next_element.name == 'ul'
+ node << node.next_element.children
+ node.next_element.remove
+ end
+ end
+
+ css('h2 > span[id]', 'h3 > span[id]', 'h4 > span[id]', 'h5 > span[id]', 'h6 > span[id]').each do
|node|
+ node.parent['id'] = node['id']
+ node.before(node.children).remove
+ end
+
+ css('table[style]', 'th[style]', 'td[style]').remove_attr('style')
+ css('table[cellpadding]').remove_attr('cellpadding')
+
+ css('.t-dsc-hitem > td', '.t-dsc-header > td').each do |node|
+ node.name = 'th'
+ node.content = ' ' if node.content.empty?
+ end
+
+ css('tt', 'span > span.source-cpp', 'span.t-c', 'span.t-lc', 'span.t-dsc-see-tt').each do |node|
+ node.name = 'code'
+ node.remove_attribute('class')
+ node.content = node.content unless node.at_css('a')
+ end
+
+ css('div > span.source-cpp').each do |node|
+ node.name = 'pre'
+ node.inner_html = node.inner_html.gsub('<br>', "\n")
+ node.content = node.content
+ end
+
+ css('div > a > img[alt="About this image"]').each do |node|
+ node.parent.parent.remove
+ end
+
+ css('area[href]').each do |node|
+ node['href'] = node['href'].remove('.html')
+ end
+
+ css('p').each do |node|
+ while node.next && (node.next.text? || node.next.name == 'a' || node.next.name == 'code')
+ node << node.next
+ end
+ node.inner_html = node.inner_html.strip
+ node << '.' if node.content =~ /[a-zA-Z0-9\)]\z/
+ node.remove if node.content.blank? && !node.at_css('img')
+ end
+
+ css('pre').each do |node|
+ node['data-language'] = if node['class'].try(:include?, 'cpp') ||
node.parent['class'].try(:include?, 'cpp')
+ 'cpp'
+ else
+ 'c'
+ end
+ node.remove_attribute('class')
+ node.content = node.content.gsub("\t", ' ' * 8)
+ end
+
+ css('code code', '.mw-geshi').each do |node|
+ node.before(node.children).remove
+ end
+
+ css('h1 ~ .fmbox').each do |node|
+ node.name = 'div'
+ node.content = node.content
+ end
+
+ css('img').each do |node|
+ node['src'] = node['src'].sub! %r{http://en.cppreference.com/common/([^"']+?)\.svg},
'http://upload.cppreference.com/mwiki/\1.svg'
+ end
+
+ doc
+ end
+ end
+ end
+end
diff --git a/lib/docs/filters/cppref/fix_code.rb b/lib/docs/filters/cppref/fix_code.rb
new file mode 100644
index 00000000..c80a7426
--- /dev/null
+++ b/lib/docs/filters/cppref/fix_code.rb
@@ -0,0 +1,21 @@
+module Docs
+ class Cppref
+ class FixCodeFilter < Filter
+ def call
+ css('div > span.source-c', 'div > span.source-cpp').each do |node|
+ node.inner_html = node.inner_html.gsub(/<br>\n?/, "\n").gsub("\n</p>\n", "</p>\n")
+ node.parent.name = 'pre'
+ node.parent['class'] = node['class']
+ node.parent.content = node.content
+ end
+
+ nbsp = Nokogiri::HTML(' ').text
+ css('pre').each do |node|
+ node.content = node.content.gsub(nbsp, ' ')
+ end
+
+ doc
+ end
+ end
+ end
+end
diff --git a/lib/docs/scrapers/cpp20.rb b/lib/docs/scrapers/cppref/cpp.rb
similarity index 54%
rename from lib/docs/scrapers/cpp20.rb
rename to lib/docs/scrapers/cppref/cpp.rb
index 14034a43..bfc87c62 100644
--- a/lib/docs/scrapers/cpp20.rb
+++ b/lib/docs/scrapers/cppref/cpp.rb
@@ -1,17 +1,12 @@
module Docs
- class Cpp20 < UrlScraper
- self.name = 'C++20'
- self.slug = 'cpp20'
+ class Cpp < Cppref
+ self.name = 'C++'
+ self.slug = 'cpp'
self.type = 'c'
self.base_url = 'https://en.cppreference.com/w/cpp/'
- self.root_path = 'header'
- html_filters.insert_before 'clean_html', 'c/fix_code'
- html_filters.push 'cpp20/entries', 'c/clean_html', 'title'
+ html_filters.insert_before 'cppref/clean_html', 'cpp/entries'
- options[:decode_and_clean_paths] = true
- options[:container] = '#content'
- options[:title] = false
options[:root_title] = 'C++ Programming Language'
options[:skip] = %w(
@@ -21,13 +16,6 @@ module Docs
regex/regex_token_iterator/operator_cmp.html
)
- options[:skip_patterns] = [/experimental/]
-
- options[:attribution] = <<-HTML
- © cppreference.com<br>
- Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
- HTML
-
# Same as get_latest_version in lib/docs/scrapers/c.rb
def get_latest_version(opts)
doc = fetch_doc('https://en.cppreference.com/w/Cppreference:Archives', opts)
diff --git a/lib/docs/scrapers/cppref/cppref.rb b/lib/docs/scrapers/cppref/cppref.rb
new file mode 100644
index 00000000..b91751ef
--- /dev/null
+++ b/lib/docs/scrapers/cppref/cppref.rb
@@ -0,0 +1,29 @@
+module Docs
+ class Cppref < UrlScraper
+ self.abstract = true
+ self.type = 'cppref'
+ self.root_path = 'header'
+
+ html_filters.insert_before 'clean_html', 'cppref/fix_code'
+ html_filters.push 'cppref/clean_html', 'title'
+ # 'cpp20/entries',
+ options[:decode_and_clean_paths] = true
+ options[:container] = '#content'
+ options[:title] = false
+ options[:skip] = %w(language/history.html)
+
+ options[:skip_patterns] = [
+ /experimental/
+ ]
+
+ options[:attribution] = <<-HTML
+ © cppreference.com<br>
+ Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
+ HTML
+
+ # def get_latest_version
+
+ # end
+
+ end
+end
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]