cskit 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/Gemfile +8 -0
- data/History.txt +3 -0
- data/LICENSE +177 -0
- data/README.md +246 -0
- data/Rakefile +29 -0
- data/cskit.gemspec +25 -0
- data/lib/cskit/annotated_string.rb +73 -0
- data/lib/cskit/annotator.rb +16 -0
- data/lib/cskit/formatters/bible/bible_html_formatter.rb +41 -0
- data/lib/cskit/formatters/bible/bible_plain_text_formatter.rb +117 -0
- data/lib/cskit/formatters/bible.rb +12 -0
- data/lib/cskit/formatters/science_health/science_health_html_formatter.rb +32 -0
- data/lib/cskit/formatters/science_health/science_health_plain_text_formatter.rb +73 -0
- data/lib/cskit/formatters/science_health.rb +12 -0
- data/lib/cskit/formatters.rb +19 -0
- data/lib/cskit/lesson/lesson.rb +72 -0
- data/lib/cskit/lesson/section.rb +26 -0
- data/lib/cskit/lesson.rb +10 -0
- data/lib/cskit/parsers/bible/bible.rb +1005 -0
- data/lib/cskit/parsers/bible/bible.treetop +64 -0
- data/lib/cskit/parsers/bible/nodes.rb +153 -0
- data/lib/cskit/parsers/bible/objects.rb +81 -0
- data/lib/cskit/parsers/science_health/nodes.rb +82 -0
- data/lib/cskit/parsers/science_health/objects.rb +47 -0
- data/lib/cskit/parsers/science_health/science_health.rb +607 -0
- data/lib/cskit/parsers/science_health/science_health.treetop +44 -0
- data/lib/cskit/parsers.rb +8 -0
- data/lib/cskit/readers/bible_reader.rb +58 -0
- data/lib/cskit/readers/reading.rb +54 -0
- data/lib/cskit/readers/science_health_reader.rb +97 -0
- data/lib/cskit/readers.rb +9 -0
- data/lib/cskit/resources/volumes/bible.rb +45 -0
- data/lib/cskit/resources/volumes/science_health.rb +49 -0
- data/lib/cskit/resources/volumes.rb +8 -0
- data/lib/cskit/version.rb +5 -0
- data/lib/cskit/volume.rb +33 -0
- data/lib/cskit.rb +73 -0
- metadata +122 -0
@@ -0,0 +1,117 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Formatters
|
5
|
+
module Bible
|
6
|
+
class BiblePlainTextFormatter < CSKit::Formatters::Formatter
|
7
|
+
|
8
|
+
def format_readings(readings)
|
9
|
+
join_readings(readings) do |reading|
|
10
|
+
format_reading(reading)
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
def format_annotated_readings(readings, annotation_formatter)
|
15
|
+
join_readings(readings) do |reading|
|
16
|
+
format_annotated_reading(reading, annotation_formatter)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def join(texts)
|
21
|
+
texts.join(separator)
|
22
|
+
end
|
23
|
+
|
24
|
+
protected
|
25
|
+
|
26
|
+
def join_readings(readings)
|
27
|
+
join(
|
28
|
+
readings.map do |reading|
|
29
|
+
join(yield(reading))
|
30
|
+
end
|
31
|
+
)
|
32
|
+
end
|
33
|
+
|
34
|
+
def format_annotated_reading(reading, annotation_formatter)
|
35
|
+
reading.texts.each_with_index.map do |text, index|
|
36
|
+
starter_pos = starter_position(text, reading.verse.starter)
|
37
|
+
terminator_pos = terminator_position(text, reading.verse.terminator)
|
38
|
+
|
39
|
+
annotated_str = CSKit::AnnotatedString.new(text, reading.annotations_at(index))
|
40
|
+
annotated_str.delete(terminator_pos + 1, text.length - (terminator_pos + 1)) if terminator_pos
|
41
|
+
annotated_str.delete(0, starter_pos) if starter_pos
|
42
|
+
|
43
|
+
text = annotated_str.render do |snippet, annotation|
|
44
|
+
annotation_formatter.format_annotation(annotation, snippet)
|
45
|
+
end
|
46
|
+
|
47
|
+
verse_number = reading.verse.start + index
|
48
|
+
attach_verse_number(verse_number, text)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def format_reading(reading)
|
53
|
+
reading.texts.each_with_index.map do |text, index|
|
54
|
+
if index == 0
|
55
|
+
pos = starter_position(text, reading.verse.starter)
|
56
|
+
text = format_starter(pos ? text[pos..-1].strip : text.strip, pos)
|
57
|
+
end
|
58
|
+
|
59
|
+
if index == reading.texts.size - 1
|
60
|
+
pos = terminator_position(text, reading.verse.terminator)
|
61
|
+
text = format_terminator(pos ? text[0..pos] : text, pos)
|
62
|
+
end
|
63
|
+
|
64
|
+
verse_number = reading.verse.start + index
|
65
|
+
attach_verse_number(verse_number, text)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
def attach_verse_number(verse_number, text)
|
70
|
+
include_verse_number? ? "#{verse_number} #{text}" : text
|
71
|
+
end
|
72
|
+
|
73
|
+
def starter_position(text, starter)
|
74
|
+
if starter
|
75
|
+
regex = /\s+#{starter.fragment}([\s,\.\-_\?\!\.;:]|$)/
|
76
|
+
find_position(text, regex, starter.cardinality)
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
def format_starter(text, pos)
|
81
|
+
pos ? "..." + text : text
|
82
|
+
end
|
83
|
+
|
84
|
+
def terminator_position(text, terminator)
|
85
|
+
if terminator
|
86
|
+
regex = /#{Regexp.escape(terminator.fragment)}/
|
87
|
+
find_position(text, regex, terminator.cardinality)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
def format_terminator(text, pos)
|
92
|
+
text
|
93
|
+
end
|
94
|
+
|
95
|
+
def find_position(text, regex, cardinality)
|
96
|
+
(0...cardinality).inject(-1) do |last_index, _|
|
97
|
+
return nil unless last_index
|
98
|
+
text.index(regex, last_index + 1)
|
99
|
+
end
|
100
|
+
end
|
101
|
+
|
102
|
+
def separator
|
103
|
+
options[:separator] || " "
|
104
|
+
end
|
105
|
+
|
106
|
+
def include_verse_number?
|
107
|
+
if options[:include_verse_number].nil?
|
108
|
+
true # default
|
109
|
+
else
|
110
|
+
!!options[:include_verse_number]
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
end
|
115
|
+
end
|
116
|
+
end
|
117
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Formatters
|
5
|
+
module Bible
|
6
|
+
|
7
|
+
autoload :BiblePlainTextFormatter, "cskit/formatters/bible/bible_plain_text_formatter"
|
8
|
+
autoload :BibleHtmlFormatter, "cskit/formatters/bible/bible_html_formatter"
|
9
|
+
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Formatters
|
5
|
+
module ScienceHealth
|
6
|
+
class ScienceHealthHtmlFormatter < ScienceHealthPlainTextFormatter
|
7
|
+
|
8
|
+
# _word_
|
9
|
+
ITALICS_REGEX = /_([a-zA-Z0-9\-\.,\"\'\?]+)_/
|
10
|
+
|
11
|
+
protected
|
12
|
+
|
13
|
+
def format_lines(lines, citation_line)
|
14
|
+
detect_italics(super)
|
15
|
+
end
|
16
|
+
|
17
|
+
def detect_italics(lines)
|
18
|
+
lines.map do |line|
|
19
|
+
line.gsub(ITALICS_REGEX) do |match|
|
20
|
+
"<em>#{$1}</em>"
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
def separator
|
26
|
+
options[:separator] || "<br />"
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,73 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Formatters
|
5
|
+
module ScienceHealth
|
6
|
+
class ScienceHealthPlainTextFormatter < CSKit::Formatters::Formatter
|
7
|
+
|
8
|
+
# semicolon, question mark, or period
|
9
|
+
SENTENCE_TERMINATOR_REGEX = /[;\?\.]/
|
10
|
+
|
11
|
+
# either a period + space, quotes, or start of line followed by the first capital letter or number.
|
12
|
+
SENTENCE_START_REGEX = /(\.\s+|\.\"\s+|\.\'\s+|^)[A-Z0-9\"\']/
|
13
|
+
|
14
|
+
def format_readings(readings)
|
15
|
+
join(
|
16
|
+
readings.map do |reading|
|
17
|
+
format_lines(reading.texts, reading.citation)
|
18
|
+
end
|
19
|
+
)
|
20
|
+
end
|
21
|
+
|
22
|
+
def join(texts)
|
23
|
+
texts.join(separator)
|
24
|
+
end
|
25
|
+
|
26
|
+
protected
|
27
|
+
|
28
|
+
def format_lines(lines, citation_line)
|
29
|
+
lines.each_with_index.map do |line, line_index|
|
30
|
+
line_text = line.text
|
31
|
+
|
32
|
+
line_text = if line_index == 0
|
33
|
+
if citation_line.start_fragment
|
34
|
+
index = line_text.index(citation_line.start_fragment)
|
35
|
+
index ? line_text[index..-1] : line_text
|
36
|
+
else
|
37
|
+
matches = line_text.match(SENTENCE_START_REGEX)
|
38
|
+
if matches && matches.length == 2
|
39
|
+
offset = matches.offset(1)
|
40
|
+
spaces = " " * offset.first # indent to match physical position in S&H book
|
41
|
+
spaces + line_text[matches.offset(1).last..-1]
|
42
|
+
else
|
43
|
+
line_text
|
44
|
+
end
|
45
|
+
end
|
46
|
+
else
|
47
|
+
line_text
|
48
|
+
end
|
49
|
+
|
50
|
+
line_text = if line_index == (lines.size - 1)
|
51
|
+
index = line_text.index(SENTENCE_TERMINATOR_REGEX)
|
52
|
+
index ? line_text[0..index] : line_text
|
53
|
+
else
|
54
|
+
line_text
|
55
|
+
end
|
56
|
+
|
57
|
+
# indent start of paragraph
|
58
|
+
if line.paragraph_start?
|
59
|
+
" #{line_text}"
|
60
|
+
else
|
61
|
+
line_text
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
def separator
|
67
|
+
options[:separator] || "\n"
|
68
|
+
end
|
69
|
+
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Formatters
|
5
|
+
module ScienceHealth
|
6
|
+
|
7
|
+
autoload :ScienceHealthPlainTextFormatter, "cskit/formatters/science_health/science_health_plain_text_formatter"
|
8
|
+
autoload :ScienceHealthHtmlFormatter, "cskit/formatters/science_health/science_health_html_formatter"
|
9
|
+
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Formatters
|
5
|
+
|
6
|
+
autoload :Bible, "cskit/formatters/bible"
|
7
|
+
autoload :ScienceHealth, "cskit/formatters/science_health"
|
8
|
+
|
9
|
+
|
10
|
+
class Formatter
|
11
|
+
attr_reader :options
|
12
|
+
|
13
|
+
def initialize(options = {})
|
14
|
+
@options = options
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
require 'json'
|
4
|
+
|
5
|
+
module CSKit
|
6
|
+
module Lesson
|
7
|
+
class Lesson
|
8
|
+
|
9
|
+
attr_reader :sections
|
10
|
+
|
11
|
+
class << self
|
12
|
+
def from_file(file)
|
13
|
+
ext = File.extname(file)[1..-1]
|
14
|
+
send(:"from_#{ext}", File.read(file))
|
15
|
+
end
|
16
|
+
|
17
|
+
def from_json(data)
|
18
|
+
sections = JSON.parse(data).map do |section_data|
|
19
|
+
Section.new(
|
20
|
+
section_data["section"],
|
21
|
+
section_data["readings"].inject({}) do |ret, (k, v)|
|
22
|
+
ret[k.to_sym] = v; ret
|
23
|
+
end
|
24
|
+
)
|
25
|
+
end
|
26
|
+
|
27
|
+
new(sections)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
def initialize(sections)
|
32
|
+
@sections = sections
|
33
|
+
end
|
34
|
+
|
35
|
+
def each_reading(volumes)
|
36
|
+
sections.each do |section|
|
37
|
+
volumes.each do |volume|
|
38
|
+
section.each_reading_group_for(volume) do |readings, citation|
|
39
|
+
yield section, citation, volume, readings
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
def each_formatted_reading(formatters)
|
46
|
+
each_reading(formatters.keys) do |section, citation, volume, readings|
|
47
|
+
formatter = formatters[volume]
|
48
|
+
yield section, citation, volume, formatter.format_readings(readings)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def each_formatted_section(formatters)
|
53
|
+
last_section = nil
|
54
|
+
current_texts = nil
|
55
|
+
|
56
|
+
each_formatted_reading(formatters) do |section, citation, volume, text|
|
57
|
+
if section.name != (last_section.name rescue nil)
|
58
|
+
yield section, current_texts if current_texts
|
59
|
+
current_texts = {}
|
60
|
+
end
|
61
|
+
|
62
|
+
last_section = section
|
63
|
+
formatter = formatters[volume]
|
64
|
+
current_texts[volume] = formatter.join([current_texts[volume], text])
|
65
|
+
end
|
66
|
+
|
67
|
+
yield last_section, current_texts if current_texts
|
68
|
+
end
|
69
|
+
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
|
3
|
+
module CSKit
|
4
|
+
module Lesson
|
5
|
+
class Section
|
6
|
+
|
7
|
+
attr_reader :name, :citation_texts
|
8
|
+
|
9
|
+
def initialize(name, citation_texts)
|
10
|
+
@name = name
|
11
|
+
@citation_texts = citation_texts
|
12
|
+
end
|
13
|
+
|
14
|
+
def each_reading_group_for(volume_name)
|
15
|
+
volume_name = volume_name.to_sym
|
16
|
+
volume = CSKit.get_volume(volume_name)
|
17
|
+
|
18
|
+
(citation_texts[volume_name] || []).each do |citation_text|
|
19
|
+
citation = volume.parse_citation(citation_text)
|
20
|
+
yield volume.readings_for(citation), citation
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|