OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib64
/
perl5
Server IP: 82.112.239.19
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
06/20/2025 01:51:09 AM
r-xr-xr-x
📁
B
-
08/27/2024 05:22:04 PM
rwxr-xr-x
📄
B.pm
28.78 KB
04/03/2024 02:35:12 PM
rw-r--r--
📁
CORE
-
08/27/2024 05:20:51 PM
rwxr-xr-x
📄
Config.pm
3.12 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
Config.pod
248.73 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
Config_git.pl
409 bytes
04/03/2024 02:35:12 PM
rw-r--r--
📄
Config_heavy.pl
57.05 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
DynaLoader.pm
24.66 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
Errno.pm
6.7 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
Fcntl.pm
3.95 KB
04/03/2024 02:35:12 PM
rw-r--r--
📁
File
-
08/27/2024 05:20:51 PM
rwxr-xr-x
📁
IO
-
08/27/2024 05:20:51 PM
rwxr-xr-x
📄
IO.pm
1.42 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
NDBM_File.pm
3.01 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
O.pm
4.19 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
POSIX.pm
19.87 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
POSIX.pod
78.81 KB
04/03/2024 02:35:12 PM
rw-r--r--
📁
PerlIO
-
08/27/2024 05:20:51 PM
rwxr-xr-x
📄
SDBM_File.pm
3.72 KB
04/03/2024 02:35:12 PM
rw-r--r--
📁
Sys
-
08/27/2024 05:22:04 PM
rwxr-xr-x
📄
attributes.pm
15.97 KB
04/03/2024 02:35:12 PM
rw-r--r--
📁
auto
-
04/03/2024 02:35:39 PM
rwxr-xr-x
📄
lib.pm
5.99 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
mro.pm
9.66 KB
04/03/2024 02:35:12 PM
rw-r--r--
📄
re.pm
24.8 KB
04/03/2024 02:35:12 PM
rw-r--r--
📁
vendor_perl
-
08/27/2024 07:00:40 PM
rwxr-xr-x
Editing: SDBM_File.pm
Close
package SDBM_File; use strict; use warnings; require Tie::Hash; require XSLoader; our @ISA = qw(Tie::Hash); our $VERSION = "1.15"; our @EXPORT_OK = qw(PAGFEXT DIRFEXT PAIRMAX); use Exporter "import"; XSLoader::load(); 1; __END__ =head1 NAME SDBM_File - Tied access to sdbm files =head1 SYNOPSIS use Fcntl; # For O_RDWR, O_CREAT, etc. use SDBM_File; tie(%h, 'SDBM_File', 'filename', O_RDWR|O_CREAT, 0666) or die "Couldn't tie SDBM file 'filename': $!; aborting"; # Now read and change the hash $h{newkey} = newvalue; print $h{oldkey}; ... untie %h; =head1 DESCRIPTION C<SDBM_File> establishes a connection between a Perl hash variable and a file in SDBM_File format. You can manipulate the data in the file just as if it were in a Perl hash, but when your program exits, the data will remain in the file, to be used the next time your program runs. =head2 Tie Use C<SDBM_File> with the Perl built-in C<tie> function to establish the connection between the variable and the file. tie %hash, 'SDBM_File', $basename, $modeflags, $perms; tie %hash, 'SDBM_File', $dirfile, $modeflags, $perms, $pagfilename; C<$basename> is the base filename for the database. The database is two files with ".dir" and ".pag" extensions appended to C<$basename>, $basename.dir (or .sdbm_dir on VMS, per DIRFEXT constant) $basename.pag The two filenames can also be given separately in full as C<$dirfile> and C<$pagfilename>. This suits for two files without ".dir" and ".pag" extensions, perhaps for example two files from L<File::Temp>. C<$modeflags> can be the following constants from the C<Fcntl> module (in the style of the L<open(2)> system call), O_RDONLY read-only access O_WRONLY write-only access O_RDWR read and write access If you want to create the file if it does not already exist then bitwise-OR (C<|>) C<O_CREAT> too. If you omit C<O_CREAT> and the database does not already exist then the C<tie> call will fail. O_CREAT create database if doesn't already exist C<$perms> is the file permissions bits to use if new database files are created. This parameter is mandatory even when not creating a new database. The permissions will be reduced by the user's umask so the usual value here would be 0666, or if some very private data then 0600. (See L<perlfunc/umask>.) =head1 EXPORTS SDBM_File optionally exports the following constants: =over =item * C<PAGFEXT> - the extension used for the page file, usually C<.pag>. =item * C<DIRFEXT> - the extension used for the directory file, C<.dir> everywhere but VMS, where it is C<.sdbm_dir>. =item * C<PAIRMAX> - the maximum size of a stored hash entry, including the length of both the key and value. =back These constants can also be used with fully qualified names, eg. C<SDBM_File::PAGFEXT>. =head1 DIAGNOSTICS On failure, the C<tie> call returns an undefined value and probably sets C<$!> to contain the reason the file could not be tied. =head2 C<sdbm store returned -1, errno 22, key "..." at ...> This warning is emitted when you try to store a key or a value that is too long. It means that the change was not recorded in the database. See BUGS AND WARNINGS below. =head1 SECURITY WARNING B<Do not accept SDBM files from untrusted sources!> The sdbm file format was designed for speed and convenience, not for portability or security. A maliciously crafted file might cause perl to crash or even expose a security vulnerability. =head1 BUGS AND WARNINGS There are a number of limits on the size of the data that you can store in the SDBM file. The most important is that the length of a key, plus the length of its associated value, may not exceed 1008 bytes. See L<perlfunc/tie>, L<perldbmfilter>, L<Fcntl> =cut