Skip to content

Commit

Permalink
docs: fix links (#122)
Browse files Browse the repository at this point in the history
Signed-off-by: Jan Kowalleck <[email protected]>
  • Loading branch information
jkowalleck authored Jul 6, 2024
1 parent 73ce317 commit aabb5e9
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 20 deletions.
26 changes: 13 additions & 13 deletions docs/customising-structure.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,12 @@ Property Name Mappings
----------------------------------------------------

You can directly control mapping of property names for properties in a Class by adding the decorators
:obj:`serializable.json_name()` or :obj:`serializable.xml_name()`.
:func:`serializable.json_name()` or :func:`serializable.xml_name()`.

For example, you might have a property called **isbn** in your class, but when serialized to JSON it should be called
**isbn_number**.

To implement this mapping, you would alter your class as follows adding the :obj:`serializable.json_name()`
To implement this mapping, you would alter your class as follows adding the :func:`serializable.json_name()`
decorator to the **isbn** property:

.. code-block:: python
Expand All @@ -51,7 +51,7 @@ decorator to the **isbn** property:
Excluding Property from Serialization
----------------------------------------------------

Properties can be ignored during deserialization by including them in the :obj:`serializable.serializable_class()`
Properties can be ignored during deserialization by including them in the :func:`serializable.serializable_class()`
annotation as per the following example.

A typical use case for this might be where a JSON schema is referenced, but this is not part of the constructor for the
Expand Down Expand Up @@ -82,14 +82,14 @@ You can force a Property to be serialized even when the value is ``None`` by ann
Customised Property Serialization
----------------------------------------------------

This feature allows you to handle, for example, serialization of :obj:`datetime.date` Python objects to and from
This feature allows you to handle, for example, serialization of :class:`datetime.date` Python objects to and from
strings.

Depending on your use case, the string format could vary, and thus this library makes no assumptions. We have provided
an some example helpers for (de-)serializing dates and datetimes.

To define a custom serializer for a property, add the :obj:`serializable.type_mapping()` decorator to the property.
For example, to have a property named *created* be use the :obj:`serializable.helpers.Iso8601Date` helper you
To define a custom serializer for a property, add the :func:`serializable.type_mapping()` decorator to the property.
For example, to have a property named *created* be use the :class:`serializable.helpers.Iso8601Date` helper you
would add the following method to your class:

.. code-block:: python
Expand All @@ -109,16 +109,16 @@ Writing Custom Property Serializers
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

You can write your own custom property serializer. The only requirements are that it must extend
:obj:`serializable.helpers.BaseHelper` and therefore implement the ``serialize()`` and ``deserialize()`` class methods.
:class:`serializable.helpers.BaseHelper` and therefore implement the ``serialize()`` and ``deserialize()`` class methods.

For examples, see :obj:`serializable.helpers`.
For examples, see :mod:`serializable.helpers`.


Serializing Lists & Sets
----------------------------------------------------

Particularly in XML, there are many ways that properties which return Lists or Sets could be represented. We can handle
this by adding the decorator :obj:`serializable.xml_array()` to the appropriate property in your class.
this by adding the decorator :func:`serializable.xml_array()` to the appropriate property in your class.

For example, given a Property that returns ``Set[Chapter]``, this could be serialized in one of a number of ways:

Expand Down Expand Up @@ -174,7 +174,7 @@ For *Example 3*, you would add the following to your class:
def chapters(self) -> List[Chapter]:
return self._chapters
Further examples are available in our unit tests.
Further examples are available in our :ref:`unit tests <unit-tests>`.

Serialization Views
----------------------------------------------------
Expand All @@ -187,7 +187,7 @@ By default all Properties will be included in the serialization process, but thi
Defining Views
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

A View is a class that extends :obj:`serializable.ViewType` and you should create classes as required in your
A View is a class that extends :class:`serializable.ViewType` and you should create classes as required in your
implementation.

For example:
Expand Down Expand Up @@ -254,7 +254,7 @@ XML Element Ordering
Some XML schemas utilise `sequence`_ which requires elements to be in a prescribed order.

You can control the order properties are serialized to elements in XML by utilising the
:obj:`serializable.xml_sequence()` decorator. The default sort order applied to properties is 100 (where lower is
:func:`serializable.xml_sequence()` decorator. The default sort order applied to properties is 100 (where lower is
earlier in the sequence).

In the example below, the ``isbn`` property will be output first.
Expand All @@ -267,4 +267,4 @@ In the example below, the ``isbn`` property will be output first.
return self._isbn
.. _sequence: https://www.w3.org/TR/xmlschema-0/#element-sequence
.. _sequence: https://www.w3.org/TR/xmlschema-0/#element-sequence
2 changes: 2 additions & 0 deletions docs/examples.rst
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@
Examples
========

.. _unit-tests:

Models used in Unit Tests
-------------------------

Expand Down
10 changes: 5 additions & 5 deletions docs/formatters.rst
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
Property Name Formatting
====================================================

By default, ``py-serializable`` uses it's :obj:`serializable.formatters.CamelCasePropertyNameFormatter` formatter for
By default, ``py-serializable`` uses it's :class:`serializable.formatters.CamelCasePropertyNameFormatter` formatter for
translating actual Python property names to element names in either JSON or XML.

``py-serializable`` includes a number of name formatters out of the box, but you can also create your own if required.
Expand All @@ -28,9 +28,9 @@ Included Formatters

``py-serializable`` includes three common formatters out of the box.

1. Camel Case Formatter: :obj:`serializable.formatters.CamelCasePropertyNameFormatter` (the default)
2. Kebab Case Formatter: :obj:`serializable.formatters.KebabCasePropertyNameFormatter`
3. Snake Case Formatter: :obj:`serializable.formatters.SnakeCasePropertyNameFormatter`
1. Camel Case Formatter: :class:`serializable.formatters.CamelCasePropertyNameFormatter` (the default)
2. Kebab Case Formatter: :class:`serializable.formatters.KebabCasePropertyNameFormatter`
3. Snake Case Formatter: :class:`serializable.formatters.SnakeCasePropertyNameFormatter`

A summary of how these differ is included in the below table.

Expand Down Expand Up @@ -60,4 +60,4 @@ Custom Formatters

If none of the included formatters work for you, why not write your own?

The only requirement is that it extends :obj:`serializable.formatters.BaseNameFormatter`!
The only requirement is that it extends :class:`serializable.formatters.BaseNameFormatter`!
4 changes: 2 additions & 2 deletions docs/getting-started.rst
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ as follows:
self._chapters = list(chapters)
To make a class serializable to/from JSON or XML, the class must be annotated with the decorator
:obj:`serializable.serializable_class`.
:func:`serializable.serializable_class`.

By simply modifying the classes above, we make them (de-)serializable with this library (albeit with some default
behaviour implied!).
Expand Down Expand Up @@ -183,4 +183,4 @@ which outputs:
<edition>1</edition>
<publishDate>2022-08-10</publishDate>
<author>me</author>
</book>
</book>

0 comments on commit aabb5e9

Please sign in to comment.