NAME

Wikibase::Datatype::Utils - Wikibase datatype utilities.

SYNOPSIS

use Wikibase::Datatype::Utils qw(check_datetime check_entity check_language check_lexeme check_property check_sense);

check_datetime($self, $key);
check_entity($self, $key);
check_language($self, $key);
check_lexeme($self, $key);
check_property($self, $key);
check_sense($self, $key);

DESCRIPTION

Datatype utilities for checking of data objects.

VARIABLES

$SKIP_CHECK_LANG

Boolean variable to skip check of right language.

Default value is 0, checking is working.

@LANGUAGE_CODES

List of supported language codes defined by user.

Default value is (), checking official language codes.

SUBROUTINES

check_datetime

check_datetime($self, $key);

Check parameter defined by $key if it's datetime for Wikibase. Format of value is variation of ISO 8601 with some changes (like 00 as valid month).

Returns undef.

check_entity

check_entity($self, $key);

Check parameter defined by $key if it's entity (/^Q\d+/).

Returns undef.

check_language

check_language($self, $key);

Check parameter defined by $key if it's ISO 639-1 language code and if language exists.

Returns undef.

check_lexeme

check_lexeme($self, $key);

Check parameter defined by $key if it's entity (/^L\d+/).

Returns undef.

check_property

check_property($self, $key);

Check parameter defined by $key if it's property (/^P\d+/).

Returns undef.

check_sense

check_sense($self, $key);

Check parameter defined by $key if it's property (/^L\d+\-S\d+$/).

Returns undef.

ERRORS

check_datetime():
        Parameter '%s' has bad date time.
                Value: %s
        Parameter '%s' has bad date time day value.
                Value: %s
        Parameter '%s' has bad date time hour value.
                Value: %s
        Parameter '%s' has bad date time minute value.
                Value: %s
        Parameter '%s' has bad date time month value.
                Value: %s
        Parameter '%s' has bad date time second value.
                Value: %s

check_entity():
        Parameter '%s' must begin with 'Q' and number after it.";

check_language():
        Language code '%s' isn't code supported by Wikibase.

check_lexeme():
        Parameter '%s' must begin with 'L' and number after it.";

check_property():
        Parameter '%s' must begin with 'P' and number after it.";

check_sense():
        Parameter '%s' must begin with 'L' and number, dash, S and number after it.

EXAMPLE1

use strict;
use warnings;

use Wikibase::Datatype::Utils qw(check_datetime);

my $self = {
        'key' => '+0134-11-00T00:00:00Z',
        'precision' => 10
};
check_datetime($self, 'key');

# Print out.
print "ok\n";

# Output:
# ok

EXAMPLE2

use strict;
use warnings;

use Wikibase::Datatype::Utils qw(check_datetime);

$Error::Pure::TYPE = 'Error';

my $self = {
        'key' => '+0134-34-00T00:01:00Z',
};
check_datetime($self, 'key');

# Print out.
print "ok\n";

# Output:
# #Error [/../Wikibase/Datatype/Utils.pm:?] Parameter 'key' has bad date time month value.

EXAMPLE3

use strict;
use warnings;

use Wikibase::Datatype::Utils qw(check_entity);

my $self = {
        'key' => 'Q123',
};
check_entity($self, 'key');

# Print out.
print "ok\n";

# Output:
# ok

EXAMPLE4

use strict;
use warnings;

use Error::Pure;
use Wikibase::Datatype::Utils qw(check_entity);

$Error::Pure::TYPE = 'Error';

my $self = {
        'key' => 'bad_entity',
};
check_entity($self, 'key');

# Print out.
print "ok\n";

# Output like:
# #Error [/../Wikibase/Datatype/Utils.pm:?] Parameter 'key' must begin with 'Q' and number after it.

EXAMPLE5

use strict;
use warnings;

use Wikibase::Datatype::Utils qw(check_lexeme);

my $self = {
        'key' => 'L123',
};
check_lexeme($self, 'key');

# Print out.
print "ok\n";

# Output:
# ok

EXAMPLE6

use strict;
use warnings;

use Error::Pure;
use Wikibase::Datatype::Utils qw(check_lexeme);

$Error::Pure::TYPE = 'Error';

my $self = {
        'key' => 'bad_entity',
};
check_lexeme($self, 'key');

# Print out.
print "ok\n";

# Output like:
# #Error [/../Wikibase/Datatype/Utils.pm:?] Parameter 'key' must begin with 'L' and number after it.

EXAMPLE7

use strict;
use warnings;

use Wikibase::Datatype::Utils qw(check_property);

my $self = {
        'key' => 'P123',
};
check_property($self, 'key');

# Print out.
print "ok\n";

# Output:
# ok

EXAMPLE8

use strict;
use warnings;

use Error::Pure;
use Wikibase::Datatype::Utils qw(check_property);

$Error::Pure::TYPE = 'Error';

my $self = {
        'key' => 'bad_property',
};
check_property($self, 'key');

# Print out.
print "ok\n";

# Output like:
# #Error [/../Wikibase/Datatype/Utils.pm:?] Parameter 'key' must begin with 'P' and number after it.

EXAMPLE9

use strict;
use warnings;

use Wikibase::Datatype::Utils qw(check_sense);

my $self = {
        'key' => 'L34727-S1',
};
check_sense($self, 'key');

# Print out.
print "ok\n";

# Output:
# ok

EXAMPLE10

use strict;
use warnings;

use Error::Pure;
use Wikibase::Datatype::Utils qw(check_sense);

$Error::Pure::TYPE = 'Error';

my $self = {
        'key' => 'bad_sense',
};
check_sense($self, 'key');

# Print out.
print "ok\n";

# Output like:
# #Error [/../Wikibase/Datatype/Utils.pm:?] Parameter 'key' must begin with 'L' and number, dash, S and number after it.

DEPENDENCIES

DateTime, Exporter, Error::Pure, List::Util, Readonly.

SEE ALSO

Wikibase::Datatype

Wikibase datatypes.

Mo::utils

Mo utilities.

Mo::utils::Language

Mo language utilities.

REPOSITORY

https://github.com/michal-josef-spacek/Wikibase-Datatype

AUTHOR

Michal Josef Špaček mailto:skim@cpan.org

http://skim.cz

LICENSE AND COPYRIGHT

© 2020-2025 Michal Josef Špaček

BSD 2-Clause License

VERSION

0.37