Crypt-HSXKPasswd
view release on metacpan or search on metacpan
lib/Crypt/HSXKPasswd/Dictionary/Basic.pm view on Meta::CPAN
package Crypt::HSXKPasswd::Dictionary::Basic;
use parent Crypt::HSXKPasswd::Dictionary;
# import required modules
use strict;
use warnings;
use Carp; # for nicer 'exception' handling for users of the module
use Fatal qw( :void open close binmode ); # make builtins throw exceptions on failure
use English qw(-no_match_vars); # for more readable code
use Readonly; # for truly constant constants
use Type::Params qw( compile multisig ); # for parameter validation with Type::Tiny objects
use Types::Standard qw( :types ); # for basic type checking (Int Str etc.)
use Crypt::HSXKPasswd::Types qw( :types ); # for custom type checking
use Crypt::HSXKPasswd::Helper; # exports utility functions like _error & _warn
# set things up for using UTF-8
use 5.016; # min Perl for good UTF-8 support, implies feature 'unicode_strings'
use Encode qw(encode decode);
use utf8;
binmode STDOUT, ':encoding(UTF-8)';
# Copyright (c) 2015, Bart Busschots T/A Bartificer Web Solutions All rights
# reserved.
#
# Code released under the FreeBSD license (included in the POD at the bottom of
# HSXKPasswd.pm)
#
# --- Constants ---------------------------------------------------------------
#
# version info
use version; our $VERSION = qv('1.2');
# utility variables
Readonly my $_CLASS => __PACKAGE__;
#
# --- Constructor -------------------------------------------------------------
#
#####-SUB-#####################################################################
# Type : CONSTRUCTOR (CLASS)
# Returns : An object of type Crypt::HSXKPasswd::Dictionary::Basic
# Arguments : 1) a string representing a file path to a dictionary file
# -- OR --
# an array ref containing a list of words
# 2) OPTIONAL - the encoding to import the file with. The default
# is UTF-8 (ignored if the first argument is not a file path).
# Throws : Croaks on invalid invocation and invalid args.
# Notes :
# See Also :
sub new{
my @args = @_;
my $class = shift @args;
_force_class($class);
# validate args
state $args_check = multisig(
[NonEmptyString, Optional[Maybe[NonEmptyString]]],
[ArrayRef[Str]],
);
my ($dict_source, $encoding) = $args_check->(@args);
# set defaults
$encoding = 'UTF-8' unless $encoding;
# start with a blank object
my $instance = {
words => [],
sources => {
files => [],
num_arrays => 0,
},
};
bless $instance, $class;
( run in 0.842 second using v1.01-cache-2.11-cpan-39bf76dae61 )