Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
bugzilla
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
etersoft
bugzilla
Commits
71f44e68
Commit
71f44e68
authored
Jul 01, 2010
by
Max Kanat-Alexander
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 382398: Make checksetup.pl localized messages be output in the
console's charset r=timello, a=mkanat
parent
cbbcceb2
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
46 additions
and
9 deletions
+46
-9
Bugzilla.pm
Bugzilla.pm
+7
-2
Requirements.pm
Bugzilla/Install/Requirements.pm
+4
-0
Util.pm
Bugzilla/Install/Util.pm
+35
-1
checksetup.pl
checksetup.pl
+0
-6
No files found.
Bugzilla.pm
View file @
71f44e68
...
@@ -44,7 +44,7 @@ use Bugzilla::Extension;
...
@@ -44,7 +44,7 @@ use Bugzilla::Extension;
use
Bugzilla::
DB
;
use
Bugzilla::
DB
;
use
Bugzilla::Install::
Localconfig
qw(read_localconfig)
;
use
Bugzilla::Install::
Localconfig
qw(read_localconfig)
;
use
Bugzilla::Install::
Requirements
qw(OPTIONAL_MODULES)
;
use
Bugzilla::Install::
Requirements
qw(OPTIONAL_MODULES)
;
use
Bugzilla::Install::
Util
;
use
Bugzilla::Install::
Util
qw(init_console)
;
use
Bugzilla::
Template
;
use
Bugzilla::
Template
;
use
Bugzilla::
User
;
use
Bugzilla::
User
;
use
Bugzilla::
Error
;
use
Bugzilla::
Error
;
...
@@ -82,7 +82,12 @@ use constant SHUTDOWNHTML_EXIT_SILENTLY => qw(
...
@@ -82,7 +82,12 @@ use constant SHUTDOWNHTML_EXIT_SILENTLY => qw(
# Note that this is a raw subroutine, not a method, so $class isn't available.
# Note that this is a raw subroutine, not a method, so $class isn't available.
sub
init_page
{
sub
init_page
{
(
binmode
STDOUT
,
':utf8'
)
if
Bugzilla
->
params
->
{
'utf8'
};
if
(
Bugzilla
->
usage_mode
==
USAGE_MODE_CMDLINE
)
{
init_console
();
}
elsif
(
Bugzilla
->
params
->
{
'utf8'
})
{
binmode
STDOUT
,
':utf8'
;
}
if
(
$
{
^
TAINT
})
{
if
(
$
{
^
TAINT
})
{
# Some environment variables are not taint safe
# Some environment variables are not taint safe
...
...
Bugzilla/Install/Requirements.pm
View file @
71f44e68
...
@@ -541,6 +541,10 @@ sub have_vers {
...
@@ -541,6 +541,10 @@ sub have_vers {
my
$wanted
=
$params
->
{
version
};
my
$wanted
=
$params
->
{
version
};
eval
"require $module;"
;
eval
"require $module;"
;
# Don't let loading a module change the output-encoding of STDOUT
# or STDERR. (CGI.pm tries to set "binmode" on these file handles when
# it's loaded, and other modules may do the same in the future.)
Bugzilla::Install::Util::
set_output_encoding
();
# VERSION is provided by UNIVERSAL::, and can be called even if
# VERSION is provided by UNIVERSAL::, and can be called even if
# the module isn't loaded.
# the module isn't loaded.
...
...
Bugzilla/Install/Util.pm
View file @
71f44e68
...
@@ -28,11 +28,13 @@ use strict;
...
@@ -28,11 +28,13 @@ use strict;
use
Bugzilla::
Constants
;
use
Bugzilla::
Constants
;
use
Encode
;
use
File::
Basename
;
use
File::
Basename
;
use
POSIX
qw(setlocale LC_CTYPE)
;
use
POSIX
qw(setlocale LC_CTYPE)
;
use
Safe
;
use
Safe
;
use
Scalar::
Util
qw(tainted)
;
use
Scalar::
Util
qw(tainted)
;
use
Term::
ANSIColor
qw(colored)
;
use
Term::
ANSIColor
qw(colored)
;
use
PerlIO
;
use
base
qw(Exporter)
;
use
base
qw(Exporter)
;
our
@EXPORT_OK
=
qw(
our
@EXPORT_OK
=
qw(
...
@@ -47,7 +49,6 @@ our @EXPORT_OK = qw(
...
@@ -47,7 +49,6 @@ our @EXPORT_OK = qw(
include_languages
include_languages
template_include_path
template_include_path
vers_cmp
vers_cmp
get_console_locale
init_console
init_console
)
;
)
;
...
@@ -569,11 +570,44 @@ sub get_console_locale {
...
@@ -569,11 +570,44 @@ sub get_console_locale {
return
$locale
;
return
$locale
;
}
}
sub
set_output_encoding
{
# If we've already set an encoding layer on STDOUT, don't
# add another one.
my
@stdout_layers
=
PerlIO::
get_layers
(
STDOUT
);
return
if
grep
(
/^encoding/
,
@stdout_layers
);
my
$encoding
;
if
(
ON_WINDOWS
and
eval
{
require
Win32::
Console
})
{
# Although setlocale() works on Windows, it doesn't always return
# the current *console's* encoding. So we use OutputCP here instead,
# when we can.
$encoding
=
Win32::Console::
OutputCP
();
}
else
{
my
$locale
=
setlocale
(
LC_CTYPE
);
if
(
$locale
=~
/\.([^\.]+)$/
)
{
$encoding
=
$1
;
}
}
$encoding
=
"cp$encoding"
if
ON_WINDOWS
;
$encoding
=
Encode::
resolve_alias
(
$encoding
)
if
$encoding
;
if
(
$encoding
and
$encoding
!~
/utf-8/i
)
{
binmode
STDOUT
,
":encoding($encoding)"
;
binmode
STDERR
,
":encoding($encoding)"
;
}
else
{
binmode
STDOUT
,
':utf8'
;
binmode
STDERR
,
':utf8'
;
}
}
sub
init_console
{
sub
init_console
{
eval
{
ON_WINDOWS
&&
require
Win32::Console::
ANSI
;
};
eval
{
ON_WINDOWS
&&
require
Win32::Console::
ANSI
;
};
$ENV
{
'ANSI_COLORS_DISABLED'
}
=
1
if
(
$@
||
!-
t
*
STDOUT
);
$ENV
{
'ANSI_COLORS_DISABLED'
}
=
1
if
(
$@
||
!-
t
*
STDOUT
);
$SIG
{
__DIE__
}
=
\&
_console_die
;
$SIG
{
__DIE__
}
=
\&
_console_die
;
prevent_windows_dialog_boxes
();
prevent_windows_dialog_boxes
();
set_output_encoding
();
}
}
sub
_console_die
{
sub
_console_die
{
...
...
checksetup.pl
View file @
71f44e68
...
@@ -62,12 +62,6 @@ use Bugzilla::Install::Util qw(install_string get_version_and_os init_console);
...
@@ -62,12 +62,6 @@ use Bugzilla::Install::Util qw(install_string get_version_and_os init_console);
# When we're running at the command line, we need to pick the right
# When we're running at the command line, we need to pick the right
# language before ever displaying any string.
# language before ever displaying any string.
init_console
();
init_console
();
# Required for displaying strings from install_string, which are always
# in UTF-8, in every language. For other scripts, Bugzilla::init_page
# handles this, but here we just need to assume that checksetup.pl output
# is always UTF-8 in order for install_string to work properly in other
# languages.
binmode
STDOUT
,
':utf8'
;
my
%
switch
;
my
%
switch
;
GetOptions
(
\%
switch
,
'help|h|?'
,
'check-modules'
,
'no-templates|t'
,
GetOptions
(
\%
switch
,
'help|h|?'
,
'check-modules'
,
'no-templates|t'
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment