Aion-Format

 view release on metacpan or  search on metacpan

t/aion/format/url.pm  view on Meta::CPAN

use common::sense; use open qw/:std :utf8/;  use Carp qw//; use Cwd qw//; use File::Basename qw//; use File::Find qw//; use File::Slurper qw//; use File::Spec qw//; use File::Path qw//; use Scalar::Util qw//;  use Test::More 0.98;  use String::Diff q...
# 
# use common::sense;
# 
# use List::Util qw//;
# use Encode qw//;
# 
# use Exporter qw/import/;
# our @EXPORT = our @EXPORT_OK = grep {
# 	ref \$Aion::Format::Url::{$_} eq "GLOB"
# 		&& *{$Aion::Format::Url::{$_}}{CODE} && !/^(_|(NaN|import)\z)/n
# } keys %Aion::Format::Url::;
# 
# 
# #@category escape url
# 
# use constant UNSAFE_RFC3986 => qr/[^A-Za-z0-9\-\._~]/;
# 
# # Эскейпит значение
# sub to_url_param(;$) {
# 	my ($param) = @_ == 0? $_: @_;
# 	use bytes;
# 	$param =~ s/${\ UNSAFE_RFC3986}/$& eq " "? "+": sprintf "%%%02X", ord $&/ge;
# 	$param
# }
# 
# # Преобразует в формат url-параметров
# sub to_url_params(;$) {
# 	my ($param) = @_ == 0? $_: @_;
# 
# 	my @R;
# 	my @S = [$param];
# 	while(@S) {
# 		my $u = pop @S;
# 		my ($x, $key) = @$u;
# 		
# 		if(ref $x eq "HASH") {
# 			push @S, defined($key)
# 				? (map [$x->{$_}, "$key\[${\to_url_param}]"], sort keys %$x)
# 				: (map [$x->{$_}, to_url_param], sort keys %$x)
# 			;
# 		}
# 		elsif(ref $x eq "ARRAY") {
# 			push @S, map [$_, "$key\[]"], @$x;
# 		}
# 		elsif(!defined $x) {}
# 		elsif($x eq 1) { unshift @R, $key }
# 		else {
# 			unshift @R, join "=", $key, to_url_param $x;
# 		}
# 	}
# 	
# 	join "&", @R
# }
# 
# # Определяет кодировку. В koi8-r и в cp1251 большие и малые буквы как бы поменялись местами, поэтому у правильной кодировки вес будет больше
# sub _bohemy {
# 	my ($s) = @_;
# 	my $c = 0;
# 	while($s =~ /[а-яё]+/gi) {
# 		my $x = $&;
# 		if($x =~ /^[А-ЯЁа-яё][а-яё]*$/) { $c += length $x } else { $c -= length $x }
# 	}
# 	$c
# }
# 
# sub from_url_param(;$) {
# 	my ($param) = @_ == 0? $_: @_;
# 
# 	utf8::encode($param) if utf8::is_utf8($param);
# 
# 	{
# 		no utf8;
# 		use bytes;
# 		$param =~ s!\+! !g;
# 		$param =~ s!%([\da-f]{2})! chr hex $1 !age;
# 	}
# 
# 	eval { $param = Encode::decode_utf8($param, Encode::FB_CROAK) };
# 
# 	if($@) { # видимо тут кодировка cp1251 или koi8-r
# 		my $cp  = Encode::decode('cp1251', $param);
# 		my $koi = Encode::decode('koi8-r', $param);
# 		# выбираем перекодировку в которой меньше больших букв внутри слова
# 		$param = _bohemy($koi) > _bohemy($cp)? $koi: $cp;
# 	}
# 
# 	$param
# }
# 
# sub from_url_params(;$) {
# 	my ($param) = @_ == 0? $_: @_;
# 
# 	my %param;
# 
# 	for(split /&/, $param) {
# 		my ($key, $v) = /=/ ? ($`, $'): ($_, 1);
# 
# 		my @keys = split /(?:\]\[|[\[\]])/, $key;
# 		use DDP; p my $x=\@keys;
# 		my $x = \%param;
# 		for my $k (@keys) {
# 			if($k eq "") {
# 				use DDP; p my $x=["arr!", $k, $x, ref $x];

