You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

53 lines
1.3 KiB

"""
All optional features are available as mixins for :class:`steam.client.SteamClient`.
Using this approach the client can remain light yet flexible.
Functionality can be added through inheritance depending on the use case.
Here is quick example of how to use one of the available mixins.
.. code:: python
from steam import SteamClient
from stema.client.mixins.somemixing import SomeMixing
class CustomSteamClient(SteamClient, SomeMixing):
pass
client = CustomSteamClient()
Making custom mixing is just as simple.
.. warning::
Take care not to override existing methods or properties, otherwise bad things will happen
.. note::
To avoid name collisions of non-public variables and methods, use `Private Variables <https://docs.python.org/2/tutorial/classes.html#private-variables-and-class-local-references>`_
.. code:: python
class MyMixin(object):
def __init__(self, *args, **kwargs):
super(MyMixin, self).__init__(*args, **kwargs)
self.my_property = 42
def my_method(self)
print "Hello!"
class MySteamClient(SteamClient, MyMixin):
pass
client = MySteamClient()
.. code:: python
>>> client.my_property
42
>>> client.my_method()
Hello!
"""