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
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Ivan Ivlev
bugzilla
Commits
e1109183
Commit
e1109183
authored
Jul 22, 2010
by
Max Kanat-Alexander
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 556579: Back out the patch from bug 554819, because it caused special
characters in quoted strings to be interpreted instead of passed along. r=LpSolit, a=LpSolit
parent
ddb5db35
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
4 deletions
+32
-4
Quicksearch.pm
Bugzilla/Search/Quicksearch.pm
+32
-4
No files found.
Bugzilla/Search/Quicksearch.pm
View file @
e1109183
...
...
@@ -30,8 +30,6 @@ use Bugzilla::Status;
use
Bugzilla::
Field
;
use
Bugzilla::
Util
;
use
Text::
ParseWords
qw(quotewords)
;
use
base
qw(Exporter)
;
@
Bugzilla::Search::Quicksearch::
EXPORT
=
qw(quicksearch)
;
...
...
@@ -149,7 +147,7 @@ sub quicksearch {
$searchstring
=~
s/\s+OR\s+/|/g
;
$searchstring
=~
s/\s+NOT\s+/ -/g
;
my
@words
=
quotewords
(
'\s+'
,
0
,
$searchstring
);
my
@words
=
splitString
(
$searchstring
);
_handle_status_and_resolution
(
\
@words
);
my
(
@unknownFields
,
%
ambiguous_fields
);
...
...
@@ -494,6 +492,36 @@ sub _handle_urls {
# Helpers
###########################################################################
# Split string on whitespace, retaining quoted strings as one
sub
splitString
{
my
$string
=
shift
;
my
@quoteparts
;
my
@parts
;
my
$i
=
0
;
# Now split on quote sign; be tolerant about unclosed quotes
@quoteparts
=
split
(
/"/
,
$string
);
foreach
my
$part
(
@quoteparts
)
{
# After every odd quote, quote special chars
$part
=
url_quote
(
$part
)
if
$i
++
%
2
;
}
# Join again
$string
=
join
(
'"'
,
@quoteparts
);
# Now split on unescaped whitespace
@parts
=
split
(
/\s+/
,
$string
);
foreach
(
@parts
)
{
# Protect plus signs from becoming a blank.
# If "+" appears as the first character, leave it alone
# as it has a special meaning. Strings which start with
# "+" must be quoted.
s/(?<!^)\+/%2B/g
;
# Remove quotes
s/"//g
;
}
return
@parts
;
}
# Expand found prefixes to states or resolutions
sub
matchPrefixes
{
my
$hr_states
=
shift
;
...
...
@@ -552,7 +580,7 @@ sub makeChart {
my
$cgi
=
Bugzilla
->
cgi
;
$cgi
->
param
(
"field$expr"
,
$field
);
$cgi
->
param
(
"type$expr"
,
$type
);
$cgi
->
param
(
"value$expr"
,
$value
);
$cgi
->
param
(
"value$expr"
,
url_decode
(
$value
)
);
}
1
;
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