daigaku 0.3.0 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.travis.yml +2 -3
- data/README.md +1 -1
- data/daigaku.gemspec +23 -26
- data/lib/daigaku.rb +0 -1
- data/lib/daigaku/chapter.rb +3 -4
- data/lib/daigaku/coloring.rb +13 -13
- data/lib/daigaku/configuration.rb +25 -28
- data/lib/daigaku/congratulator.rb +17 -5
- data/lib/daigaku/course.rb +9 -8
- data/lib/daigaku/exceptions.rb +0 -2
- data/lib/daigaku/generator.rb +13 -13
- data/lib/daigaku/github_client.rb +4 -4
- data/lib/daigaku/loadable.rb +11 -15
- data/lib/daigaku/loading/chapters.rb +0 -2
- data/lib/daigaku/loading/courses.rb +0 -2
- data/lib/daigaku/loading/units.rb +0 -2
- data/lib/daigaku/markdown.rb +1 -0
- data/lib/daigaku/markdown/printer.rb +89 -0
- data/lib/daigaku/markdown/ruby_doc.rb +6 -8
- data/lib/daigaku/solution.rb +18 -15
- data/lib/daigaku/storeable.rb +11 -12
- data/lib/daigaku/task.rb +1 -1
- data/lib/daigaku/terminal.rb +3 -4
- data/lib/daigaku/terminal/cli.rb +6 -8
- data/lib/daigaku/terminal/courses.rb +19 -16
- data/lib/daigaku/terminal/output.rb +0 -2
- data/lib/daigaku/terminal/setup.rb +13 -18
- data/lib/daigaku/terminal/solutions.rb +27 -32
- data/lib/daigaku/terminal/welcome.rb +9 -11
- data/lib/daigaku/test.rb +7 -10
- data/lib/daigaku/test_result.rb +13 -16
- data/lib/daigaku/unit.rb +1 -3
- data/lib/daigaku/version.rb +1 -1
- data/lib/daigaku/views.rb +4 -3
- data/lib/daigaku/views/chapters_menu.rb +16 -20
- data/lib/daigaku/views/courses_menu.rb +12 -15
- data/lib/daigaku/views/main_menu.rb +23 -23
- data/lib/daigaku/views/menu.rb +9 -13
- data/lib/daigaku/views/splash.rb +11 -13
- data/lib/daigaku/views/subscriber.rb +38 -0
- data/lib/daigaku/views/task_view.rb +80 -78
- data/lib/daigaku/views/top_bar.rb +4 -10
- data/lib/daigaku/views/units_menu.rb +16 -21
- data/lib/daigaku/window.rb +12 -70
- data/spec/daigaku/chapter_spec.rb +23 -18
- data/spec/daigaku/coloring_spec.rb +0 -1
- data/spec/daigaku/configuration_spec.rb +54 -50
- data/spec/daigaku/congratulator_spec.rb +11 -8
- data/spec/daigaku/course_spec.rb +70 -51
- data/spec/daigaku/generator_spec.rb +24 -25
- data/spec/daigaku/github_client_spec.rb +17 -18
- data/spec/daigaku/loading/chapters_spec.rb +2 -3
- data/spec/daigaku/loading/courses_spec.rb +2 -3
- data/spec/daigaku/loading/units_spec.rb +4 -5
- data/spec/daigaku/markdown/ruby_doc_spec.rb +3 -6
- data/spec/daigaku/reference_solution_spec.rb +8 -10
- data/spec/daigaku/solution_spec.rb +18 -20
- data/spec/daigaku/storeable_spec.rb +12 -10
- data/spec/daigaku/task_spec.rb +3 -4
- data/spec/daigaku/terminal/cli_spec.rb +29 -21
- data/spec/daigaku/terminal/courses_spec.rb +104 -99
- data/spec/daigaku/terminal/output_spec.rb +44 -39
- data/spec/daigaku/terminal/setup_spec.rb +1 -3
- data/spec/daigaku/terminal/solutions_spec.rb +0 -2
- data/spec/daigaku/terminal/welcome_spec.rb +0 -2
- data/spec/daigaku/terminal_spec.rb +5 -7
- data/spec/daigaku/test_example_spec.rb +16 -14
- data/spec/daigaku/test_result_spec.rb +21 -25
- data/spec/daigaku/test_spec.rb +11 -12
- data/spec/daigaku/unit_spec.rb +24 -27
- data/spec/daigaku/views/chapters_menu_spec.rb +0 -1
- data/spec/daigaku/views/courses_menu_spec.rb +0 -1
- data/spec/daigaku/views/menu_spec.rb +1 -2
- data/spec/daigaku/views/task_view_spec.rb +0 -2
- data/spec/daigaku/views/units_menu_spec.rb +0 -1
- data/spec/daigaku/views_spec.rb +0 -1
- data/spec/daigaku_spec.rb +9 -12
- data/spec/path_helpers_spec.rb +11 -12
- data/spec/resource_helpers_spec.rb +11 -12
- data/spec/spec_helper.rb +3 -4
- data/spec/support/macros/content_helpers.rb +16 -17
- data/spec/support/macros/mock_helpers.rb +6 -6
- data/spec/support/macros/path_helpers.rb +15 -15
- data/spec/support/macros/resource_helpers.rb +34 -35
- metadata +12 -10
@@ -1,16 +1,16 @@
|
|
1
1
|
module PathHelpers
|
2
|
-
LOCAL_DIR
|
3
|
-
CONFIGURATION_FILE
|
4
|
-
COURSES
|
5
|
-
SOLUTIONS
|
6
|
-
TEMP_PATH
|
7
|
-
COURSE_DIR_NAMES
|
8
|
-
CHAPTER_DIR_NAMES
|
9
|
-
UNIT_DIR_NAMES
|
10
|
-
TASK_NAME
|
11
|
-
REFERENCE_SOLUTION_NAME = 'solution.rb'
|
12
|
-
TEST_NAME
|
13
|
-
STORAGE_FILE
|
2
|
+
LOCAL_DIR = '.daigaku'.freeze
|
3
|
+
CONFIGURATION_FILE = 'daigaku.settings'.freeze
|
4
|
+
COURSES = 'courses'.freeze
|
5
|
+
SOLUTIONS = 'solutions'.freeze
|
6
|
+
TEMP_PATH = File.expand_path('../../../../tmp/', __FILE__).freeze
|
7
|
+
COURSE_DIR_NAMES = %w(Course_A Course_B).freeze
|
8
|
+
CHAPTER_DIR_NAMES = %w(1_Chapter-A 2_Chapter-B).freeze
|
9
|
+
UNIT_DIR_NAMES = %w(1_unit-a 2_unit-b).freeze
|
10
|
+
TASK_NAME = 'task.md'.freeze
|
11
|
+
REFERENCE_SOLUTION_NAME = 'solution.rb'.freeze
|
12
|
+
TEST_NAME = 'solution_spec.rb'.freeze
|
13
|
+
STORAGE_FILE = 'daigaku.db.yml'.freeze
|
14
14
|
|
15
15
|
def temp_basepath
|
16
16
|
TEMP_PATH
|
@@ -86,17 +86,17 @@ module PathHelpers
|
|
86
86
|
|
87
87
|
def all_solution_file_paths
|
88
88
|
all_unit_dirs.map do |unit_dir|
|
89
|
-
underscored_unit_dir =
|
89
|
+
underscored_unit_dir = File.basename(unit_dir).gsub(/[\_\-\.]+/, '_')
|
90
90
|
file_name = underscored_unit_dir + Daigaku::Solution::FILE_SUFFIX
|
91
91
|
|
92
92
|
unit_path = File.join(solutions_basepath, unit_dir.split('/')[-3..-1])
|
93
|
-
parts
|
93
|
+
parts = File.join(File.dirname(unit_path), file_name).split('/')
|
94
94
|
|
95
95
|
course_parts = parts[-3..-1].map do |part|
|
96
96
|
part.gsub(/^[\d]+\_/, '').gsub(/[\_\-]+/, '_').downcase
|
97
97
|
end
|
98
98
|
|
99
|
-
|
99
|
+
(parts[0...-3] + course_parts).join('/')
|
100
100
|
end
|
101
101
|
end
|
102
102
|
|
@@ -1,12 +1,12 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
require 'zip'
|
1
|
+
require 'fileutils'
|
2
|
+
require 'zip'
|
4
3
|
|
4
|
+
module ResourceHelpers
|
5
5
|
def prepare_courses
|
6
|
-
|
6
|
+
create_directory(courses_basepath)
|
7
7
|
|
8
8
|
course_dir_names.each do |course|
|
9
|
-
chapter_dir_names.each do |
|
9
|
+
chapter_dir_names.each do |_|
|
10
10
|
unit_dirs(course).each do |units|
|
11
11
|
units.each do |unit|
|
12
12
|
create_directory(unit)
|
@@ -29,23 +29,19 @@ module ResourceHelpers
|
|
29
29
|
def prepare_solutions
|
30
30
|
all_solution_file_paths.each do |path|
|
31
31
|
base_dir = File.dirname(path)
|
32
|
-
name
|
32
|
+
name = File.basename(path)
|
33
33
|
create_file(base_dir, name, solution_content)
|
34
34
|
end
|
35
35
|
end
|
36
36
|
|
37
|
-
def prepare_download(zip_file_name,
|
37
|
+
def prepare_download(zip_file_name, multiple_courses: false)
|
38
38
|
zip_file_path = File.join(courses_basepath, zip_file_name)
|
39
|
-
|
40
|
-
unless Dir.exist?(File.dirname(zip_file_path))
|
41
|
-
FileUtils.makedirs(File.dirname(zip_file_path))
|
42
|
-
end
|
39
|
+
create_directory(File.dirname(zip_file_path))
|
43
40
|
|
44
41
|
Zip::File.open(zip_file_path, Zip::File::CREATE) do |zip_file|
|
45
42
|
Dir[File.join(courses_basepath, '**', '**')].each do |file|
|
46
|
-
|
47
|
-
|
48
|
-
end
|
43
|
+
next unless course_match?(file, multiple_courses)
|
44
|
+
zip_file.add(file.sub(courses_basepath, '')[1..-1], file) { true }
|
49
45
|
end
|
50
46
|
end
|
51
47
|
|
@@ -54,16 +50,12 @@ module ResourceHelpers
|
|
54
50
|
|
55
51
|
def prepare_github_download(zip_file_name)
|
56
52
|
zip_file_path = File.join(courses_basepath, zip_file_name)
|
57
|
-
|
58
|
-
unless Dir.exist?(File.dirname(zip_file_path))
|
59
|
-
FileUtils.makedirs(File.dirname(zip_file_path))
|
60
|
-
end
|
53
|
+
create_directory(File.dirname(zip_file_path))
|
61
54
|
|
62
55
|
Zip::File.open(zip_file_path, Zip::File::CREATE) do |zip_file|
|
63
56
|
Dir[File.join(courses_basepath, '**', '**')].each do |file|
|
64
|
-
|
65
|
-
|
66
|
-
end
|
57
|
+
next unless file =~ /.*\-master/
|
58
|
+
zip_file.add(file.sub(courses_basepath, '')[1..-1], file) { true }
|
67
59
|
end
|
68
60
|
end
|
69
61
|
|
@@ -71,34 +63,41 @@ module ResourceHelpers
|
|
71
63
|
end
|
72
64
|
|
73
65
|
def course_match?(name, multiple_courses)
|
66
|
+
first_course_matches = name.match(course_dirs.first)
|
67
|
+
|
74
68
|
if multiple_courses
|
75
|
-
|
69
|
+
first_course_matches || name.match(course_dirs.second)
|
76
70
|
else
|
77
|
-
|
71
|
+
first_course_matches
|
78
72
|
end
|
79
73
|
end
|
80
74
|
|
81
75
|
def cleanup_download(zip_file_name)
|
82
76
|
directory = course_dirs.first
|
83
|
-
zip_file
|
84
|
-
|
77
|
+
zip_file = File.join(File.dirname(directory), zip_file_name)
|
78
|
+
remove_file(zip_file)
|
85
79
|
end
|
86
80
|
|
87
81
|
def cleanup_temp_data
|
88
|
-
|
82
|
+
remove_directory(temp_basepath)
|
83
|
+
end
|
84
|
+
|
85
|
+
def remove_directory(dir_path)
|
86
|
+
FileUtils.remove_dir(dir_path) if Dir.exist?(dir_path)
|
89
87
|
end
|
90
88
|
|
91
89
|
def create_directory(dir_path)
|
92
|
-
FileUtils.
|
90
|
+
FileUtils.makedirs(dir_path) unless Dir.exist?(dir_path)
|
93
91
|
end
|
94
92
|
|
95
93
|
def create_file(base_dir, name, content)
|
96
|
-
create_directory(base_dir)
|
94
|
+
create_directory(base_dir)
|
97
95
|
file_path = File.join(base_dir, name)
|
96
|
+
File.open(file_path, 'w') { |f| f.puts content }
|
97
|
+
end
|
98
98
|
|
99
|
-
|
100
|
-
|
101
|
-
end
|
99
|
+
def remove_file(file)
|
100
|
+
FileUtils.rm(file) if File.exist?(file)
|
102
101
|
end
|
103
102
|
|
104
103
|
def available_courses
|
@@ -114,8 +113,8 @@ module ResourceHelpers
|
|
114
113
|
end
|
115
114
|
|
116
115
|
def available_units(course_name, chapter_name)
|
117
|
-
units = unit_dirs(course_name).map do |
|
118
|
-
|
116
|
+
units = unit_dirs(course_name).map do |unit_dir|
|
117
|
+
unit_dir.map do |path|
|
119
118
|
next unless path.split('/')[-2] == chapter_name
|
120
119
|
Daigaku::Unit.new(path)
|
121
120
|
end
|
@@ -128,7 +127,7 @@ module ResourceHelpers
|
|
128
127
|
task = unit_dirs(course_name).map do |units|
|
129
128
|
units.map do |path|
|
130
129
|
split = path.split('/')
|
131
|
-
next if
|
130
|
+
next if split[-2] != chapter_name || split[-1] != unit_name
|
132
131
|
|
133
132
|
Daigaku::Task.new(path)
|
134
133
|
end
|
@@ -141,7 +140,7 @@ module ResourceHelpers
|
|
141
140
|
solution = unit_dirs(course_name).map do |units|
|
142
141
|
units.map do |path|
|
143
142
|
split = path.split('/')
|
144
|
-
next if
|
143
|
+
next if split[-2] != chapter_name || split[-1] != unit_name
|
145
144
|
|
146
145
|
Daigaku::ReferenceSolution.new(path)
|
147
146
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: daigaku
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.4.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Paul Götze
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2016-
|
11
|
+
date: 2016-10-09 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: curses
|
@@ -114,42 +114,42 @@ dependencies:
|
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version:
|
117
|
+
version: 1.6.1
|
118
118
|
type: :runtime
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version:
|
124
|
+
version: 1.6.1
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
126
|
name: quick_store
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|
128
128
|
requirements:
|
129
129
|
- - "~>"
|
130
130
|
- !ruby/object:Gem::Version
|
131
|
-
version: '0.
|
131
|
+
version: '0.2'
|
132
132
|
type: :runtime
|
133
133
|
prerelease: false
|
134
134
|
version_requirements: !ruby/object:Gem::Requirement
|
135
135
|
requirements:
|
136
136
|
- - "~>"
|
137
137
|
- !ruby/object:Gem::Version
|
138
|
-
version: '0.
|
138
|
+
version: '0.2'
|
139
139
|
- !ruby/object:Gem::Dependency
|
140
140
|
name: code_breaker
|
141
141
|
requirement: !ruby/object:Gem::Requirement
|
142
142
|
requirements:
|
143
143
|
- - "~>"
|
144
144
|
- !ruby/object:Gem::Version
|
145
|
-
version: '0.
|
145
|
+
version: '0.3'
|
146
146
|
type: :runtime
|
147
147
|
prerelease: false
|
148
148
|
version_requirements: !ruby/object:Gem::Requirement
|
149
149
|
requirements:
|
150
150
|
- - "~>"
|
151
151
|
- !ruby/object:Gem::Version
|
152
|
-
version: '0.
|
152
|
+
version: '0.3'
|
153
153
|
- !ruby/object:Gem::Dependency
|
154
154
|
name: bundler
|
155
155
|
requirement: !ruby/object:Gem::Requirement
|
@@ -237,6 +237,7 @@ files:
|
|
237
237
|
- lib/daigaku/loading/courses.rb
|
238
238
|
- lib/daigaku/loading/units.rb
|
239
239
|
- lib/daigaku/markdown.rb
|
240
|
+
- lib/daigaku/markdown/printer.rb
|
240
241
|
- lib/daigaku/markdown/ruby_doc.rb
|
241
242
|
- lib/daigaku/reference_solution.rb
|
242
243
|
- lib/daigaku/solution.rb
|
@@ -264,6 +265,7 @@ files:
|
|
264
265
|
- lib/daigaku/views/main_menu.rb
|
265
266
|
- lib/daigaku/views/menu.rb
|
266
267
|
- lib/daigaku/views/splash.rb
|
268
|
+
- lib/daigaku/views/subscriber.rb
|
267
269
|
- lib/daigaku/views/task_view.rb
|
268
270
|
- lib/daigaku/views/top_bar.rb
|
269
271
|
- lib/daigaku/views/units_menu.rb
|
@@ -319,9 +321,9 @@ require_paths:
|
|
319
321
|
- lib
|
320
322
|
required_ruby_version: !ruby/object:Gem::Requirement
|
321
323
|
requirements:
|
322
|
-
- - "
|
324
|
+
- - ">="
|
323
325
|
- !ruby/object:Gem::Version
|
324
|
-
version:
|
326
|
+
version: 2.2.5
|
325
327
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
326
328
|
requirements:
|
327
329
|
- - ">="
|