refactor: Move server to subfolder

parent a1c60615
# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class
# C extensions
*.so
# Distribution / packaging
.Python
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
pip-wheel-metadata/
share/python-wheels/
*.egg-info/
.installed.cfg
*.egg
MANIFEST
# PyInstaller
# Usually these files are written by a python script from a template
# before PyInstaller builds the exe, so as to inject date/other infos into it.
*.manifest
*.spec
# Installer logs
pip-log.txt
pip-delete-this-directory.txt
# Unit test / coverage reports
htmlcov/
.tox/
.nox/
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*.cover
*.py,cover
.hypothesis/
.pytest_cache/
cover/
# Translations
*.mo
*.pot
# Django stuff:
*.log
local_settings.py
db.sqlite3
db.sqlite3-journal
# Flask stuff:
instance/
.webassets-cache
# Scrapy stuff:
.scrapy
# Sphinx documentation
docs/_build/
# PyBuilder
.pybuilder/
target/
# Jupyter Notebook
.ipynb_checkpoints
# IPython
profile_default/
ipython_config.py
# pyenv
# For a library or package, you might want to ignore these files since the code is
# intended to run in multiple environments; otherwise, check them in:
# .python-version
# pipenv
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
# However, in case of collaboration, if having platform-specific dependencies or dependencies
# having no cross-platform support, pipenv may install dependencies that don't work, or not
# install all needed dependencies.
#Pipfile.lock
# PEP 582; used by e.g. github.com/David-OConnor/pyflow
__pypackages__/
# Celery stuff
celerybeat-schedule
celerybeat.pid
# SageMath parsed files
*.sage.py
# Environments
.env
.venv
env/
venv/
ENV/
env.bak/
venv.bak/
# Spyder project settings
.spyderproject
.spyproject
# Rope project settings
.ropeproject
# mkdocs documentation
/site
# mypy
.mypy_cache/
.dmypy.json
dmypy.json
# Pyre type checker
.pyre/
# pytype static type analyzer
.pytype/
# Cython debug symbols
cython_debug/
# static files generated from Django application using `collectstatic`
media
static
# IDE # IDE
.idea/ .idea/
# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class
# C extensions
*.so
# Distribution / packaging
.Python
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
pip-wheel-metadata/
share/python-wheels/
*.egg-info/
.installed.cfg
*.egg
MANIFEST
# PyInstaller
# Usually these files are written by a python script from a template
# before PyInstaller builds the exe, so as to inject date/other infos into it.
*.manifest
*.spec
# Installer logs
pip-log.txt
pip-delete-this-directory.txt
# Unit test / coverage reports
htmlcov/
.tox/
.nox/
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*.cover
*.py,cover
.hypothesis/
.pytest_cache/
cover/
# Translations
*.mo
*.pot
# Django stuff:
*.log
local_settings.py
db.sqlite3
db.sqlite3-journal
# Flask stuff:
instance/
.webassets-cache
# Scrapy stuff:
.scrapy
# Sphinx documentation
docs/_build/
# PyBuilder
.pybuilder/
target/
# Jupyter Notebook
.ipynb_checkpoints
# IPython
profile_default/
ipython_config.py
# pyenv
# For a library or package, you might want to ignore these files since the code is
# intended to run in multiple environments; otherwise, check them in:
# .python-version
# pipenv
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
# However, in case of collaboration, if having platform-specific dependencies or dependencies
# having no cross-platform support, pipenv may install dependencies that don't work, or not
# install all needed dependencies.
#Pipfile.lock
# PEP 582; used by e.g. github.com/David-OConnor/pyflow
__pypackages__/
# Celery stuff
celerybeat-schedule
celerybeat.pid
# SageMath parsed files
*.sage.py
# Environments
.env
.venv
env/
venv/
ENV/
env.bak/
venv.bak/
# Spyder project settings
.spyderproject
.spyproject
# Rope project settings
.ropeproject
# mkdocs documentation
/site
# mypy
.mypy_cache/
.dmypy.json
dmypy.json
# Pyre type checker
.pyre/
# pytype static type analyzer
.pytype/
# Cython debug symbols
cython_debug/
# static files generated from Django application using `collectstatic`
media
static
# IDE
../.idea/
...@@ -3,10 +3,10 @@ from collections import defaultdict ...@@ -3,10 +3,10 @@ from collections import defaultdict
from dataclasses import dataclass from dataclasses import dataclass
from typing import List, Dict, Optional from typing import List, Dict, Optional
from model.animals import random_animal_name from server.model.hand import Hand
from model.card import Card from server.model.animals import random_animal_name
from model.deck import Deck from server.model.card import Card
from model.hand import Hand from server.model.deck import Deck
@dataclass @dataclass
...@@ -93,7 +93,7 @@ class Game: ...@@ -93,7 +93,7 @@ class Game:
else: # Next player, announce or menteur else: # Next player, announce or menteur
announce = current_player.announce(current_bet) announce = current_player.announce(current_bet)
if announce.bet: if announce.bet:
while announce.bet.value() < current_bet.value(): # Bad announce! while announce.bet.value() < current_bet.value(): # Bad announce!
print(f"Invalid bet, {announce.bet} < {current_bet}!") print(f"Invalid bet, {announce.bet} < {current_bet}!")
announce = current_player.announce(current_bet) announce = current_player.announce(current_bet)
current_bet = announce.bet current_bet = announce.bet
......
from random import randrange, shuffle from random import randrange, shuffle
from model.card import Card, Value, Color from server.model.card import Card, Value, Color
class Deck: class Deck:
......
from collections import Counter from collections import Counter
from typing import List from typing import List
from model.card import Card from server.model.card import Card
class Hand: class Hand:
......
from model.hand import Hand from server.model.hand import Hand
from model.card import Value, Color, Card from server.model.card import Value, Color, Card
def carre(value) -> Hand: def carre(value) -> Hand:
......
from model.card import Value, Color, Card from server.model.card import Value, Color, Card
from model.hands import pair, single, double_pair, brelan, full, carre from server.model.hands import pair, single, double_pair, brelan, full, carre
ACE_OF_HEARTS = Card(Value.Ace, Color.Hearts) ACE_OF_HEARTS = Card(Value.Ace, Color.Hearts)
ACE_OF_SPADES = Card(Value.Ace, Color.Spades) ACE_OF_SPADES = Card(Value.Ace, Color.Spades)
......
from unittest import TestCase from unittest import TestCase
from model.data import Player from server.model.data import Player
from model.deck import Deck from server.model.deck import Deck
from model.hand import Hand from server.model.hand import Hand
from model.card import Value, Color, Card from server.model.card import Value, Color, Card
from model.hands import full, brelan, pair, single, double_pair, carre from server.model.hands import full, brelan, pair, single, double_pair, carre
from model.known import ACE_OF_HEARTS, PAIR_ACE, SINGLE_ACE, DOUBLE_PAIR_ACE, BRELAN_ACE, FULL_ACE from server.model.known import ACE_OF_HEARTS, PAIR_ACE, SINGLE_ACE, DOUBLE_PAIR_ACE, BRELAN_ACE, FULL_ACE
class TestDeck(TestCase): class TestDeck(TestCase):
......
from unittest import TestCase from unittest import TestCase
from model.data import Game, Player from server.model.data import Game, Player
class TestGame(TestCase): class TestGame(TestCase):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment