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
|
JFR Teamy - play-off
====================
Generator drabinek wizualizacji play-off dla turniejów prowadzonych przy użyciu JFR Teamy.
Przykład wizualizacji: [III liga LD, sezon 2016/17](https://emkael.info/brydz/playoff/).
Wymagania systemowe
-------------------
Dla wersji skompilowanej: jakiś współczesny system rodziny MS Windows.
Dla wersji skryptowej:
* Python 2.x ze standardowym zestawem bibliotek
* MySQL connector dla Pythona
Instalacja
----------
Dla wersji skompilowanej: [ściągnąć](https://emkael.github.io/_files/playoff-teamy/playoff-1.0.0.zip), rozpakować, upewnić się, że [`playoff.js`](playoff.js) jest w katalogu pliku wykonywalnego.
Dla wersji skryptowej: sklonować to repozytorium.
Użycie
------
Niezależnie od wersji, należy wykonać w linii poleceń polecenie:
```
playoff.exe PLIK_USTAWIEŃ_JSON
```
lub
```
python playoff.py PLIK_USTAWIEŃ_JSON
```
`PLIK_USTAWIEŃ_JSON` jest plikiem konfiguracyjnym, dostarczającym wszelkich danych niezbędnych do pracy programu.
Jeśli w wywołaniu nie podano ścieżki do pliku ustawień, program spyta o nią sam.
Jego strukturę opisuje dokument [CONFIG](CONFIG.md).
Znane ograniczenia
------------------
* wszystkie mecze danej fazy muszą lądować na FTP w tej samej ścieżce:
linki generowane są na podstawie URL całej fazy (linki z datami u góry),
prefiksów turniejów oraz numerów rund
* fazy powinny być określone raczej chronologicznie (czytaj: nie
testowano, co się stanie, jeśli określimy np., że w meczu fazy 2 ma zagrać
zwycięzca z fazy 4), ale nie powinno być problemu z "przeskakiwaniem"
faz (czyli awansem zwycięzcy z fazy 1 od razu do fazy 3), przy czym
takiej sytuacji też nie testowano (rysować się powinno, ale ubytki estetyczne są prawie pewne)
* program wymaga działania Webmastera (wyniki czytane są z takiego
miejsca bazy, do którego pisze Webmaster, a z jakichś powodów nie pisze
Admin przy zamykaniu rundy/segmentu), więc nawet w przypadku grania
"off-line" (Kolektor+statyczne po każdym segmencie), może być potrzeba
przejechania segmentu Webmasterem
* przez cały czas trwania play-off pełne nazwy teamów (w bazach i te
określone w JSONie) muszą się zgadzać - teamy są rozróżniane po nich właśnie
* skorzystanie z funkcjonalności umieszczenia drużyny na określonym miejscu klasyfikacji końcowej (przed rozegraniem play-off) wymaga obecności flag teamów
* nie ma możliwości skonfigurowania więcej niż jednego połączenia do MySQL
Autor
-----
Michał Klichowicz (mkl)
Licencja
--------
[Uproszczona licencja BSD](LICENSE)
|