iw7-mod/deps/curl/tests/pathhelp.pm
2025-04-29 03:15:39 -04:00

186 lines
5.9 KiB
Perl

###########################################################################
# _ _ ____ _
# Project ___| | | | _ \| |
# / __| | | | |_) | |
# | (__| |_| | _ <| |___
# \___|\___/|_| \_\_____|
#
# Copyright (C) Evgeny Grin (Karlson2k), <k2k@narod.ru>.
#
# This software is licensed as described in the file COPYING, which
# you should have received as part of this distribution. The terms
# are also available at https://curl.se/docs/copyright.html.
#
# You may opt to use, copy, modify, merge, publish, distribute and/or sell
# copies of the Software, and permit persons to whom the Software is
# furnished to do so, under the terms of the COPYING file.
#
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
# KIND, either express or implied.
#
# SPDX-License-Identifier: curl
#
###########################################################################
# This Perl package helps with path transforming when running curl tests on
# native Windows and MSYS/Cygwin.
# Following input formats are supported (via built-in Perl functions):
# (1) /some/path - absolute path in POSIX-style
# (2) D:/some/path - absolute path in Windows-style
# (3) some/path - relative path
# (4) D:some/path - path relative to current directory on Windows drive
# (paths like 'D:' are treated as 'D:./') (*)
# (5) \some/path - path from root directory on current Windows drive (*)
# All forward '/' and back '\' slashes are treated identically except leading
# slash in forms (1) and (5).
# Forward slashes are simpler processed in Perl, do not require extra escaping
# for shell (unlike back slashes) and accepted by Windows native programs, so
# all functions return paths with only forward slashes.
# All returned paths don't contain any duplicated slashes, only single slashes
# are used as directory separators on output.
# On non-Windows platforms functions acts as transparent wrappers for similar
# Perl's functions or return unmodified string (depending on functionality),
# so all functions can be unconditionally used on all platforms.
#
# (*) CAUTION! Forms (4) and (5) are not recommended to use as they can be
# interpreted incorrectly in Perl and MSYS/Cygwin environment have low
# control on Windows current drive and Windows current path on specific
# drive.
package pathhelp;
use strict;
use warnings;
use Cwd 'abs_path';
BEGIN {
use base qw(Exporter);
our @EXPORT_OK = qw(
os_is_win
exe_ext
sys_native_abs_path
sys_native_current_path
build_sys_abs_path
);
}
#######################################################################
# Block for cached static variables
#
{
# Cached static variable, Perl 5.0-compatible.
my $is_win = $^O eq 'MSWin32'
|| $^O eq 'cygwin'
|| $^O eq 'msys';
# Returns boolean true if OS is any form of Windows.
sub os_is_win {
return $is_win;
}
# Cached static variable, Perl 5.0-compatible.
my $cygdrive_present;
# Returns boolean true if Windows drives mounted with '/cygdrive/' prefix.
sub drives_mounted_on_cygdrive {
return $cygdrive_present if defined $cygdrive_present;
$cygdrive_present = ((-e '/cygdrive/') && (-d '/cygdrive/')) ? 1 : 0;
return $cygdrive_present;
}
}
#######################################################################
# Returns current working directory in Windows format on Windows.
#
sub sys_native_current_path {
return Cwd::getcwd() if !os_is_win();
my $cur_dir;
if($^O eq 'MSWin32') {
$cur_dir = Cwd::getcwd();
}
else {
$cur_dir = Cygwin::posix_to_win_path(Cwd::getcwd());
}
$cur_dir =~ s{[/\\]+}{/}g;
return $cur_dir;
}
#######################################################################
# Converts given path to system native absolute path, i.e. to Windows
# absolute format on Windows platform. Both relative and absolute
# formats are supported for input.
#
sub sys_native_abs_path {
my ($path) = @_;
# Return untouched on non-Windows platforms.
return Cwd::abs_path($path) if !os_is_win();
# Do not process empty path.
return $path if ($path eq '');
my $res;
if($^O eq 'msys' || $^O eq 'cygwin') {
$res = Cygwin::posix_to_win_path(Cwd::abs_path($path));
}
elsif($path =~ m{^/(cygdrive/)?([a-z])/(.*)}) {
$res = uc($2) . ":/" . $3;
}
else {
$res = Cwd::abs_path($path);
}
$res =~ s{[/\\]+}{/}g;
return $res;
}
#######################################################################
# Converts given path to build system format absolute path, i.e. to
# MSYS/Cygwin POSIX-style absolute format on Windows platform. Both
# relative and absolute formats are supported for input.
#
sub build_sys_abs_path {
my ($path) = @_;
# Return untouched on non-Windows platforms.
return Cwd::abs_path($path) if !os_is_win();
my $res;
if($^O eq 'msys' || $^O eq 'cygwin') {
$res = Cygwin::win_to_posix_path($path, 1);
}
else {
$res = Cwd::abs_path($path);
if($res =~ m{^([A-Za-z]):(.*)}) {
$res = "/" . lc($1) . $2;
$res = '/cygdrive' . $res if(drives_mounted_on_cygdrive());
}
}
return $res;
}
#***************************************************************************
# Return file extension for executable files on this operating system
#
sub exe_ext {
my ($component, @arr) = @_;
if ($ENV{'CURL_TEST_EXE_EXT'}) {
return $ENV{'CURL_TEST_EXE_EXT'};
}
if ($ENV{'CURL_TEST_EXE_EXT_'.$component}) {
return $ENV{'CURL_TEST_EXE_EXT_'.$component};
}
if ($^O eq 'MSWin32' || $^O eq 'cygwin' || $^O eq 'msys' ||
$^O eq 'dos' || $^O eq 'os2') {
return '.exe';
}
return '';
}
1; # End of module