Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
122e88a8
Commit
122e88a8
authored
Aug 30, 2017
by
Eric Appelt
Committed by
Éric Araujo
Aug 30, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-30096: Use ABC in abc reference examples (#1220)
Use base class rather than metaclass in examples.
parent
384899df
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
39 additions
and
24 deletions
+39
-24
Doc/library/abc.rst
Doc/library/abc.rst
+39
-24
No files found.
Doc/library/abc.rst
View file @
122e88a8
...
@@ -24,7 +24,33 @@ a class or instance provides a particular interface, for example, is it
...
@@ -24,7 +24,33 @@ a class or instance provides a particular interface, for example, is it
hashable or a mapping.
hashable or a mapping.
This module provides the following classes:
This module provides the metaclass :class:`ABCMeta` for defining ABCs and
a helper class :class:`ABC` to alternatively define ABCs through inheritance:
.. class:: ABC
A helper class that has :class:`ABCMeta` as its metaclass. With this class,
an abstract base class can be created by simply deriving from :class:`ABC`
avoiding sometimes confusing metaclass usage, for example::
from abc import ABC
class MyABC(ABC):
pass
Note that the type of :class:`ABC` is still :class:`ABCMeta`, therefore
inheriting from :class:`ABC` requires the usual precautions regarding
metaclass usage, as multiple inheritance may lead to metaclass conflicts.
One may also define an abstract base class by passing the metaclass
keyword and using :class:`ABCMeta` directly, for example::
from abc import ABCMeta
class MyABC(metaclass=ABCMeta):
pass
.. versionadded:: 3.4
.. class:: ABCMeta
.. class:: ABCMeta
...
@@ -46,15 +72,15 @@ This module provides the following classes:
...
@@ -46,15 +72,15 @@ This module provides the following classes:
Register *subclass* as a "virtual subclass" of this ABC. For
Register *subclass* as a "virtual subclass" of this ABC. For
example::
example::
from abc import ABCMeta
from abc import ABC
class MyABC(metaclass=ABCMeta
):
class MyABC(ABC
):
pass
pass
MyABC.register(tuple)
MyABC.register(tuple)
assert issubclass(tuple, MyABC)
assert issubclass(tuple, MyABC)
assert isinstance((), MyABC)
assert isinstance((), MyABC)
.. versionchanged:: 3.3
.. versionchanged:: 3.3
Returns the registered subclass, to allow usage as a class decorator.
Returns the registered subclass, to allow usage as a class decorator.
...
@@ -95,7 +121,7 @@ This module provides the following classes:
...
@@ -95,7 +121,7 @@ This module provides the following classes:
def get_iterator(self):
def get_iterator(self):
return iter(self)
return iter(self)
class MyIterable(
metaclass=ABCMeta
):
class MyIterable(
ABC
):
@abstractmethod
@abstractmethod
def __iter__(self):
def __iter__(self):
...
@@ -132,17 +158,6 @@ This module provides the following classes:
...
@@ -132,17 +158,6 @@ This module provides the following classes:
available as a method of ``Foo``, so it is provided separately.
available as a method of ``Foo``, so it is provided separately.
.. class:: ABC
A helper class that has :class:`ABCMeta` as its metaclass. With this class,
an abstract base class can be created by simply deriving from :class:`ABC`,
avoiding sometimes confusing metaclass usage.
Note that the type of :class:`ABC` is still :class:`ABCMeta`, therefore
inheriting from :class:`ABC` requires the usual precautions regarding metaclass
usage, as multiple inheritance may lead to metaclass conflicts.
.. versionadded:: 3.4
The :mod:`abc` module also provides the following decorators:
The :mod:`abc` module also provides the following decorators:
...
@@ -168,7 +183,7 @@ The :mod:`abc` module also provides the following decorators:
...
@@ -168,7 +183,7 @@ The :mod:`abc` module also provides the following decorators:
descriptors, it should be applied as the innermost decorator, as shown in
descriptors, it should be applied as the innermost decorator, as shown in
the following usage examples::
the following usage examples::
class C(
metaclass=ABCMeta
):
class C(
ABC
):
@abstractmethod
@abstractmethod
def my_abstract_method(self, ...):
def my_abstract_method(self, ...):
...
...
...
@@ -230,7 +245,7 @@ The :mod:`abc` module also provides the following decorators:
...
@@ -230,7 +245,7 @@ The :mod:`abc` module also provides the following decorators:
is now correctly identified as abstract when applied to an abstract
is now correctly identified as abstract when applied to an abstract
method::
method::
class C(
metaclass=ABCMeta
):
class C(
ABC
):
@classmethod
@classmethod
@abstractmethod
@abstractmethod
def my_abstract_classmethod(cls, ...):
def my_abstract_classmethod(cls, ...):
...
@@ -251,7 +266,7 @@ The :mod:`abc` module also provides the following decorators:
...
@@ -251,7 +266,7 @@ The :mod:`abc` module also provides the following decorators:
is now correctly identified as abstract when applied to an abstract
is now correctly identified as abstract when applied to an abstract
method::
method::
class C(
metaclass=ABCMeta
):
class C(
ABC
):
@staticmethod
@staticmethod
@abstractmethod
@abstractmethod
def my_abstract_staticmethod(...):
def my_abstract_staticmethod(...):
...
@@ -278,7 +293,7 @@ The :mod:`abc` module also provides the following decorators:
...
@@ -278,7 +293,7 @@ The :mod:`abc` module also provides the following decorators:
is now correctly identified as abstract when applied to an abstract
is now correctly identified as abstract when applied to an abstract
method::
method::
class C(
metaclass=ABCMeta
):
class C(
ABC
):
@property
@property
@abstractmethod
@abstractmethod
def my_abstract_property(self):
def my_abstract_property(self):
...
@@ -288,7 +303,7 @@ The :mod:`abc` module also provides the following decorators:
...
@@ -288,7 +303,7 @@ The :mod:`abc` module also provides the following decorators:
read-write abstract property by appropriately marking one or more of the
read-write abstract property by appropriately marking one or more of the
underlying methods as abstract::
underlying methods as abstract::
class C(
metaclass=ABCMeta
):
class C(
ABC
):
@property
@property
def x(self):
def x(self):
...
...
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment