File: cache.rst

package info (click to toggle)
python-persistent 4.0.8-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 680 kB
  • ctags: 1,140
  • sloc: python: 4,156; ansic: 2,727; xml: 845; makefile: 112
file content (59 lines) | stat: -rw-r--r-- 1,821 bytes parent folder | download | duplicates (3)
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
Caching Persistent Objects
==========================

Creating Objects ``de novo``
----------------------------

Creating ghosts from scratch, as opposed to ghostifying a non-ghost
is rather tricky. :class:`~persistent.interfaces.IPeristent` doesn't
really provide the right interface given that:

- :meth:`_p_deactivate` and :meth:`_p_invalidate` are overridable, and
  could assume that the object's state is properly initialized.

- Assigning :attr:`_p_changed` to None just calls :meth:`_p_deactivate`.

- Deleting :attr:`_p_changed` just calls :meth:`_p_invalidate`.

.. note::

   The current cache implementation is intimately tied up with the
   persistence implementation and has internal access to the persistence
   state.  The cache implementation can update the persistence state for
   newly created and ininitialized objects directly.

   The future persistence and cache implementations will be far more
   decoupled. The persistence implementation will only manage object
   state and generate object-usage events.  The cache implemnentation(s)
   will be rersponsible for managing persistence-related (meta-)state,
   such as _p_state, _p_changed, _p_oid, etc.  So in that future
   implemention, the cache will be more central to managing object
   persistence information.

Caches have a :meth:`new_ghost` method that:

- adds an object to the cache, and

- initializes its persistence data.

.. doctest::

   >>> import persistent
   >>> from persistent.tests.utils import ResettingJar

   >>> class C(persistent.Persistent):
   ...     pass

   >>> jar = ResettingJar()
   >>> cache = persistent.PickleCache(jar, 10, 100)
   >>> ob = C.__new__(C)
   >>> cache.new_ghost('1', ob)

   >>> ob._p_changed
   >>> ob._p_jar is jar
   True
   >>> ob._p_oid
   '1'

   >>> cache.cache_non_ghost_count
   0