Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

_find_matching_zoneinfo_file returns filename only, causing _from_etc_localtime to fail #14

Open
autarch opened this issue Nov 12, 2016 · 1 comment
Labels

Comments

@autarch
Copy link
Member

autarch commented Nov 12, 2016

Migrated from rt.cpan.org #14874 (status was 'stalled')

Requestors:

From on 2005-10-02 05:19:51:

DateTime::TimeZone version 0.36
Perl version 5.005_03
FreeBSD 4.10

On line 151 of my version of DateTime::TimeZone::Local, the variable $real_name is assigned the value of $_ in the subroutine _find_matching_zoneinfo_file. On my system, that is only the filename without any directory component. Thus a timezone of "America/Los_Angeles" only assigns the value "Los_Angeles" to $real_name. When it gets back up into _from_etc_localtime, "Los_Angeles" is not a valid time zone and therefore DateTime::TimeZone->new() fails on line 71.

To fix this, I modified line 151 to read:

$real_name = $File::Find::name;

This returns the file path in $real_name, ultimately ending up with the correct timezone of "America/Los_Angeles" in _from_etc_localtime.

I have not tested version 0.37, but it appears the line in question has not changed in that version.

My version of File::Find does not seem to contain a version number.

@autarch
Copy link
Member Author

autarch commented Nov 12, 2016

From [email protected] (@autarch) on 2006-05-21 17:53:03:

On Sun Oct 02 01:19:51 2005, guest wrote:

DateTime::TimeZone version 0.36
Perl version 5.005_03
FreeBSD 4.10

On line 151 of my version of DateTime::TimeZone::Local, the variable
$real_name is assigned the value of $_ in the subroutine
_find_matching_zoneinfo_file. On my system, that is only the
filename without any directory component. Thus a timezone of
"America/Los_Angeles" only assigns the value "Los_Angeles" to
$real_name. When it gets back up into _from_etc_localtime,
"Los_Angeles" is not a valid time zone and therefore
DateTime::TimeZone->new() fails on line 71.

To fix this, I modified line 151 to read:

$real_name = $File::Find::name;

This returns the file path in $real_name, ultimately ending up with
the correct timezone of "America/Los_Angeles" in
_from_etc_localtime.

I have not tested version 0.37, but it appears the line in question
has not changed in that version.

My version of File::Find does not seem to contain a version number.

This should have been fixed a while back when I changed the code to
call File::Find with the no_chdir option. In that case, the value of $_
and $File::Find::name should be the same inside the callback, per the
File::Find docs. However, that change was back in 0.2507.

Are you still seeing this problem?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Development

No branches or pull requests

1 participant