
NAME
Identity::Utils - Provide utility functions related to distribution identities
SYNOPSIS
use Identity::Utils;
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>:from<Perl5>";
say short-name($identity); # Foo::Bar
say ver($identity); # 0.0.42
say without-ver($identity); # Foo::Bar:auth<zef:lizmat>:api<2.0>:from<Perl5>
say version($identity); # v0.0.42
say auth($identity); # zef:lizmat
say without-auth($identity); # Foo::Bar:ver<0.0.42>:api<2.0>:from<Perl5>
say ecosystem($identity); # zef
say nick($identity); # lizmat
say api($identity); # 2.0
say without-api($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:from<Perl5>
say from($identity); # Perl5
say without-from($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>
say sanitize($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>:from<Perl5>
say build("Foo::Bar", :ver<0.0.42>); # Foo::Bar:ver<0.0.42>
# build from a hash of a JSON file
say build(from-json("META6.json".io.slurp);
say is-short-name($identity); # False
say is-short-name("Foo::Bar"); # True
say is-pinned($identity); # True
say is-pinned("Foo::Bar"); # False
my $spec = dependency-specification($identity);
my $compunit = compunit($identity);
my $meta = meta($identity, $repo);
my $source-io = source-io($identity, $repo);
my $source = source($identity, $repo);
my $bytecode-io = bytecode-io($identity, $repo);
my $bytecode = bytecode($identity, $repo);
.say for latest-successors(@identities);
say raku-land-url($identity); # https://raku.land/...
say rea-meta-url($identity); # https://raw.githubusercontent.com...
say rea-dist-url($identity); # https://github.com/Raku/REA/...
say "Download of $identity distribution successful"
if rea-dist($identity);
say rea-meta($identity); # {"api":"","auth":"zef:lizmat","authors"...
say rea-index-url; # https://raw.githubusercontent.com/Raku...
my $rea-json = rea-index;
say zef-index-url; # https://360.zef.pm
my $zef-json = zef-index;
use Identity::Utils <short-name auth>; # only import "short-name" and "auth"
DESCRIPTION
Identity::Utils provides some utility functions for inspecting various aspects of distribution identity strings. They assume any given string is a well-formed identity in the form name:ver<0.0.1>:auth<eco:nick> with an optional api:<1> field.
A general note with regards to api: if it consists of "0", then it is assumed there is no api field specified.
SELECTIVE IMPORTING
use Identity::Utils <short-name auth>; # only import "short-name" and "auth"
By default all utility functions are exported. But you can limit this to the functions you actually need by specifying the names in the use statement.
To prevent name collisions and/or import any subroutine with a more memorable name, one can use the "original-name:known-as" syntax. A semi-colon in a specified string indicates the name by which the subroutine is known in this distribution, followed by the name with which it will be known in the lexical context in which the use command is executed.
use Identity::Utils <short-name:name>; # import "short-name" as "name"
say name("Identity::Utils:auth<zef:lizmat>"); # Identity::Utils
SUBROUTINES
api
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say api($identity); # 2.0
Returns the api field of the given identity, or Nil if no api field could be found.
auth
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say auth($identity); # zef:lizmat
Returns the auth field of the given identity, or Nil if no auth field could be found.
build
my $ver = "0.0.42";
my $auth = "zef:lizmat";
my $api = "2.0";
my $from = "Perl5";
say build("Foo::Bar", :$ver, :$auth, :$api, :$from);
# Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>:from<Perl5>
say build("Foo::Bar", :$ver, :nick<lizmat>);
# Foo::Bar:ver<0.0.42>:auth<zef:lizmat>
Builds an identity string from the given short name and optional named arguments:
ver - the "ver" value to be used
auth - the "auth" value to be used, overrides "ecosystem" and "nick"
api - the "api" value to be used
from - the "from" value to be used, 'Perl6' and 'Raku' will be ignored
ecosystem - the ecosystem part of "auth", defaults to "zef"
nick - the nick part of "auth", unless overridden by "auth"
use String::Utils;
say build(String::Utils); # String::Utils:ver<0.0.34>:auth<zef:lizmat>
An identity string can also be built from a type object.
# build from a hash of a JSON file
say build(from-json("META6.json".io.slurp);
Alternately, an identity string can be built from an Associative such as being created from a META6.json file.
bytecode
my $buf = bytecode($identity); # default: $*REPO
my $buf = bytecode($identity, "."); # as if with -I.
Returns a Buf object with the precompiled bytecode of the given identity and the currently active repository ($*REPO).
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Attempts to create the bytecode file if there isn't one yet.
Returns Nil if the given identity could not be found, or there is no bytecode file for the short-name of the given identity (probably because it failed to compile).
bytecode-io
my $io = bytecode-io($identity); # default: $*REPO
my $io = bytecode-io($identity, "."); # as if with -I.
Returns an IO::Path object of the precompiled bytecode of the given identity and the currently active repository ($*REPO).
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Attempts to create the bytecode file if there isn't one yet.
Returns Nil if the given identity could not be found, or there is no bytecode file for the short-name of the given identity (probably because it failed to compile).
compunit
my $compunit = compunit($identity); # default: $*REPO
my $compunit = compunit($identity, "."); # as if with -I.
my $compunit = compunit($identity, :need); # make bytecode
Returns a Compunit object for the given identity and the currently active repository ($*REPO).
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
A boolean named argument need can be specified to indicate that a bytecode file should be created if there is none for this compunit yet.
Returns Nil if the given identity could not be found.
my %meta := from-json "META6.json".IO.slurp;
# runtime dependencies
.say for dependencies-from-meta(%meta);
# author-dependencies
.say for dependencies-from-meta(%meta, :stage<author>);
# build-dependencies
.say for dependencies-from-meta(%meta, :stage<build>);
# test-dependencies
.say for dependencies-from-meta(%meta, :stage<test>);
# test-dependencies
.say for dependencies-from-meta(%meta, :stage<all>);
Returns an iterable that produces all of the dependencies found in given hash, usually produced from the META6.json file of a distribution.
Takes an optional :stage named argument, which defaults to "runtime". Other possible values are "author", "build", "test" and "all". If "all" is specified, the unique dependencies of "author", "build", "test" and "runtime" will be returned.
Returns Empty if no dependencies could be found for (implicitely) given stage.
dependencies-from-identity
.say for dependencies-from-identity($identity); # default: $*REPO
.say for dependencies-from-identity($identity, "."); # as if with -I.
Returns an iterable that produces all of the dependencies of the given identity.
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Returns Empty if either the given identity could not be found, or there are no dependencies.
dependency-specification
my $spec = dependency-specification($identity);
Creates a CompUnit::DependencySpecification object for the given identity.
distribution-name
say distribution-name("SBOM::CycloneDX:ver<0.0.9>:auth<zef:lizmat>");
# SBOM-CycloneDX-0.0.9.tar.gz
Return the distribution name for the given pinned identity. Optionally takes a second positional argument for the extension to be used: defaults to "tar.gz".
ecosystem
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say ecosystem($identity); # zef
Returns the ecosystem part of the auth field of the given identity, or Nil if no auth field could be found.
from
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>:from<Perl5>";
say from($identity); # Perl5
Returns the from field of the given identity as a Str, or Nil if no from field could be found.
is-pinned
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say is-pinned($identity); # True
say is-pinned("Foo::Bar"); # False
Returns a boolean indicating whether the given identity is considered to be pinned to a specific release. This implies: having an auth and having a version without a + or a * in it.
is-short-name
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say is-short-name($identity); # False
say is-short-name("Foo::Bar"); # True
Returns a boolean indicating whether the given identity consists of just a short-name.
issue-tracker-url
say issue-tracker-url("https://gitlab.com/raku-land/raku-land.git");
# https://gitlab.com/raku-land/raku-land/-/issues
Convert the URL of a distribution into the URL of the page where issues can be made / inspected. Currently supported are URLs on Github and Gitlab. Nil will be returned if the URL is not recognized.
latest-successors
.say for latest-successors(@identies);
Returns a sorted Seq of identities that have been filtered by the same semantics that are used when installing a module without specifying anything other than a short name of an identity.
For instance, taking:
AccountableBagHash:ver<0.0.3>:auth<cpan:ELIZABETH>
AccountableBagHash:ver<0.0.6>:auth<zef:lizmat>
would only return AccountableBagHash:ver<0.0.6>:auth<zef:lizmat> because it has a higher version number, and the ecosystems are different.
my $meta = meta($identity); # default: $*REPO
my $meta = meta($identity, "."); # as if with -I.
Returns a hash with the meta information of the given identity and the currently active repository ($*REPO) as typically found in the META6.json file of a distribution.
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Returns Nil if the given identity could not be found.
nick
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say nick($identity); # lizmat
Returns the nickname part of the auth field of the given identity, or Nil if no auth field could be found.
raku-land-url
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>:api<2.0>";
say raku-land-url($identity); # https://raku.land/zef:lizmat/FOO::Bar?v=0.0.42
Returns the raku.land URL of the given identity.
rea-dist
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>";
say "Download of $identity distribution successful"
if rea-dist($identity);
Attempts to download the distribution tar file of the given identity from the Raku Ecosystem Archive (REA) and returns True if this was successful.
Allows specifying a second argument that is either a path or an IO::Path object to indicate where the download should be stored: it defaults to "." indicating the current directory.
If the path indicates a directory, then the distribution will be stored in that directory with the identity's long name. Otherwise the path will be taken as the name to store the distribution as.
Assumes the curl command-line program is installed and a network connection is available.
Optionally takes a :verbose named argument: if specified with a truish value, will show any error information on STDERR if the download failed for some reason.
rea-dist-url
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>";
say rea-dist-url($identity);
# https://github.com/Raku/REA/raw/refs/heads/main/archive/F/Foo::Bar/Foo::Bar:ver<0.0.42>:auth<zef:lizmat>.tar.gz
Returns the URL of the distribution of the given identity in the Raku Ecosystem Archive (REA).
rea-index
my $json = rea-index;
Returns the JSON of the REA (Raku Ecosystem Archive) index.
Assumes the curl command-line program is installed and a network connection is available.
rea-index-url
say rea-index-url;
# https://raw.githubusercontent.com/Raku/REA/refs/heads/main/META.json
Returns the URL of the JSON-index of the REA (Raku Ecosystem Archive).
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>";
say rea-meta($identity); # {"api":"","auth":"zef:lizmat","authors"...
Attempts to download the meta information file of the given identity from the Raku Ecosystem Archive (REA) and returns that if successful. Otherwise returns Nil.
Assumes the curl command-line program is installed and a network connection is available.
Optionally takes a :verbose named argument: if specified with a truish value, will show any error information on STDERR if the download failed for some reason.
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>";
say rea-meta-url($identity);
# https://raw.githubusercontent.com/Raku/REA/refs/heads/main/meta/F/Foo::Bar/Foo::Bar:ver<0.0.42>:auth<zef:lizmat>.json
Returns the URL of the meta information of the given identity in the Raku Ecosystem Archive (REA).
sanitize
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>:api<2.0>";
say sanitize($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>
Returns a version of the given identity in which any ver, auth and api fields are put in the correct order.
short-name
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say short-name($identity); # Foo::Bar
Returns the short name part of the given identity, or the identity itself if no ver, auth or api fields could be found.
source
say source($identity); # default: $*REPO
say source($identity, "."); # as if with -I.
Returns the source-code of the given identity and the currently active repository ($*REPO) as typically found in the lib directory of a distribution.
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Returns Nil if the given identity could not be found, or there is no source-file for the short-name of the given identity.
source-io
my $io = source-io($identity); # default: $*REPO
my $io = source-io($identity, "."); # as if with -I.
Returns an IO::Path object of the source of the given identity and the currently active repository ($*REPO) as typically found in the lib directory of a distribution.
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Returns Nil if the given identity could not be found, or there is no source-file for the short-name of the given identity.
ver
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say ver($identity); # 0.0.42
Returns the ver field of the given identity as a Str, or Nil if no ver field could be found.
version
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say version($identity); # v0.0.42
Returns the ver field of the given identity as a Version object, or Nil if no ver field could be found.
without-api
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say without-api($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>
=head2 raku-land-url
=begin code :lang<raku>
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>:api<2.0>";
say raku-land-url($identity); # https://raku.land/zef:lizmat/FOO::Bar?v=0.0.42
Returns the raku.land URL of the given identity.
sanitize
my $identity = "Foo::Bar:auth<zef:lizmat>:ver<0.0.42>:api<2.0>";
say sanitize($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>
Returns a version of the given identity in which any ver, auth and api fields are put in the correct order.
short-name
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say short-name($identity); # Foo::Bar
Returns the short name part of the given identity, or the identity itself if no ver, auth or api fields could be found.
source
say source($identity); # default: $*REPO
say source($identity, "."); # as if with -I.
Returns the source-code of the given identity and the currently active repository ($*REPO) as typically found in the lib directory of a distribution.
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Returns Nil if the given identity could not be found, or there is no source-file for the short-name of the given identity.
source-distribution-url
say source-distribution("https://github.com/janedoe/Foo.git", v1.2.3);
# 'https://github.com/janedoe/Foo/archive/refs/tags/1.2.3.zip'
Convert the URL of a distribution into the URL to download the artifact of the given version from. Currently only Github URLs are supported. Nil will be returned if the URL is not recognized.
source-io
my $io = source-io($identity); # default: $*REPO
my $io = source-io($identity, "."); # as if with -I.
Returns an IO::Path object of the source of the given identity and the currently active repository ($*REPO) as typically found in the lib directory of a distribution.
It is also possible to override the repository (chain) by specifying a second argument, this can be an object of type:
Str - indicate a path for a ::FileSystem repo, just as with -I.
IO::Path - indicate a path for a ::FileSystem repo
CompUnit::Repository - the actual repo to use
Returns Nil if the given identity could not be found, or there is no source-file for the short-name of the given identity.
ver
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say ver($identity); # 0.0.42
Returns the ver field of the given identity as a Str, or Nil if no ver field could be found.
version
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say version($identity); # v0.0.42
Returns the ver field of the given identity as a Version object, or Nil if no ver field could be found.
without-api
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say without-api($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>
Returns the identity without any api field of the given identity.
without-auth
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say without-auth($identity); # Foo::Bar:ver<0.0.42>:api<2.0>
Returns the identity without any auth field of the given identity.
without-from
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:from<Perl5>";
say without-from($identity); # Foo::Bar:ver<0.0.42>:auth<zef:lizmat>
Returns the identity without any from field of the given identity.
without-ver
my $identity = "Foo::Bar:ver<0.0.42>:auth<zef:lizmat>:api<2.0>";
say without-ver($identity); # Foo::Bar:auth<zef:lizmat>:api<2.0>
Returns the identity without any ver field of the given identity.
zef-index
my $json = zef-index;
Returns the JSON of the zef index.
Assumes the curl command-line program is installed and a network connection is available.
zef-index-url
say zef-index-url; # https://360.zef.pm
Returns the URL of the JSON-index of the zef ecosystem.
AUTHOR
Elizabeth Mattijsen liz@raku.rocks
Source can be located at: https://github.com/lizmat/Identity-Utils . Comments and Pull Requests are welcome.
If you like this module, or what I’m doing more generally, committing to a small sponsorship would mean a great deal to me!
COPYRIGHT AND LICENSE
Copyright 2022, 2024, 2025 Elizabeth Mattijsen
This library is free software; you can redistribute it and/or modify it under the Artistic License 2.0.