-
Notifications
You must be signed in to change notification settings - Fork 0
/
read.rb
93 lines (75 loc) · 4.25 KB
/
read.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
# encoding: utf-8
#
# Подключаем класс Post и его детей: Memo, Link, Task
require_relative 'lib/post'
require_relative 'lib/memo'
require_relative 'lib/link'
require_relative 'lib/task'
# Будем обрабатывать параметры командной строки с помощью
# специальной библиотеки optparse
require 'optparse'
# Все наши опции будут записаны сюда
options = {}
# Заведем нужные нам опции
OptionParser.new do |opt|
# Этот текст будет выводиться, когда программа запущена с опцией -h
opt.banner = 'Usage: read.rb [options]'
# Вывод в случае, если запросили help
opt.on('-h', 'Prints this help') do
puts opt
exit
end
# Опция --type будет передавать тип поста, который мы хотим считать
opt.on('--type POST_TYPE', 'какой тип постов показывать ' \
'(по умолчанию любой)') { |o| options[:type] = o }
# Опция --id передает номер записи в базе данных (идентификатор)
opt.on('--id POST_ID', 'если задан id — показываем подробно ' \
' только этот пост') { |o| options[:id] = o }
# Опция --limit передает, сколько записей мы хотим прочитать из базы
opt.on('--limit NUMBER', 'сколько последних постов показать ' \
'(по умолчанию все)') { |o| options[:limit] = o }
# В конце у только что созданного объекта класс OptionParser вызываем
# метод parse, чтобы он заполнил наш хэш options в соответствии с правилами.
end.parse!
# Вызываем метод find класса Post, который найдет нам нужные записи в
# соответствии с запросом. Записываем то, что он вернет в переменную result.
result = if options[:id].nil?
# Если id не передали, ищем все записи по параметрам
Post.find_all(options[:limit], options[:type])
else
# Если передали — забиваем на остальные параметры и ищем по id
Post.find_by_id(options[:id])
end
if result.is_a? Post
# Если результат — это один объект класса Post, значит выводим его
puts "Запись #{result.class.name}, id = #{options[:id]}"
# Получим строки для поста с помощью метода to_string и выведем их на экран
result.to_strings.each { |line| puts line }
else
# Если результат — это не один пост, а сразу несколько, показываем таблицу
# Сначала — напечатаем шапку таблицы с названиями полей
print '| id '
print '| @type '
print '| @created_at '
print '| @text '
print '| @url '
print '| @due_date '
print '|'
# Теперь для каждой строки из результатов выведем её в нужном формате
result.each do |row|
# Начинаем с пустой строки
puts
# Для каждого элемента строки выводим его в нужном формате.
row.each do |element|
# С палкой перед ним и обрезая первые 40 символов для очень длинных строк.
# Также удаляем символы переноса.
element_text = "| #{element.to_s.delete("\\n\\r")[0..17]}"
# Если текст элемента короткий, добавляем нужное количество пробелов
element_text << ' ' * (21 - element_text.size)
# Выводим текст элемента
print element_text
end
print '|'
end
puts
end