File: control

package info (click to toggle)
libclass-std-storable-perl 0.0.1-2.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 100 kB
  • sloc: perl: 111; makefile: 2
file content (40 lines) | stat: -rw-r--r-- 2,038 bytes parent folder | download | duplicates (2)
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
Source: libclass-std-storable-perl
Section: perl
Priority: optional
Maintainer: KURASHIKI Satoru <lurdan@gmail.com>
Build-Depends: debhelper (>= 9.20120312)
Build-Depends-Indep: libclass-std-perl (>= 0.0.4),
 libmodule-build-perl,
 perl
Standards-Version: 3.9.6
Homepage: https://metacpan.org/release/Class-Std-Storable
Vcs-Git: git://anonscm.debian.org/collab-maint/libclass-std-storable-perl.git
Vcs-Browser: http://anonscm.debian.org/cgit/collab-maint/libclass-std-storable-perl.git

Package: libclass-std-storable-perl
Architecture: all
Depends: ${misc:Depends}, ${perl:Depends},
 libclass-std-perl (>= 0.0.4)
Description: Support for creating serializable "inside-out" classes 
 Class::Std introduced the "inside-out" model for classes (perldoc Class::Std
 for details). Among its salient features is complete encapsulation; that is,
 an object's data may only be accessed via its methods, unlike the usual
 hashref model that permits direct access by any code whatsoever. However, the
 drawback of complete encapsulation is that normal mechanisms for
 serialization won't work, as they rely on direct access to an object's
 attributes.
 .
 This class provides the class-building functionality from Class::Std, and in
 addition provides an interface to allow Storable to freeze and thaw any
 declared attributes of this class and any superclasses that were built via
 Class::Std::Storable.
 .
 However, in order to let Storable save attributes and construct the object,
 it is necessary to expose the attributes of the class to the world. Thus, any
 code could use the same interface that Storable does to get a copy of object
 attributes and create new objects with arbitrary attributes without going
 through the constructor. While the interface CAN'T be used to replace the
 existing attributes of an object, it COULD be used to create an arbitrarily
 mutated clone of an object without going through its methods. Also, if
 attributes are themselves references, then the objects to which they refer
 can be obtained and modified.