summaryrefslogtreecommitdiff
path: root/README.md
blob: d77f1a7697f7ab1e4a8389c20422624b17af2e88 (plain)
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
OSiKa
=====

Narzędzie oceny siły rąk brydżowych w oparciu o algorytmy licytacji naturalnej Łukasza Sławińskiego

Wymagania systemowe
-------------------

Wersja konsolowa:
 * interpreter PHP 5.3+[1] z modułem JSON

[1]: z wyjątkiem testów jednostkowych z katalogu [/tests/](tests) - kompletnie niepotrzebnych użytkownikowi końcowemu - te wymagają PHP 5.4+

Wersja interaktywna (WWW), dodatkowo:
 * eee... serwer WWW?
 * biblioteki JavaScript:
   + [jQuery](http://jquery.com)
   + [jQuery-hashchange](http://benalman.com/projects/jquery-hashchange-plugin/)
   + [Mustache](https://github.com/janl/mustache.js/)
 
Instalacja
----------

Wersja konsolowa:
Wystarczające jest ściągnięcie paczki z głównego katalogu repozytorium albo ręczne ściągnięcie całości katalogu [/bin/](bin/) z repozytorium.

Wersja interaktywna:
Po ściągnięciu z repozytorium katalogów [/web/](web/) oraz [/bin/](bin/), należy:
 * umieścić zawartość katalogu [/web/](web/) w miejscu dostępnym dla serwera WWW
 * w podkatalogu /web/lib/ umieścić wymagane biblioteki JavaScript (niedostarczane z aplikacją)
 * jeśli potrzeba, w pliku /web/index.html edytować ścieżki do bibliotek JavaScript
 * w pliku [/web/osika.php](web/osika.php) edytować linię rozpoczynającą się od `require_once` tak, aby wskazywała na odpowiedni plik katalogu [/bin/lib/](bin/lib/)
 
Użycie
------

Wersja konsolowa:
W katalogu instalacji wydać polecenie:
```
php osika [OPCJE] REKA
```
Dodatkowo, w systemach uniksowych, po nadaniu praw do wykonywania dla pliku [/bin/osika](bin/osika/), możliwe jest bezpośrednie wywołanie:
```
./osika [OPCJE] REKA
```

REKA
Dane wejściowe - zawartość ręki. Wszystkie 13 kart w formacie przecinkowym, tj. xxx,xxx,xxxx,xxx. Dodatkowo:
 * ignorowane są białe znaki.
 * wielkość liter nie ma znaczenia
 * ręka musi zawierać 13 kart
 * x oznacza dowolną blotkę (ale cyfry również dozwolone)
 * Dama = Q/D, Walet = J/W, 10 = 10/T
 * w pojedynczym kolorze nie mogą duplikować się honory ani 9
 * kolejność kart w kolorze nie ma znaczenia
 * blotki nie są weryfikowane (kolor może posiadać zduplikowane blotki, może też posiadać niemożliwą liczbę blotek, np. 10)

OPCJE
-h, --help: wyświetlają instrukcję obsługi
-f FORMAT, --format FORMAT: format wyników programu; dostępne wartości: raw, table, json; wartość domyślna: table
-s KOLORY, --suits KOLORY: lista kolorów, dla których podawane są wyniki (rozdzielona przecinkami); dostępne wartości: s, h, d, c, total, all; wartość domyślna: all
-c KATEGORIE, --categories KATEGORIE: lista składników analizy siły ręki (rozdzielona przecinkami); dostępne wartości wymienione są w pomocy programu (`php osika -h`); wartość domyślna: all

Wersja interaktywna:
Się wpisuje, się klika i się wyświetla.

Podziękowania i autorstwo
-------------------------

Autorem algorytmów licytacji naturalnej (w tym algorytmu oceny siły karty OSiKa) jest Łukasz Sławiński (Pikier).

Program powstał z pomysłu i przy aktywnym współudziale użytkowników [forumbridge.pl](http://www.forumbridge.pl), w szczególności:
 * Tomasza Radko (TRad)
 * Marka Walczaka (walec)

Autorem kodu źródłowego jest Michał Klichowicz (mkl).

Licencja
--------

Program udostępniany jest na licencji GPL wersji 2.
Szczegóły licencji znajdują się w pliku [LICENSE](LICENSE)

***
`She said, do me a favour, and stop flattering yourself.`