Compare commits
No commits in common. "efe128fd596d1b64a77c24858572f16872f326d0" and "acada2851dada8483344e4557714d5bebd759a58" have entirely different histories.
efe128fd59
...
acada2851d
|
@ -67,44 +67,7 @@
|
||||||
|
|
||||||
## Функціональність
|
## Функціональність
|
||||||
|
|
||||||
Наша система спрямована, в першу чергу, на взаємодію з користувачами.
|
*[Functionality (функциональні вимоги)]*
|
||||||
|
|
||||||
***Користувач** - це особа, що взаємодіє із системою.*
|
|
||||||
|
|
||||||
Cистема розділяє користувачів на дві категорії:
|
|
||||||
- гість
|
|
||||||
- авторизований користувач
|
|
||||||
|
|
||||||
***Гість** - це користувач, що не пройшов ідентифікацію в системі. Такого користувача не можна зіставити з жодним обліковим записом.*
|
|
||||||
|
|
||||||
Гість може:
|
|
||||||
- створити обліковий запис
|
|
||||||
- пройти ідентифікацію в системі
|
|
||||||
- пройти анонімне опитування
|
|
||||||
|
|
||||||
***Зареєстрований користувач** - це користувач, котрий успішно пройшов ідентифікацію в системі. Такого користувача можна однозначно зіставити з обліковим записом, що наявний у системі.*
|
|
||||||
|
|
||||||
Зареєстрований користувач може:
|
|
||||||
- редагувати властивості свого облікового запису
|
|
||||||
- видалити свій обліковий запис
|
|
||||||
- скинути дані про ідентицікацію в системі
|
|
||||||
- створити опитування
|
|
||||||
- відредагувати своє опитування
|
|
||||||
- видалити своє опитування
|
|
||||||
- призупинити своє опитування
|
|
||||||
- продовжити своє опитування
|
|
||||||
- переглянути властивості свого опитування
|
|
||||||
- переглянути результати свого опитування
|
|
||||||
- пройти анонімне опитування
|
|
||||||
- пройти поіменне опитування
|
|
||||||
|
|
||||||
*[Респондент](https://slovnyk.ua/index.php?swrd=%D1%80%D0%B5%D1%81%D0%BF%D0%BE%D0%BD%D0%B4%D0%B5%D0%BD%D1%82) - той, хто відповідає на питання анкети; опитуваний.*
|
|
||||||
|
|
||||||
***Опитування** - це перелік запитань, кожне з яких передбачає обов'язкову або необов'язкову відповідь. Кожна відповідь має визначений тип.*
|
|
||||||
|
|
||||||
***Анонімне опитування** - це опитування, відповідь на яке може не містити інформації про обліковий запис респондента (*респондент все одно може вирішити надати таку інформацію).*
|
|
||||||
|
|
||||||
***Поіменне опитування** - це опитування, відповідь на яке обов'язково містить дані про обліковий запис респондента.*
|
|
||||||
|
|
||||||
## Практичність
|
## Практичність
|
||||||
|
|
||||||
|
|
|
@ -1,160 +0,0 @@
|
||||||
#!/bin/python3
|
|
||||||
|
|
||||||
import sys
|
|
||||||
|
|
||||||
# magic values
|
|
||||||
NO = 0
|
|
||||||
AUTO = 1
|
|
||||||
YES = 2
|
|
||||||
|
|
||||||
def convert_generic_v1(data):
|
|
||||||
split_raw_lines = [i.strip().split("|") for i in data.split("\n") if i]
|
|
||||||
|
|
||||||
return generate_table(split_raw_lines)
|
|
||||||
|
|
||||||
def convert_usecase_v1(filename, data):
|
|
||||||
split_raw_lines_from_file = [i.split(" | ") for i in data.split("\n") if i]
|
|
||||||
|
|
||||||
if '/' in filename:
|
|
||||||
use_case_name = filename.rsplit("/", 1)[1].upper()
|
|
||||||
elif '\\' in filename:
|
|
||||||
use_case_name = filename.rsplit("\\", 1)[1].upper()
|
|
||||||
else:
|
|
||||||
use_case_name = filename.upper()
|
|
||||||
|
|
||||||
split_raw_lines = [["ID", use_case_name]] + split_raw_lines_from_file
|
|
||||||
|
|
||||||
merged_lines = []
|
|
||||||
for i in split_raw_lines:
|
|
||||||
if i[0] == "":
|
|
||||||
merged_lines[-1][1] += "<br>" + i[1]
|
|
||||||
else:
|
|
||||||
merged_lines.append(i)
|
|
||||||
|
|
||||||
return generate_table(merged_lines)
|
|
||||||
|
|
||||||
def generate_table(raw_table_data):
|
|
||||||
table_lines = raw_table_data
|
|
||||||
transposed_table = list(zip(*table_lines))
|
|
||||||
|
|
||||||
field_sizes = [max([max([len(k)+2 for k in j.split("\n")]) for j in i]) for i in transposed_table]
|
|
||||||
|
|
||||||
formatted_table_lines = []
|
|
||||||
|
|
||||||
l = "|"
|
|
||||||
for i, field in enumerate(table_lines[0]):
|
|
||||||
l += field.center(field_sizes[i])
|
|
||||||
l += "|"
|
|
||||||
|
|
||||||
formatted_table_lines.append(l)
|
|
||||||
formatted_table_lines.append(f"|{'|'.join([':'+'-'*(i-2)+':' for i in field_sizes])}|")
|
|
||||||
|
|
||||||
for line in table_lines[1:]:
|
|
||||||
l = "|"
|
|
||||||
for i, field in enumerate(line):
|
|
||||||
l += field.center(field_sizes[i])
|
|
||||||
l += "|"
|
|
||||||
|
|
||||||
formatted_table_lines.append(l)
|
|
||||||
|
|
||||||
return "\n".join(formatted_table_lines)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__=="__main__":
|
|
||||||
# parse args
|
|
||||||
files = []
|
|
||||||
write_to_file = AUTO
|
|
||||||
write_to_stdout = AUTO
|
|
||||||
usecase_formatting = AUTO
|
|
||||||
verbose = AUTO
|
|
||||||
process_table_files = AUTO
|
|
||||||
|
|
||||||
# 1 pass (argument harvest)
|
|
||||||
for i in sys.argv[1:]:
|
|
||||||
if i.startswith("-"):
|
|
||||||
# записувати таблицю в файл
|
|
||||||
if i in ["-f", "--file"]:
|
|
||||||
write_to_file = YES
|
|
||||||
elif i in ["-nf", "--no-file"]:
|
|
||||||
write_to_file = NO
|
|
||||||
|
|
||||||
# виводити таблицю у стандартний вивід
|
|
||||||
elif i in ["-o", "--stdout"]:
|
|
||||||
write_to_stdout = YES
|
|
||||||
elif i in ["-no", "--no-stdout"]:
|
|
||||||
write_to_stdout = NO
|
|
||||||
|
|
||||||
# форматувати таблицю як use-case
|
|
||||||
elif i in ["-u", "--usecase", "--use-case"]:
|
|
||||||
usecase_formatting = YES
|
|
||||||
elif i in ["-nu", "--no-usecase", "--no-use-case"]:
|
|
||||||
usecase_formatting = NO
|
|
||||||
|
|
||||||
# виводити на екран додаткову інформацію
|
|
||||||
elif i in ["-v", "--verbose"]:
|
|
||||||
verbose = YES
|
|
||||||
elif i in ["-nv", "--no-verbose"]:
|
|
||||||
verbose = NO
|
|
||||||
|
|
||||||
elif i in ["-t", "--process-table"]:
|
|
||||||
process_table_files = YES
|
|
||||||
elif i in ["-nt", "--no-process-table"]:
|
|
||||||
process_table_files = NO
|
|
||||||
|
|
||||||
# 2 pass (filename harvest)
|
|
||||||
for i in sys.argv[1:]:
|
|
||||||
if not i.startswith("-"):
|
|
||||||
if i.endswith(".table") and process_table_files <= AUTO:
|
|
||||||
print(f"[Warning]: Excluding {i} to prevent processing of an already processed file (pass --process-table to override this behaviour)")
|
|
||||||
else:
|
|
||||||
files.append(i)
|
|
||||||
|
|
||||||
if len(files) < 1:
|
|
||||||
print("You need to pass at least one file as CLI argument", file=sys.stderr)
|
|
||||||
print("Exiting...", file=sys.stderr)
|
|
||||||
exit(1)
|
|
||||||
|
|
||||||
if len(files) == 1:
|
|
||||||
name = files[0]
|
|
||||||
data = open(name, encoding = "utf-8").read()
|
|
||||||
|
|
||||||
if usecase_formatting == YES:
|
|
||||||
if verbose == YES:
|
|
||||||
print(f"Force-formatting {name} as a use-case\n")
|
|
||||||
formatted_table_data = convert_usecase_v1(name.rsplit(".", 1)[0], data)
|
|
||||||
elif (name.endswith(".usecase") or name.endswith(".uc")) and usecase_formatting >= AUTO:
|
|
||||||
if verbose == YES:
|
|
||||||
print(f"Auto-detected use-case in file {name}\n")
|
|
||||||
formatted_table_data = convert_usecase_v1(name.rsplit(".", 1)[0], data)
|
|
||||||
else:
|
|
||||||
formatted_table_data = convert_generic_v1(data)
|
|
||||||
|
|
||||||
if write_to_stdout >= AUTO:
|
|
||||||
print(formatted_table_data)
|
|
||||||
|
|
||||||
if write_to_file > AUTO:
|
|
||||||
open(name + ".table", 'w', encoding = "utf-8").write(formatted_table_data+"\n")
|
|
||||||
|
|
||||||
exit(0)
|
|
||||||
|
|
||||||
for no, name in enumerate(files):
|
|
||||||
print(f"Converting {no+1}/{len(files)}")
|
|
||||||
|
|
||||||
data = open(name, encoding = "utf-8").read()
|
|
||||||
|
|
||||||
if usecase_formatting == YES:
|
|
||||||
if verbose >= AUTO:
|
|
||||||
print(f"Force-formatting {name} as a use-case")
|
|
||||||
formatted_table_data = convert_usecase_v1(name.rsplit(".", 1)[0], data)
|
|
||||||
elif (name.endswith(".usecase") or name.endswith(".uc")) and usecase_formatting >= AUTO:
|
|
||||||
if verbose >= AUTO:
|
|
||||||
print(f"Auto-detected use-case in file {name}")
|
|
||||||
formatted_table_data = convert_usecase_v1(name.rsplit(".", 1)[0], data)
|
|
||||||
else:
|
|
||||||
formatted_table_data = convert_generic_v1(data)
|
|
||||||
|
|
||||||
if write_to_stdout > AUTO:
|
|
||||||
print(formatted_table_data)
|
|
||||||
|
|
||||||
if write_to_file >= AUTO:
|
|
||||||
open(name + ".table", 'w', encoding = "utf-8").write(formatted_table_data+"\n")
|
|
Reference in New Issue