t/aion/format/url.pm  view on Meta::CPAN

# 			$link{dir} = $`;
# 			$link{file} = $&;
# 		} elsif($dir) {
# 			$link{path} = $link{dir} = "$link{path}/";
# 		} else {
# 			$link{dir} = "$link{path}/";
# 		}
# 	} elsif($dir) {
# 		$link{path} = "/";
# 	} else { delete $link{path} }
# 
# 	$link{orig} = $orig;
# 	$link{onpage} = $onpage;
# 	$link{link} = join "", $link{proto}, "://",
# 		exists $link{user} || exists $link{pass}? ($link{user},
# 			exists $link{pass}? ":$link{pass}": (), '@'): (),
# 		$link{dom},
# 		$link{path},
# 		length($link{query})? ("?", $link{query}): (),
# 		length($link{hash})? ("#", $link{hash}): (),
# 	;
# 
# 	return \%link;
# }
# 
# # Нормализует url
# sub normalize_url($;$$) {
# 	parse_url($_[0], $_[1], $_[2])->{link}
# }
# 
# 1;
# 
# __END__
# 
# =encoding utf-8
# 
# =head1 NAME
# 
# Aion::Format::Url - utilities for encoding and decoding URLs
# 
# =head1 SYNOPSIS
# 
# 	use Aion::Format::Url;
# 	
# 	to_url_params {a => 1, b => [[1,2],3,{x=>10}]} # => a&b[][]&b[][]=2&b[]=3&b[][x]=10
# 	
# 	normalize_url "?x", "http://load.er/fix/mix?y=6"  # => http://load.er/fix/mix?x
# 
# =head1 DESCRIPTION
# 
# Utilities for encoding and decoding URLs.
# 
# =head1 SUBROUTINES
# 
# =head2 to_url_param (;$scalar)
# 
# Escapes C<$scalar> for the search part of the URL.
# 
# 	to_url_param "a b" # => a+b
# 	
# 	[map to_url_param, "a b", "🦁"] # --> [qw/a+b %F0%9F%A6%81/]
# 
# =head2 to_url_params (;$hash_ref)
# 
# Generates the search portion of the URL.
# 
# 	local $_ = {a => 1, b => [[1,2],3,{x=>10}]};
# 	to_url_params  # => a&b[][]&b[][]=2&b[]=3&b[][x]=10
# 
# =over
# 
# =item 1. Keys with C<undef> values are not converted to strings.
# 
# =item 2. The empty value is empty.
# 
# =item 3. The value C<1> is only for a string key.
# 
# =item 4. Keys are converted in alphabetical order.
# 
# =back
# 
# 	to_url_params {k => "", n => undef, f => 1}  # => f&k=
# 
# =head2 from_url_params (;$scalar)
# 
# Parses the search part of the URL.
# 
# 	local $_ = 'a&b[][]&b[][]=2&b[]=3&b[][x]=10';
# 	from_url_params  # --> {a => 1, b => [[1,2],3,{x=>10}]}
# 
# =head2 from_url_param (;$scalar)
# 
# Used to parse keys and values in a URL parameter.
# 
# Reverse to C<to_url_param>.
# 
# 	local $_ = to_url_param '↬';
# 	from_url_param  # => ↬
# 
# =head2 parse_url ($url, $onpage, $dir)
# 
# Parses and normalizes URLs.
# 
# =over
# 
# =item * C<$url> - URL or part of it to be parsed.
# 
# =item * C<$onpage> is the URL of the page with C<$url>. If C<$url> is not complete, then it is completed from here. Optional. By default it uses the C<$onpage = 'off://off'> configuration.
# 
# =item * C<$dir> (bool): 1 - normalize the URL path with a "/" at the end if it is a directory. 0 - without "/".
# 
# =back
# 
# 	my $res = {
# 	    proto  => "off",
# 	    dom    => "off",
# 	    domain => "off",
# 	    link   => "off://off",
# 	    orig   => "",
# 	    onpage => "off://off",
# 	};



( run in 0.939 second using v1.01-cache-2.11-cpan-39bf76dae61 )