From 0a0da6395ab262bba62f12f85882f4f919ba402e Mon Sep 17 00:00:00 2001 From: Jarkko Hietaniemi Date: Mon, 7 Jan 2002 15:52:34 +0000 Subject: [PATCH] Add file magic for Storable, from Jim Cromie p4raw-id: //depot/perl@14119 --- ext/Storable/Storable.pm | 39 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) diff --git a/ext/Storable/Storable.pm b/ext/Storable/Storable.pm index d72b71d..353c999 100644 --- a/ext/Storable/Storable.pm +++ b/ext/Storable/Storable.pm @@ -70,7 +70,7 @@ package Storable; @ISA = qw(Exporter DynaLoader); use AutoLoader; use vars qw($forgive_me $VERSION); -$VERSION = '1.014'; +$VERSION = '1.015'; *AUTOLOAD = \&AutoLoader::AUTOLOAD; # Grrr... # @@ -127,6 +127,31 @@ sub CAN_FLOCK { $Config{'d_lockf'}; } +sub show_file_magic { + print <1 byte &01 (network-ordered) +0 string pst0 perl Storable(v0.7) data +# byte&04 unportable syntax +>4 byte&04 =4 +>>5 byte >0 v2.%d +>4 byte &01 (network-ordered) +# byte&01 unportable syntax +>4 byte&01 =0 (local-ordered) +>>6 byte >0 (sizeof int %d) +>>7 byte >0 (sizeof long %d) +>>8 byte >0 (sizeof ptr %d) +>>9 byte >0 (sizeof NV %d) +EOM +} + bootstrap Storable; 1; __END__ @@ -674,6 +699,18 @@ natively, i.e. without freezing to memory and thawing the result. It is aimed to replace Storable's dclone() some day. However, it does not currently support Storable hooks to redefine the way deep cloning is performed. +=head1 Storable magic + +Yes, there's a lot of that :-) But more precisely, in UNIX systems +there's a utility called C, which recognizes data files based on +their contents (usually their first few bytes). For this to work, +a certain file called "magic" needs to taught about the "signature" +of the data. Where that configuration file lives depends on the UNIX +flavour, often it's something like F or +F. Your system administrator needs to do the updating. +The necessary signature information is output to stdout by +invoking Storable::show_file_magic(). + =head1 EXAMPLES Here are some code samples showing a possible usage of Storable: -- 2.7.4