Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
fe9e1390
Commit
fe9e1390
authored
Dec 28, 2002
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
postreview fix (SCRUM)
fixed layout
parent
e3ba2564
Changes
23
Hide whitespace changes
Inline
Side-by-side
Showing
23 changed files
with
137 additions
and
210 deletions
+137
-210
sql/filesort.cc
sql/filesort.cc
+1
-1
sql/gstream.cc
sql/gstream.cc
+20
-18
sql/item.cc
sql/item.cc
+11
-21
sql/item.h
sql/item.h
+3
-3
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+1
-29
sql/item_cmpfunc.h
sql/item_cmpfunc.h
+2
-2
sql/item_func.h
sql/item_func.h
+1
-1
sql/item_row.h
sql/item_row.h
+1
-1
sql/item_strfunc.cc
sql/item_strfunc.cc
+3
-3
sql/item_subselect.cc
sql/item_subselect.cc
+37
-76
sql/item_subselect.h
sql/item_subselect.h
+7
-6
sql/nt_servc.cc
sql/nt_servc.cc
+16
-16
sql/opt_range.cc
sql/opt_range.cc
+6
-5
sql/password.c
sql/password.c
+1
-1
sql/spatial.cc
sql/spatial.cc
+3
-3
sql/sql_help.cc
sql/sql_help.cc
+7
-7
sql/sql_lex.cc
sql/sql_lex.cc
+3
-3
sql/sql_olap.cc
sql/sql_olap.cc
+6
-6
sql/sql_select.cc
sql/sql_select.cc
+1
-1
sql/sql_show.cc
sql/sql_show.cc
+2
-2
sql/sql_string.cc
sql/sql_string.cc
+1
-1
sql/sql_table.cc
sql/sql_table.cc
+1
-1
sql/stacktrace.c
sql/stacktrace.c
+3
-3
No files found.
sql/filesort.cc
View file @
fe9e1390
...
@@ -496,7 +496,7 @@ static void make_sortkey(register SORTPARAM *param,
...
@@ -496,7 +496,7 @@ static void make_sortkey(register SORTPARAM *param,
length
=
sort_field
->
length
;
length
=
sort_field
->
length
;
}
}
#ifdef USE_STRCOLL
#ifdef USE_STRCOLL
if
(
use_strnxfrm
(
cs
))
if
(
use_strnxfrm
(
cs
))
{
{
if
(
item
->
binary
())
if
(
item
->
binary
())
{
{
...
...
sql/gstream.cc
View file @
fe9e1390
...
@@ -3,36 +3,38 @@
...
@@ -3,36 +3,38 @@
int
GTextReadStream
::
get_next_toc_type
()
const
int
GTextReadStream
::
get_next_toc_type
()
const
{
{
const
char
*
cur
=
m_cur
;
const
char
*
cur
=
m_cur
;
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
{
{
cur
++
;
cur
++
;
}
}
if
(
!
(
*
cur
))
if
(
!
(
*
cur
))
{
{
return
eostream
;
return
eostream
;
}
}
if
(((
*
cur
>=
'a'
)
&&
(
*
cur
<=
'z'
))
||
((
*
cur
>=
'A'
)
&&
(
*
cur
<=
'Z'
))
||
(
*
cur
==
'_'
))
if
(((
*
cur
>=
'a'
)
&&
(
*
cur
<=
'z'
))
||
((
*
cur
>=
'A'
)
&&
(
*
cur
<=
'Z'
))
||
(
*
cur
==
'_'
))
{
{
return
word
;
return
word
;
}
}
if
(((
*
cur
>=
'0'
)
&&
(
*
cur
<=
'9'
))
||
(
*
cur
==
'-'
)
||
(
*
cur
==
'+'
)
||
(
*
cur
==
'.'
))
if
(((
*
cur
>=
'0'
)
&&
(
*
cur
<=
'9'
))
||
(
*
cur
==
'-'
)
||
(
*
cur
==
'+'
)
||
(
*
cur
==
'.'
))
{
{
return
numeric
;
return
numeric
;
}
}
if
(
*
cur
==
'('
)
if
(
*
cur
==
'('
)
{
{
return
l_bra
;
return
l_bra
;
}
}
if
(
*
cur
==
')'
)
if
(
*
cur
==
')'
)
{
{
return
r_bra
;
return
r_bra
;
}
}
if
(
*
cur
==
','
)
if
(
*
cur
==
','
)
{
{
return
comma
;
return
comma
;
}
}
...
@@ -43,28 +45,28 @@ int GTextReadStream::get_next_toc_type() const
...
@@ -43,28 +45,28 @@ int GTextReadStream::get_next_toc_type() const
const
char
*
GTextReadStream
::
get_next_word
(
int
*
word_len
)
const
char
*
GTextReadStream
::
get_next_word
(
int
*
word_len
)
{
{
const
char
*
cur
=
m_cur
;
const
char
*
cur
=
m_cur
;
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
{
{
cur
++
;
cur
++
;
}
}
m_last_text_position
=
cur
;
m_last_text_position
=
cur
;
if
(
!
(
*
cur
))
if
(
!
(
*
cur
))
{
{
return
0
;
return
0
;
}
}
const
char
*
wd_start
=
cur
;
const
char
*
wd_start
=
cur
;
if
(((
*
cur
<
'a'
)
||
(
*
cur
>
'z'
))
&&
((
*
cur
<
'A'
)
||
(
*
cur
>
'Z'
))
&&
(
*
cur
!=
'_'
))
if
(((
*
cur
<
'a'
)
||
(
*
cur
>
'z'
))
&&
((
*
cur
<
'A'
)
||
(
*
cur
>
'Z'
))
&&
(
*
cur
!=
'_'
))
{
{
return
NULL
;
return
NULL
;
}
}
++
cur
;
++
cur
;
while
(((
*
cur
>=
'a'
)
&&
(
*
cur
<=
'z'
))
||
((
*
cur
>=
'A'
)
&&
(
*
cur
<=
'Z'
))
||
(
*
cur
==
'_'
)
||
while
(((
*
cur
>=
'a'
)
&&
(
*
cur
<=
'z'
))
||
((
*
cur
>=
'A'
)
&&
(
*
cur
<=
'Z'
)
)
||
((
*
cur
>=
'0'
)
&&
(
*
cur
<=
'9'
)))
(
*
cur
==
'_'
)
||
((
*
cur
>=
'0'
)
&&
(
*
cur
<=
'9'
)))
{
{
++
cur
;
++
cur
;
}
}
...
@@ -79,19 +81,19 @@ const char *GTextReadStream::get_next_word(int *word_len)
...
@@ -79,19 +81,19 @@ const char *GTextReadStream::get_next_word(int *word_len)
int
GTextReadStream
::
get_next_number
(
double
*
d
)
int
GTextReadStream
::
get_next_number
(
double
*
d
)
{
{
const
char
*
cur
=
m_cur
;
const
char
*
cur
=
m_cur
;
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
{
{
cur
++
;
cur
++
;
}
}
m_last_text_position
=
cur
;
m_last_text_position
=
cur
;
if
(
!
(
*
cur
))
if
(
!
(
*
cur
))
{
{
set_error_msg
(
"Numeric constant expected"
);
set_error_msg
(
"Numeric constant expected"
);
return
1
;
return
1
;
}
}
if
(((
*
cur
<
'0'
)
||
(
*
cur
>
'9'
))
&&
(
*
cur
!=
'-'
)
&&
(
*
cur
!=
'+'
)
&&
(
*
cur
!=
'.'
))
if
(((
*
cur
<
'0'
)
||
(
*
cur
>
'9'
))
&&
(
*
cur
!=
'-'
)
&&
(
*
cur
!=
'+'
)
&&
(
*
cur
!=
'.'
))
{
{
set_error_msg
(
"Numeric constant expected"
);
set_error_msg
(
"Numeric constant expected"
);
return
1
;
return
1
;
...
@@ -101,7 +103,7 @@ int GTextReadStream::get_next_number(double *d)
...
@@ -101,7 +103,7 @@ int GTextReadStream::get_next_number(double *d)
*
d
=
strtod
(
cur
,
&
endptr
);
*
d
=
strtod
(
cur
,
&
endptr
);
if
(
endptr
)
if
(
endptr
)
{
{
m_cur
=
endptr
;
m_cur
=
endptr
;
}
}
...
@@ -112,11 +114,11 @@ int GTextReadStream::get_next_number(double *d)
...
@@ -112,11 +114,11 @@ int GTextReadStream::get_next_number(double *d)
char
GTextReadStream
::
get_next_symbol
()
char
GTextReadStream
::
get_next_symbol
()
{
{
const
char
*
cur
=
m_cur
;
const
char
*
cur
=
m_cur
;
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
while
((
*
cur
)
&&
(
strchr
(
"
\t\r\n
"
,
*
cur
)))
{
{
cur
++
;
cur
++
;
}
}
if
(
!
(
*
cur
))
if
(
!
(
*
cur
))
{
{
return
0
;
return
0
;
}
}
...
...
sql/item.cc
View file @
fe9e1390
...
@@ -502,18 +502,17 @@ bool Item_ref_on_list_position::fix_fields(THD *thd,
...
@@ -502,18 +502,17 @@ bool Item_ref_on_list_position::fix_fields(THD *thd,
struct
st_table_list
*
tables
,
struct
st_table_list
*
tables
,
Item
**
reference
)
Item
**
reference
)
{
{
ref
=
0
;
List_iterator
<
Item
>
li
(
list
);
List_iterator
<
Item
>
li
(
list
);
Item
*
item
;
Item
*
item
;
uint
i
=
0
;
for
(
uint
i
=
0
;
(
item
=
li
++
)
&&
i
<
pos
;
i
++
);
for
(;
(
item
=
li
++
)
&&
i
<
pos
;
i
++
);
if
(
item
)
if
(
i
==
pos
)
{
{
ref
=
li
.
ref
();
ref
=
li
.
ref
();
return
Item_ref_null_helper
::
fix_fields
(
thd
,
tables
,
reference
);
return
Item_ref_null_helper
::
fix_fields
(
thd
,
tables
,
reference
);
}
}
else
else
{
{
ref
=
0
;
my_error
(
ER_CARDINALITY_COL
,
MYF
(
0
),
pos
);
my_error
(
ER_CARDINALITY_COL
,
MYF
(
0
),
pos
);
return
1
;
return
1
;
}
}
...
@@ -1280,29 +1279,20 @@ longlong Item_cache_str::val_int()
...
@@ -1280,29 +1279,20 @@ longlong Item_cache_str::val_int()
bool
Item_cache_row
::
allocate
(
uint
num
)
bool
Item_cache_row
::
allocate
(
uint
num
)
{
{
n
=
num
;
item_count
=
num
;
THD
*
thd
=
current_thd
;
THD
*
thd
=
current_thd
;
if
(
!
(
values
=
(
Item_cache
**
)
thd
->
calloc
(
sizeof
(
Item_cache
*
)
*
n
)))
return
(
!
(
values
=
{
(
Item_cache
**
)
thd
->
calloc
(
sizeof
(
Item_cache
*
)
*
item_count
)));
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
1
;
}
return
0
;
}
}
bool
Item_cache_row
::
setup
(
Item
*
item
)
bool
Item_cache_row
::
setup
(
Item
*
item
)
{
{
if
(
!
values
&&
allocate
(
item
->
cols
()))
if
(
!
values
&&
allocate
(
item
->
cols
()))
return
1
;
return
1
;
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
for
(
uint
i
=
0
;
i
<
item_count
;
i
++
)
{
{
if
(
!
(
values
[
i
]
=
Item_cache
::
get_cache
(
item
->
el
(
i
)
->
result_type
())))
if
(
!
(
values
[
i
]
=
Item_cache
::
get_cache
(
item
->
el
(
i
)
->
result_type
())))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
1
;
return
1
;
}
values
[
i
]
->
setup
(
item
->
el
(
i
));
values
[
i
]
->
setup
(
item
->
el
(
i
));
}
}
return
0
;
return
0
;
...
@@ -1312,7 +1302,7 @@ void Item_cache_row::store(Item * item)
...
@@ -1312,7 +1302,7 @@ void Item_cache_row::store(Item * item)
{
{
null_value
=
0
;
null_value
=
0
;
item
->
bring_value
();
item
->
bring_value
();
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
for
(
uint
i
=
0
;
i
<
item_count
;
i
++
)
{
{
values
[
i
]
->
store
(
item
->
el
(
i
));
values
[
i
]
->
store
(
item
->
el
(
i
));
null_value
|=
values
[
i
]
->
null_value
;
null_value
|=
values
[
i
]
->
null_value
;
...
@@ -1330,7 +1320,7 @@ void Item_cache_row::illegal_method_call(const char *method)
...
@@ -1330,7 +1320,7 @@ void Item_cache_row::illegal_method_call(const char *method)
bool
Item_cache_row
::
check_cols
(
uint
c
)
bool
Item_cache_row
::
check_cols
(
uint
c
)
{
{
if
(
c
!=
n
)
if
(
c
!=
item_count
)
{
{
my_error
(
ER_CARDINALITY_COL
,
MYF
(
0
),
c
);
my_error
(
ER_CARDINALITY_COL
,
MYF
(
0
),
c
);
return
1
;
return
1
;
...
@@ -1340,7 +1330,7 @@ bool Item_cache_row::check_cols(uint c)
...
@@ -1340,7 +1330,7 @@ bool Item_cache_row::check_cols(uint c)
bool
Item_cache_row
::
null_inside
()
bool
Item_cache_row
::
null_inside
()
{
{
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
for
(
uint
i
=
0
;
i
<
item_count
;
i
++
)
{
{
if
(
values
[
i
]
->
cols
()
>
1
)
if
(
values
[
i
]
->
cols
()
>
1
)
{
{
...
@@ -1359,7 +1349,7 @@ bool Item_cache_row::null_inside()
...
@@ -1359,7 +1349,7 @@ bool Item_cache_row::null_inside()
void
Item_cache_row
::
bring_value
()
void
Item_cache_row
::
bring_value
()
{
{
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
for
(
uint
i
=
0
;
i
<
item_count
;
i
++
)
values
[
i
]
->
bring_value
();
values
[
i
]
->
bring_value
();
return
;
return
;
}
}
...
...
sql/item.h
View file @
fe9e1390
...
@@ -731,9 +731,9 @@ class Item_cache_str: public Item_cache
...
@@ -731,9 +731,9 @@ class Item_cache_str: public Item_cache
class
Item_cache_row
:
public
Item_cache
class
Item_cache_row
:
public
Item_cache
{
{
Item_cache
**
values
;
Item_cache
**
values
;
uint
n
;
uint
item_count
;
public:
public:
Item_cache_row
()
:
values
(
0
),
n
(
2
)
{
fixed
=
1
;
null_value
=
1
;
}
Item_cache_row
()
:
values
(
0
),
item_count
(
2
)
{
fixed
=
1
;
null_value
=
1
;
}
/*
/*
'allocate' used only in row transformer, to preallocate space for row
'allocate' used only in row transformer, to preallocate space for row
...
@@ -768,7 +768,7 @@ class Item_cache_row: public Item_cache
...
@@ -768,7 +768,7 @@ class Item_cache_row: public Item_cache
};
};
enum
Item_result
result_type
()
const
{
return
ROW_RESULT
;
}
enum
Item_result
result_type
()
const
{
return
ROW_RESULT
;
}
uint
cols
()
{
return
n
;
}
uint
cols
()
{
return
item_count
;
}
Item
*
el
(
uint
i
)
{
return
values
[
i
];
}
Item
*
el
(
uint
i
)
{
return
values
[
i
];
}
Item
**
addr
(
uint
i
)
{
return
(
Item
**
)
(
values
+
i
);
}
Item
**
addr
(
uint
i
)
{
return
(
Item
**
)
(
values
+
i
);
}
bool
check_cols
(
uint
c
);
bool
check_cols
(
uint
c
);
...
...
sql/item_cmpfunc.cc
View file @
fe9e1390
...
@@ -153,11 +153,7 @@ int Arg_comparator::set_compare_func(Item_bool_func2 *item, Item_result type)
...
@@ -153,11 +153,7 @@ int Arg_comparator::set_compare_func(Item_bool_func2 *item, Item_result type)
comparators
[
i
].
set_cmp_func
(
owner
,
(
*
a
)
->
addr
(
i
),
(
*
b
)
->
addr
(
i
));
comparators
[
i
].
set_cmp_func
(
owner
,
(
*
a
)
->
addr
(
i
),
(
*
b
)
->
addr
(
i
));
}
}
else
else
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
1
;
return
1
;
}
}
}
return
0
;
return
0
;
}
}
...
@@ -276,11 +272,7 @@ int Arg_comparator::compare_e_row()
...
@@ -276,11 +272,7 @@ int Arg_comparator::compare_e_row()
bool
Item_in_optimizer
::
preallocate_row
()
bool
Item_in_optimizer
::
preallocate_row
()
{
{
if
((
cache
=
Item_cache
::
get_cache
(
ROW_RESULT
)))
return
(
!
(
cache
=
Item_cache
::
get_cache
(
ROW_RESULT
)));
return
0
;
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
1
;
}
}
bool
Item_in_optimizer
::
fix_fields
(
THD
*
thd
,
struct
st_table_list
*
tables
,
bool
Item_in_optimizer
::
fix_fields
(
THD
*
thd
,
struct
st_table_list
*
tables
,
...
@@ -296,11 +288,7 @@ bool Item_in_optimizer::fix_fields(THD *thd, struct st_table_list *tables,
...
@@ -296,11 +288,7 @@ bool Item_in_optimizer::fix_fields(THD *thd, struct st_table_list *tables,
used_tables_cache
=
args
[
0
]
->
used_tables
();
used_tables_cache
=
args
[
0
]
->
used_tables
();
const_item_cache
=
args
[
0
]
->
const_item
();
const_item_cache
=
args
[
0
]
->
const_item
();
if
(
!
cache
&&
!
(
cache
=
Item_cache
::
get_cache
(
args
[
0
]
->
result_type
())))
if
(
!
cache
&&
!
(
cache
=
Item_cache
::
get_cache
(
args
[
0
]
->
result_type
())))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
1
;
return
1
;
}
cache
->
setup
(
args
[
0
]);
cache
->
setup
(
args
[
0
]);
if
(
args
[
1
]
->
fix_fields
(
thd
,
tables
,
args
))
if
(
args
[
1
]
->
fix_fields
(
thd
,
tables
,
args
))
return
1
;
return
1
;
...
@@ -1246,18 +1234,10 @@ void cmp_item_row::store_value(Item *item)
...
@@ -1246,18 +1234,10 @@ void cmp_item_row::store_value(Item *item)
item
->
null_value
|=
item
->
el
(
i
)
->
null_value
;
item
->
null_value
|=
item
->
el
(
i
)
->
null_value
;
}
}
else
else
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
;
return
;
}
}
}
else
else
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
;
return
;
}
}
}
void
cmp_item_row
::
store_value_by_template
(
cmp_item
*
t
,
Item
*
item
)
void
cmp_item_row
::
store_value_by_template
(
cmp_item
*
t
,
Item
*
item
)
...
@@ -1281,18 +1261,10 @@ void cmp_item_row::store_value_by_template(cmp_item *t, Item *item)
...
@@ -1281,18 +1261,10 @@ void cmp_item_row::store_value_by_template(cmp_item *t, Item *item)
item
->
null_value
|=
item
->
el
(
i
)
->
null_value
;
item
->
null_value
|=
item
->
el
(
i
)
->
null_value
;
}
}
else
else
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
;
return
;
}
}
}
else
else
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
;
return
;
}
}
}
int
cmp_item_row
::
cmp
(
Item
*
arg
)
int
cmp_item_row
::
cmp
(
Item
*
arg
)
...
...
sql/item_cmpfunc.h
View file @
fe9e1390
...
@@ -544,8 +544,8 @@ class cmp_item_row :public cmp_item
...
@@ -544,8 +544,8 @@ class cmp_item_row :public cmp_item
cmp_item_row
()
:
comparators
(
0
),
n
(
0
)
{}
cmp_item_row
()
:
comparators
(
0
),
n
(
0
)
{}
~
cmp_item_row
()
~
cmp_item_row
()
{
{
if
(
comparators
)
if
(
comparators
)
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
if
(
comparators
[
i
])
if
(
comparators
[
i
])
delete
comparators
[
i
];
delete
comparators
[
i
];
}
}
...
...
sql/item_func.h
View file @
fe9e1390
...
@@ -995,7 +995,7 @@ class Item_func_match :public Item_real_func
...
@@ -995,7 +995,7 @@ class Item_func_match :public Item_real_func
{
{
ft_handler
->
please
->
close_search
(
ft_handler
);
ft_handler
->
please
->
close_search
(
ft_handler
);
ft_handler
=
0
;
ft_handler
=
0
;
if
(
join_key
)
if
(
join_key
)
table
->
file
->
ft_handler
=
0
;
table
->
file
->
ft_handler
=
0
;
table
->
fulltext_searched
=
0
;
table
->
fulltext_searched
=
0
;
}
}
...
...
sql/item_row.h
View file @
fe9e1390
...
@@ -33,7 +33,7 @@ class Item_row: public Item
...
@@ -33,7 +33,7 @@ class Item_row: public Item
~
Item_row
()
~
Item_row
()
{
{
if
(
array_holder
&&
items
)
if
(
array_holder
&&
items
)
sql_element_free
(
items
);
sql_element_free
(
items
);
}
}
...
...
sql/item_strfunc.cc
View file @
fe9e1390
...
@@ -1961,7 +1961,7 @@ String *Item_func_conv_charset::val_str(String *str)
...
@@ -1961,7 +1961,7 @@ String *Item_func_conv_charset::val_str(String *str)
d0
=
d
=
(
unsigned
char
*
)
str
->
ptr
();
d0
=
d
=
(
unsigned
char
*
)
str
->
ptr
();
de
=
d
+
dmaxlen
;
de
=
d
+
dmaxlen
;
while
(
s
<
se
&&
d
<
de
){
while
(
s
<
se
&&
d
<
de
){
cnvres
=
from
->
mb_wc
(
from
,
&
wc
,
s
,
se
);
cnvres
=
from
->
mb_wc
(
from
,
&
wc
,
s
,
se
);
if
(
cnvres
>
0
)
if
(
cnvres
>
0
)
...
@@ -2035,7 +2035,7 @@ String *Item_func_conv_charset3::val_str(String *str)
...
@@ -2035,7 +2035,7 @@ String *Item_func_conv_charset3::val_str(String *str)
d0
=
d
=
(
unsigned
char
*
)
str
->
ptr
();
d0
=
d
=
(
unsigned
char
*
)
str
->
ptr
();
de
=
d
+
dmaxlen
;
de
=
d
+
dmaxlen
;
while
(
s
<
se
&&
d
<
de
){
while
(
s
<
se
&&
d
<
de
){
cnvres
=
from_charset
->
mb_wc
(
from_charset
,
&
wc
,
s
,
se
);
cnvres
=
from_charset
->
mb_wc
(
from_charset
,
&
wc
,
s
,
se
);
if
(
cnvres
>
0
)
if
(
cnvres
>
0
)
...
@@ -2655,7 +2655,7 @@ String *Item_func_spatial_collection::val_str(String *str)
...
@@ -2655,7 +2655,7 @@ String *Item_func_spatial_collection::val_str(String *str)
null_value
=
1
;
null_value
=
1
;
str
->
length
(
0
);
str
->
length
(
0
);
if
(
str
->
reserve
(
9
,
512
))
if
(
str
->
reserve
(
9
,
512
))
return
0
;
return
0
;
str
->
q_append
((
char
)
Geometry
::
wkbNDR
);
str
->
q_append
((
char
)
Geometry
::
wkbNDR
);
...
...
sql/item_subselect.cc
View file @
fe9e1390
...
@@ -32,6 +32,11 @@ SUBSELECT TODO:
...
@@ -32,6 +32,11 @@ SUBSELECT TODO:
#include "mysql_priv.h"
#include "mysql_priv.h"
#include "sql_select.h"
#include "sql_select.h"
inline
Item
*
and_items
(
Item
*
cond
,
Item
*
item
)
{
return
(
cond
?
(
new
Item_cond_and
(
cond
,
item
))
:
item
);
}
Item_subselect
::
Item_subselect
()
:
Item_subselect
::
Item_subselect
()
:
Item_result_field
(),
engine_owner
(
1
),
value_assigned
(
0
),
substitution
(
0
),
Item_result_field
(),
engine_owner
(
1
),
value_assigned
(
0
),
substitution
(
0
),
have_to_be_excluded
(
0
)
have_to_be_excluded
(
0
)
...
@@ -51,7 +56,7 @@ void Item_subselect::init(THD *thd, st_select_lex *select_lex,
...
@@ -51,7 +56,7 @@ void Item_subselect::init(THD *thd, st_select_lex *select_lex,
DBUG_ENTER
(
"Item_subselect::init"
);
DBUG_ENTER
(
"Item_subselect::init"
);
DBUG_PRINT
(
"subs"
,
(
"select_lex 0x%xl"
,
(
ulong
)
select_lex
));
DBUG_PRINT
(
"subs"
,
(
"select_lex 0x%xl"
,
(
ulong
)
select_lex
));
select_transformer
(
select_lex
->
master_unit
());
select_transformer
(
thd
,
select_lex
->
master_unit
());
if
(
select_lex
->
next_select
())
if
(
select_lex
->
next_select
())
engine
=
new
subselect_union_engine
(
thd
,
select_lex
->
master_unit
(),
result
,
engine
=
new
subselect_union_engine
(
thd
,
select_lex
->
master_unit
(),
result
,
this
);
this
);
...
@@ -67,7 +72,7 @@ Item_subselect::~Item_subselect()
...
@@ -67,7 +72,7 @@ Item_subselect::~Item_subselect()
delete
engine
;
delete
engine
;
}
}
void
Item_subselect
::
select_transformer
(
st_select_lex_unit
*
unit
)
void
Item_subselect
::
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
)
{
{
DBUG_ENTER
(
"Item_subselect::select_transformer"
);
DBUG_ENTER
(
"Item_subselect::select_transformer"
);
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
...
@@ -146,7 +151,8 @@ void Item_singlerow_subselect::reset()
...
@@ -146,7 +151,8 @@ void Item_singlerow_subselect::reset()
value
->
null_value
=
1
;
value
->
null_value
=
1
;
}
}
void
Item_singlerow_subselect
::
select_transformer
(
st_select_lex_unit
*
unit
)
void
Item_singlerow_subselect
::
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
)
{
{
SELECT_LEX
*
select_lex
=
unit
->
first_select
();
SELECT_LEX
*
select_lex
=
unit
->
first_select
();
...
@@ -155,7 +161,6 @@ void Item_singlerow_subselect::select_transformer(st_select_lex_unit *unit)
...
@@ -155,7 +161,6 @@ void Item_singlerow_subselect::select_transformer(st_select_lex_unit *unit)
{
{
have_to_be_excluded
=
1
;
have_to_be_excluded
=
1
;
THD
*
thd
=
current_thd
;
if
(
thd
->
lex
.
describe
)
if
(
thd
->
lex
.
describe
)
{
{
char
warn_buff
[
MYSQL_ERRMSG_SIZE
];
char
warn_buff
[
MYSQL_ERRMSG_SIZE
];
...
@@ -178,18 +183,10 @@ void Item_singlerow_subselect::select_transformer(st_select_lex_unit *unit)
...
@@ -178,18 +183,10 @@ void Item_singlerow_subselect::select_transformer(st_select_lex_unit *unit)
cond
=
select_lex
->
having
;
cond
=
select_lex
->
having
;
else
else
if
(
!
(
cond
=
new
Item_cond_and
(
select_lex
->
having
,
select_lex
->
where
)))
if
(
!
(
cond
=
new
Item_cond_and
(
select_lex
->
having
,
select_lex
->
where
)))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
;
return
;
}
if
(
!
(
substitution
=
new
Item_func_if
(
cond
,
substitution
,
if
(
!
(
substitution
=
new
Item_func_if
(
cond
,
substitution
,
new
Item_null
())))
new
Item_null
())))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
;
return
;
}
}
}
}
}
}
}
...
@@ -210,21 +207,13 @@ void Item_singlerow_subselect::fix_length_and_dec()
...
@@ -210,21 +207,13 @@ void Item_singlerow_subselect::fix_length_and_dec()
{
{
engine
->
fix_length_and_dec
(
row
=
&
value
);
engine
->
fix_length_and_dec
(
row
=
&
value
);
if
(
!
(
value
=
Item_cache
::
get_cache
(
engine
->
type
())))
if
(
!
(
value
=
Item_cache
::
get_cache
(
engine
->
type
())))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
;
return
;
}
}
}
else
else
{
{
THD
*
thd
=
current_thd
;
THD
*
thd
=
current_thd
;
if
(
!
(
row
=
(
Item_cache
**
)
thd
->
alloc
(
sizeof
(
Item_cache
*
)
*
max_columns
)))
if
(
!
(
row
=
(
Item_cache
**
)
thd
->
alloc
(
sizeof
(
Item_cache
*
)
*
max_columns
)))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
thd
->
fatal_error
=
1
;
return
;
return
;
}
engine
->
fix_length_and_dec
(
row
);
engine
->
fix_length_and_dec
(
row
);
value
=
*
row
;
value
=
*
row
;
}
}
...
@@ -443,7 +432,8 @@ Item_allany_subselect::Item_allany_subselect(Item_allany_subselect *item):
...
@@ -443,7 +432,8 @@ Item_allany_subselect::Item_allany_subselect(Item_allany_subselect *item):
func
=
item
->
func
;
func
=
item
->
func
;
}
}
void
Item_in_subselect
::
single_value_transformer
(
st_select_lex_unit
*
unit
,
void
Item_in_subselect
::
single_value_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
,
Item
*
left_expr
,
Item
*
left_expr
,
compare_func_creator
func
)
compare_func_creator
func
)
{
{
...
@@ -457,10 +447,8 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
...
@@ -457,10 +447,8 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
Item_in_optimizer
*
optimizer
;
Item_in_optimizer
*
optimizer
;
substitution
=
optimizer
=
new
Item_in_optimizer
(
left_expr
,
this
);
substitution
=
optimizer
=
new
Item_in_optimizer
(
left_expr
,
this
);
if
(
!
optimizer
)
if
(
!
optimizer
)
{
current_thd
->
fatal_error
=
1
;
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
/*
/*
As far as Item_ref_in_optimizer do not substitude itself on fix_fields
As far as Item_ref_in_optimizer do not substitude itself on fix_fields
we can use same item for all selects.
we can use same item for all selects.
...
@@ -497,15 +485,9 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
...
@@ -497,15 +485,9 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
(
char
*
)
"<no matter>"
,
(
char
*
)
"<no matter>"
,
(
char
*
)
"<result>"
));
(
char
*
)
"<result>"
));
if
(
sl
->
having
||
sl
->
with_sum_func
||
sl
->
group_list
.
first
)
if
(
sl
->
having
||
sl
->
with_sum_func
||
sl
->
group_list
.
first
)
if
(
sl
->
having
)
sl
->
having
=
and_items
(
sl
->
having
,
item
);
sl
->
having
=
new
Item_cond_and
(
sl
->
having
,
item
);
else
sl
->
having
=
item
;
else
else
if
(
sl
->
where
)
sl
->
where
=
and_items
(
sl
->
where
,
item
);
sl
->
where
=
new
Item_cond_and
(
sl
->
where
,
item
);
else
sl
->
where
=
item
;
}
}
else
else
{
{
...
@@ -516,10 +498,7 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
...
@@ -516,10 +498,7 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
item
=
(
*
func
)(
expr
,
new
Item_asterisk_remover
(
this
,
item
,
item
=
(
*
func
)(
expr
,
new
Item_asterisk_remover
(
this
,
item
,
(
char
*
)
"<no matter>"
,
(
char
*
)
"<no matter>"
,
(
char
*
)
"<result>"
));
(
char
*
)
"<result>"
));
if
(
sl
->
where
)
sl
->
where
=
and_items
(
sl
->
where
,
item
);
sl
->
where
=
new
Item_cond_and
(
sl
->
where
,
item
);
else
sl
->
where
=
item
;
}
}
else
else
{
{
...
@@ -546,7 +525,6 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
...
@@ -546,7 +525,6 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
item
=
(
*
func
)(
left_expr
,
item
);
item
=
(
*
func
)(
left_expr
,
item
);
substitution
=
item
;
substitution
=
item
;
have_to_be_excluded
=
1
;
have_to_be_excluded
=
1
;
THD
*
thd
=
current_thd
;
if
(
thd
->
lex
.
describe
)
if
(
thd
->
lex
.
describe
)
{
{
char
warn_buff
[
MYSQL_ERRMSG_SIZE
];
char
warn_buff
[
MYSQL_ERRMSG_SIZE
];
...
@@ -561,7 +539,8 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
...
@@ -561,7 +539,8 @@ void Item_in_subselect::single_value_transformer(st_select_lex_unit *unit,
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
void
Item_in_subselect
::
row_value_transformer
(
st_select_lex_unit
*
unit
,
void
Item_in_subselect
::
row_value_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
,
Item
*
left_expr
)
Item
*
left_expr
)
{
{
DBUG_ENTER
(
"Item_in_subselect::row_value_transformer"
);
DBUG_ENTER
(
"Item_in_subselect::row_value_transformer"
);
...
@@ -575,10 +554,8 @@ void Item_in_subselect::row_value_transformer(st_select_lex_unit *unit,
...
@@ -575,10 +554,8 @@ void Item_in_subselect::row_value_transformer(st_select_lex_unit *unit,
Item_in_optimizer
*
optimizer
;
Item_in_optimizer
*
optimizer
;
substitution
=
optimizer
=
new
Item_in_optimizer
(
left_expr
,
this
);
substitution
=
optimizer
=
new
Item_in_optimizer
(
left_expr
,
this
);
if
(
!
optimizer
)
if
(
!
optimizer
)
{
current_thd
->
fatal_error
=
1
;
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
unit
->
dependent
=
1
;
unit
->
dependent
=
1
;
uint
n
=
left_expr
->
cols
();
uint
n
=
left_expr
->
cols
();
if
(
optimizer
->
preallocate_row
()
||
(
*
optimizer
->
get_cache
())
->
allocate
(
n
))
if
(
optimizer
->
preallocate_row
()
||
(
*
optimizer
->
get_cache
())
->
allocate
(
n
))
...
@@ -608,40 +585,32 @@ void Item_in_subselect::row_value_transformer(st_select_lex_unit *unit,
...
@@ -608,40 +585,32 @@ void Item_in_subselect::row_value_transformer(st_select_lex_unit *unit,
(
char
*
)
"<no matter>"
,
(
char
*
)
"<no matter>"
,
(
char
*
)
"<left expr>"
),
(
char
*
)
"<left expr>"
),
func
);
func
);
if
(
!
item
)
item
=
and_items
(
item
,
func
);
item
=
func
;
else
item
=
new
Item_cond_and
(
item
,
func
);
}
}
if
(
sl
->
having
||
sl
->
with_sum_func
||
sl
->
group_list
.
first
||
if
(
sl
->
having
||
sl
->
with_sum_func
||
sl
->
group_list
.
first
||
!
sl
->
table_list
.
elements
)
!
sl
->
table_list
.
elements
)
if
(
sl
->
having
)
sl
->
having
=
and_items
(
sl
->
having
,
item
);
sl
->
having
=
new
Item_cond_and
(
sl
->
having
,
item
);
else
sl
->
having
=
item
;
else
else
if
(
sl
->
where
)
sl
->
where
=
and_items
(
sl
->
where
,
item
);
sl
->
where
=
new
Item_cond_and
(
sl
->
where
,
item
);
else
sl
->
where
=
item
;
}
}
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
void
Item_in_subselect
::
select_transformer
(
st_select_lex_unit
*
unit
)
void
Item_in_subselect
::
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
)
{
{
if
(
left_expr
->
cols
()
==
1
)
if
(
left_expr
->
cols
()
==
1
)
single_value_transformer
(
unit
,
left_expr
,
single_value_transformer
(
thd
,
unit
,
left_expr
,
&
Item_bool_func2
::
eq_creator
);
&
Item_bool_func2
::
eq_creator
);
else
else
row_value_transformer
(
unit
,
left_expr
);
row_value_transformer
(
thd
,
unit
,
left_expr
);
}
}
void
Item_allany_subselect
::
select_transformer
(
st_select_lex_unit
*
unit
)
void
Item_allany_subselect
::
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
)
{
{
single_value_transformer
(
unit
,
left_expr
,
func
);
single_value_transformer
(
thd
,
unit
,
left_expr
,
func
);
}
}
subselect_single_select_engine
::
subselect_single_select_engine
(
THD
*
thd
,
subselect_single_select_engine
::
subselect_single_select_engine
(
THD
*
thd
,
...
@@ -678,7 +647,7 @@ subselect_union_engine::subselect_union_engine(THD *thd,
...
@@ -678,7 +647,7 @@ subselect_union_engine::subselect_union_engine(THD *thd,
subselect_engine
(
thd
,
item
,
result
)
subselect_engine
(
thd
,
item
,
result
)
{
{
unit
=
u
;
unit
=
u
;
if
(
!
result
)
if
(
!
result
)
{
{
//out of memory
//out of memory
thd
->
fatal_error
=
1
;
thd
->
fatal_error
=
1
;
...
@@ -694,13 +663,13 @@ int subselect_single_select_engine::prepare()
...
@@ -694,13 +663,13 @@ int subselect_single_select_engine::prepare()
prepared
=
1
;
prepared
=
1
;
SELECT_LEX_NODE
*
save_select
=
thd
->
lex
.
current_select
;
SELECT_LEX_NODE
*
save_select
=
thd
->
lex
.
current_select
;
thd
->
lex
.
current_select
=
select_lex
;
thd
->
lex
.
current_select
=
select_lex
;
if
(
join
->
prepare
((
TABLE_LIST
*
)
select_lex
->
table_list
.
first
,
if
(
join
->
prepare
((
TABLE_LIST
*
)
select_lex
->
table_list
.
first
,
select_lex
->
where
,
select_lex
->
where
,
(
ORDER
*
)
select_lex
->
order_list
.
first
,
(
ORDER
*
)
select_lex
->
order_list
.
first
,
(
ORDER
*
)
select_lex
->
group_list
.
first
,
(
ORDER
*
)
select_lex
->
group_list
.
first
,
select_lex
->
having
,
select_lex
->
having
,
(
ORDER
*
)
0
,
select_lex
,
(
ORDER
*
)
0
,
select_lex
,
select_lex
->
master_unit
(),
0
))
select_lex
->
master_unit
(),
0
))
return
1
;
return
1
;
thd
->
lex
.
current_select
=
save_select
;
thd
->
lex
.
current_select
=
save_select
;
return
0
;
return
0
;
...
@@ -726,11 +695,7 @@ static Item_result set_row(SELECT_LEX *select_lex, Item * item,
...
@@ -726,11 +695,7 @@ static Item_result set_row(SELECT_LEX *select_lex, Item * item,
if
(
row
)
if
(
row
)
{
{
if
(
!
(
row
[
i
]
=
Item_cache
::
get_cache
(
res_type
)))
if
(
!
(
row
[
i
]
=
Item_cache
::
get_cache
(
res_type
)))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
STRING_RESULT
;
// we should return something
return
STRING_RESULT
;
// we should return something
}
row
[
i
]
->
set_len_n_dec
(
sel_item
->
max_length
,
sel_item
->
decimals
);
row
[
i
]
->
set_len_n_dec
(
sel_item
->
max_length
,
sel_item
->
decimals
);
}
}
}
}
...
@@ -763,7 +728,7 @@ void subselect_union_engine::fix_length_and_dec(Item_cache **row)
...
@@ -763,7 +728,7 @@ void subselect_union_engine::fix_length_and_dec(Item_cache **row)
mlen
=
len
;
mlen
=
len
;
if
(
!
sel_item
)
if
(
!
sel_item
)
sel_item
=
s_item
;
sel_item
=
s_item
;
maybe_null
!
=
s_item
->
maybe_null
;
maybe_null
=
s_item
->
maybe_null
;
}
}
item
->
max_length
=
mlen
;
item
->
max_length
=
mlen
;
res_type
=
sel_item
->
result_type
();
res_type
=
sel_item
->
result_type
();
...
@@ -771,11 +736,7 @@ void subselect_union_engine::fix_length_and_dec(Item_cache **row)
...
@@ -771,11 +736,7 @@ void subselect_union_engine::fix_length_and_dec(Item_cache **row)
if
(
row
)
if
(
row
)
{
{
if
(
!
(
row
[
0
]
=
Item_cache
::
get_cache
(
res_type
)))
if
(
!
(
row
[
0
]
=
Item_cache
::
get_cache
(
res_type
)))
{
my_message
(
ER_OUT_OF_RESOURCES
,
ER
(
ER_OUT_OF_RESOURCES
),
MYF
(
0
));
current_thd
->
fatal_error
=
1
;
return
;
return
;
}
row
[
0
]
->
set_len_n_dec
(
mlen
,
sel_item
->
decimals
);
row
[
0
]
->
set_len_n_dec
(
mlen
,
sel_item
->
decimals
);
}
}
}
}
...
@@ -784,7 +745,7 @@ void subselect_union_engine::fix_length_and_dec(Item_cache **row)
...
@@ -784,7 +745,7 @@ void subselect_union_engine::fix_length_and_dec(Item_cache **row)
SELECT_LEX
*
sl
=
unit
->
first_select
();
SELECT_LEX
*
sl
=
unit
->
first_select
();
bool
fake
=
0
;
bool
fake
=
0
;
res_type
=
set_row
(
sl
,
item
,
row
,
&
fake
);
res_type
=
set_row
(
sl
,
item
,
row
,
&
fake
);
for
(
sl
=
sl
->
next_select
();
sl
;
sl
->
next_select
())
for
(
sl
=
sl
->
next_select
();
sl
;
sl
->
next_select
())
{
{
List_iterator_fast
<
Item
>
li
(
sl
->
item_list
);
List_iterator_fast
<
Item
>
li
(
sl
->
item_list
);
Item
*
sel_item
;
Item
*
sel_item
;
...
...
sql/item_subselect.h
View file @
fe9e1390
...
@@ -71,7 +71,7 @@ class Item_subselect :public Item_result_field
...
@@ -71,7 +71,7 @@ class Item_subselect :public Item_result_field
{
{
null_value
=
1
;
null_value
=
1
;
}
}
virtual
void
select_transformer
(
st_select_lex_unit
*
unit
);
virtual
void
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
);
bool
assigned
()
{
return
value_assigned
;
}
bool
assigned
()
{
return
value_assigned
;
}
void
assigned
(
bool
a
)
{
value_assigned
=
a
;
}
void
assigned
(
bool
a
)
{
value_assigned
=
a
;
}
enum
Type
type
()
const
;
enum
Type
type
()
const
;
...
@@ -106,7 +106,7 @@ class Item_singlerow_subselect :public Item_subselect
...
@@ -106,7 +106,7 @@ class Item_singlerow_subselect :public Item_subselect
decimals
=
item
->
decimals
;
decimals
=
item
->
decimals
;
}
}
void
reset
();
void
reset
();
void
select_transformer
(
st_select_lex_unit
*
unit
);
void
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
);
void
store
(
uint
i
,
Item
*
item
);
void
store
(
uint
i
,
Item
*
item
);
double
val
();
double
val
();
longlong
val_int
();
longlong
val_int
();
...
@@ -173,10 +173,11 @@ class Item_in_subselect :public Item_exists_subselect
...
@@ -173,10 +173,11 @@ class Item_in_subselect :public Item_exists_subselect
null_value
=
0
;
null_value
=
0
;
was_null
=
0
;
was_null
=
0
;
}
}
virtual
void
select_transformer
(
st_select_lex_unit
*
unit
);
virtual
void
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
);
void
single_value_transformer
(
st_select_lex_unit
*
unit
,
void
single_value_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
,
Item
*
left_expr
,
compare_func_creator
func
);
Item
*
left_expr
,
compare_func_creator
func
);
void
row_value_transformer
(
st_select_lex_unit
*
unit
,
Item
*
left_expr
);
void
row_value_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
,
Item
*
left_expr
);
longlong
val_int
();
longlong
val_int
();
double
val
();
double
val
();
String
*
val_str
(
String
*
);
String
*
val_str
(
String
*
);
...
@@ -195,7 +196,7 @@ class Item_allany_subselect :public Item_in_subselect
...
@@ -195,7 +196,7 @@ class Item_allany_subselect :public Item_in_subselect
Item_allany_subselect
(
THD
*
thd
,
Item
*
left_expr
,
compare_func_creator
f
,
Item_allany_subselect
(
THD
*
thd
,
Item
*
left_expr
,
compare_func_creator
f
,
st_select_lex
*
select_lex
);
st_select_lex
*
select_lex
);
Item_allany_subselect
(
Item_allany_subselect
*
item
);
Item_allany_subselect
(
Item_allany_subselect
*
item
);
virtual
void
select_transformer
(
st_select_lex_unit
*
unit
);
virtual
void
select_transformer
(
THD
*
thd
,
st_select_lex_unit
*
unit
);
};
};
class
subselect_engine
:
public
Sql_alloc
class
subselect_engine
:
public
Sql_alloc
...
...
sql/nt_servc.cc
View file @
fe9e1390
...
@@ -431,7 +431,7 @@ BOOL NTService::SeekStatus(LPCSTR szInternName, int OperationType)
...
@@ -431,7 +431,7 @@ BOOL NTService::SeekStatus(LPCSTR szInternName, int OperationType)
if
(
ret_error
==
ERROR_ACCESS_DENIED
)
if
(
ret_error
==
ERROR_ACCESS_DENIED
)
{
{
printf
(
"Install/Remove of the Service Denied!
\n
"
);
printf
(
"Install/Remove of the Service Denied!
\n
"
);
if
(
!
is_super_user
())
if
(
!
is_super_user
())
printf
(
"That operation should be made by an user with Administrator privileges!
\n
"
);
printf
(
"That operation should be made by an user with Administrator privileges!
\n
"
);
}
}
else
else
...
@@ -530,13 +530,13 @@ BOOL NTService::is_super_user()
...
@@ -530,13 +530,13 @@ BOOL NTService::is_super_user()
UINT
x
;
UINT
x
;
BOOL
ret_value
=
FALSE
;
BOOL
ret_value
=
FALSE
;
if
(
!
OpenThreadToken
(
GetCurrentThread
(),
TOKEN_QUERY
,
TRUE
,
&
hAccessToken
))
if
(
!
OpenThreadToken
(
GetCurrentThread
(),
TOKEN_QUERY
,
TRUE
,
&
hAccessToken
))
{
{
if
(
GetLastError
()
!=
ERROR_NO_TOKEN
)
if
(
GetLastError
()
!=
ERROR_NO_TOKEN
)
return
FALSE
;
return
FALSE
;
if
(
!
OpenProcessToken
(
GetCurrentProcess
(),
TOKEN_QUERY
,
&
hAccessToken
))
if
(
!
OpenProcessToken
(
GetCurrentProcess
(),
TOKEN_QUERY
,
&
hAccessToken
))
return
FALSE
;
return
FALSE
;
}
}
ret_value
=
GetTokenInformation
(
hAccessToken
,
TokenGroups
,
InfoBuffer
,
ret_value
=
GetTokenInformation
(
hAccessToken
,
TokenGroups
,
InfoBuffer
,
...
@@ -544,21 +544,21 @@ BOOL NTService::is_super_user()
...
@@ -544,21 +544,21 @@ BOOL NTService::is_super_user()
CloseHandle
(
hAccessToken
);
CloseHandle
(
hAccessToken
);
if
(
!
ret_value
)
if
(
!
ret_value
)
return
FALSE
;
return
FALSE
;
if
(
!
AllocateAndInitializeSid
(
&
siaNtAuthority
,
2
,
if
(
!
AllocateAndInitializeSid
(
&
siaNtAuthority
,
2
,
SECURITY_BUILTIN_DOMAIN_RID
,
SECURITY_BUILTIN_DOMAIN_RID
,
DOMAIN_ALIAS_RID_ADMINS
,
DOMAIN_ALIAS_RID_ADMINS
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
&
psidAdministrators
))
&
psidAdministrators
))
return
FALSE
;
return
FALSE
;
ret_value
=
FALSE
;
ret_value
=
FALSE
;
for
(
x
=
0
;
x
<
ptgGroups
->
GroupCount
;
x
++
)
for
(
x
=
0
;
x
<
ptgGroups
->
GroupCount
;
x
++
)
{
{
if
(
EqualSid
(
psidAdministrators
,
ptgGroups
->
Groups
[
x
].
Sid
)
)
if
(
EqualSid
(
psidAdministrators
,
ptgGroups
->
Groups
[
x
].
Sid
)
)
{
{
ret_value
=
TRUE
;
ret_value
=
TRUE
;
break
;
break
;
...
...
sql/opt_range.cc
View file @
fe9e1390
...
@@ -2162,12 +2162,13 @@ check_quick_keys(PARAM *param,uint idx,SEL_ARG *key_tree,
...
@@ -2162,12 +2162,13 @@ check_quick_keys(PARAM *param,uint idx,SEL_ARG *key_tree,
tmp
=
1
;
// Max one record
tmp
=
1
;
// Max one record
else
else
{
{
if
(
tmp_min_flag
&
GEOM_FLAG
)
if
(
tmp_min_flag
&
GEOM_FLAG
)
{
{
tmp
=
param
->
table
->
file
->
tmp
=
param
->
table
->
file
->
records_in_range
((
int
)
keynr
,(
byte
*
)(
param
->
min_key
+
1
),
records_in_range
((
int
)
keynr
,
(
byte
*
)(
param
->
min_key
+
1
),
min_key_length
,
(
ha_rkey_function
)(
tmp_min_flag
^
GEOM_FLAG
),
min_key_length
,
(
byte
*
)
NullS
,
0
,
HA_READ_KEY_EXACT
);
(
ha_rkey_function
)(
tmp_min_flag
^
GEOM_FLAG
),
(
byte
*
)
NullS
,
0
,
HA_READ_KEY_EXACT
);
}
}
else
else
{
{
...
...
sql/password.c
View file @
fe9e1390
...
@@ -573,7 +573,7 @@ void get_hash_and_password(ulong* salt, uint8 pversion, char* hash, unsigned cha
...
@@ -573,7 +573,7 @@ void get_hash_and_password(ulong* salt, uint8 pversion, char* hash, unsigned cha
while
(
salt
<
salt_end
)
/* Iterate over these elements*/
while
(
salt
<
salt_end
)
/* Iterate over these elements*/
{
{
val
=*
salt
;
val
=*
salt
;
for
(
t
=
3
;
t
>=
0
;
t
--
)
for
(
t
=
3
;
t
>=
0
;
t
--
)
{
{
bp
[
t
]
=
val
%
256
;
bp
[
t
]
=
val
%
256
;
...
...
sql/spatial.cc
View file @
fe9e1390
...
@@ -506,7 +506,7 @@ int GPolygon::get_data_as_text(String *txt) const
...
@@ -506,7 +506,7 @@ int GPolygon::get_data_as_text(String *txt) const
for
(;
n_linear_rings
>
0
;
--
n_linear_rings
)
for
(;
n_linear_rings
>
0
;
--
n_linear_rings
)
{
{
if
(
no_data
(
data
,
4
))
if
(
no_data
(
data
,
4
))
return
1
;
return
1
;
uint32
n_points
=
uint4korr
(
data
);
uint32
n_points
=
uint4korr
(
data
);
data
+=
4
;
data
+=
4
;
...
@@ -593,7 +593,7 @@ int GPolygon::area(double *ar) const
...
@@ -593,7 +593,7 @@ int GPolygon::area(double *ar) const
data
+=
(
8
+
8
);
data
+=
(
8
+
8
);
}
}
lr_area
=
fabs
(
lr_area
)
/
2
;
lr_area
=
fabs
(
lr_area
)
/
2
;
if
(
result
==-
1
)
result
=
lr_area
;
if
(
result
==-
1
)
result
=
lr_area
;
else
result
-=
lr_area
;
else
result
-=
lr_area
;
}
}
*
ar
=
fabs
(
result
);
*
ar
=
fabs
(
result
);
...
@@ -1344,7 +1344,7 @@ int GGeometryCollection::get_mbr(MBR *mbr) const
...
@@ -1344,7 +1344,7 @@ int GGeometryCollection::get_mbr(MBR *mbr) const
data
+=
4
;
data
+=
4
;
for
(;
n_objects
>
0
;
--
n_objects
)
for
(;
n_objects
>
0
;
--
n_objects
)
{
{
if
(
no_data
(
data
,
WKB_HEADER_SIZE
))
if
(
no_data
(
data
,
WKB_HEADER_SIZE
))
return
1
;
return
1
;
uint32
wkb_type
=
uint4korr
(
data
+
sizeof
(
char
));
uint32
wkb_type
=
uint4korr
(
data
+
sizeof
(
char
));
data
+=
WKB_HEADER_SIZE
;
data
+=
WKB_HEADER_SIZE
;
...
...
sql/sql_help.cc
View file @
fe9e1390
...
@@ -96,7 +96,7 @@ int search_functions(MI_INFO *file_leafs, const char *mask,
...
@@ -96,7 +96,7 @@ int search_functions(MI_INFO *file_leafs, const char *mask,
DBUG_ENTER
(
"search_functions"
);
DBUG_ENTER
(
"search_functions"
);
int
count
=
0
;
int
count
=
0
;
if
(
mi_scan_init
(
file_leafs
))
if
(
mi_scan_init
(
file_leafs
))
DBUG_RETURN
(
-
1
);
DBUG_RETURN
(
-
1
);
help_leaf
leaf
;
help_leaf
leaf
;
...
@@ -191,7 +191,7 @@ int search_categories(THD *thd,
...
@@ -191,7 +191,7 @@ int search_categories(THD *thd,
if
(
!
(
file_categories
=
open_help_file
(
thd
,
"function_category_name"
)))
if
(
!
(
file_categories
=
open_help_file
(
thd
,
"function_category_name"
)))
DBUG_RETURN
(
-
1
);
DBUG_RETURN
(
-
1
);
if
(
mi_scan_init
(
file_categories
))
if
(
mi_scan_init
(
file_categories
))
{
{
mi_close
(
file_categories
);
mi_close
(
file_categories
);
DBUG_RETURN
(
-
1
);
DBUG_RETURN
(
-
1
);
...
@@ -393,11 +393,11 @@ int mysqld_help(THD *thd, const char *mask)
...
@@ -393,11 +393,11 @@ int mysqld_help(THD *thd, const char *mask)
description
->
ptr
(),
example
->
ptr
())))
description
->
ptr
(),
example
->
ptr
())))
goto
end
;
goto
end
;
}
}
else
if
((
res
=
send_header_2
(
protocol
))
||
else
if
((
res
=
send_header_2
(
protocol
))
||
(
res
=
send_variant_2_list
(
protocol
,
&
function_list
,
false
))
||
(
res
=
send_variant_2_list
(
protocol
,
&
function_list
,
false
))
||
(
search_categories
(
thd
,
mask
,
&
categories_list
,
0
)
<
0
&&
(
search_categories
(
thd
,
mask
,
&
categories_list
,
0
)
<
0
&&
(
res
=
1
))
||
(
res
=
1
))
||
(
res
=
send_variant_2_list
(
protocol
,
&
categories_list
,
true
)))
(
res
=
send_variant_2_list
(
protocol
,
&
categories_list
,
true
)))
{
{
goto
end
;
goto
end
;
}
}
...
...
sql/sql_lex.cc
View file @
fe9e1390
...
@@ -1036,7 +1036,7 @@ void st_select_lex_node::include_global(st_select_lex_node **plink)
...
@@ -1036,7 +1036,7 @@ void st_select_lex_node::include_global(st_select_lex_node **plink)
//excluding from global list (internal function)
//excluding from global list (internal function)
void
st_select_lex_node
::
fast_exclude
()
void
st_select_lex_node
::
fast_exclude
()
{
{
if
(
link_prev
)
if
(
link_prev
)
{
{
if
((
*
link_prev
=
link_next
))
if
((
*
link_prev
=
link_next
))
link_next
->
link_prev
=
link_prev
;
link_next
->
link_prev
=
link_prev
;
...
@@ -1068,7 +1068,7 @@ void st_select_lex_node::exclude()
...
@@ -1068,7 +1068,7 @@ void st_select_lex_node::exclude()
void
st_select_lex_unit
::
exclude_level
()
void
st_select_lex_unit
::
exclude_level
()
{
{
SELECT_LEX_UNIT
*
units
=
0
,
**
units_last
=
&
units
;
SELECT_LEX_UNIT
*
units
=
0
,
**
units_last
=
&
units
;
for
(
SELECT_LEX
*
sl
=
first_select
();
sl
;
sl
=
sl
->
next_select
())
for
(
SELECT_LEX
*
sl
=
first_select
();
sl
;
sl
=
sl
->
next_select
())
{
{
if
(
sl
->
link_prev
&&
(
*
sl
->
link_prev
=
sl
->
link_next
))
if
(
sl
->
link_prev
&&
(
*
sl
->
link_prev
=
sl
->
link_next
))
sl
->
link_next
->
link_prev
=
sl
->
link_prev
;
sl
->
link_next
->
link_prev
=
sl
->
link_prev
;
...
@@ -1142,7 +1142,7 @@ void st_select_lex_node::mark_as_dependent(SELECT_LEX *last)
...
@@ -1142,7 +1142,7 @@ void st_select_lex_node::mark_as_dependent(SELECT_LEX *last)
for
(
SELECT_LEX_NODE
*
s
=
this
;
for
(
SELECT_LEX_NODE
*
s
=
this
;
s
&&
s
!=
last
;
s
&&
s
!=
last
;
s
=
s
->
outer_select
())
s
=
s
->
outer_select
())
if
(
!
s
->
dependent
)
if
(
!
s
->
dependent
)
{
{
// Select is dependent of outer select
// Select is dependent of outer select
s
->
dependent
=
1
;
s
->
dependent
=
1
;
...
...
sql/sql_olap.cc
View file @
fe9e1390
...
@@ -62,7 +62,7 @@ static int make_new_olap_select(LEX *lex, SELECT_LEX *select_lex, List<Item> new
...
@@ -62,7 +62,7 @@ static int make_new_olap_select(LEX *lex, SELECT_LEX *select_lex, List<Item> new
List_iterator
<
Item
>
list_it
(
select_lex
->
item_list
);
List_iterator
<
Item
>
list_it
(
select_lex
->
item_list
);
List_iterator
<
Item
>
new_it
(
new_fields
);
List_iterator
<
Item
>
new_it
(
new_fields
);
while
((
item
=
list_it
++
))
while
((
item
=
list_it
++
))
{
{
bool
not_found
=
true
;
bool
not_found
=
true
;
if
(
item
->
type
()
==
Item
::
FIELD_ITEM
)
if
(
item
->
type
()
==
Item
::
FIELD_ITEM
)
...
@@ -109,15 +109,15 @@ static int olap_combos(List<Item> old_fields, List<Item> new_fields, Item *item
...
@@ -109,15 +109,15 @@ static int olap_combos(List<Item> old_fields, List<Item> new_fields, Item *item
int
num_new_fields
)
int
num_new_fields
)
{
{
int
sl_return
=
0
;
int
sl_return
=
0
;
if
(
position
==
num_new_fields
)
if
(
position
==
num_new_fields
)
{
{
if
(
item
)
if
(
item
)
new_fields
.
push_front
(
item
);
new_fields
.
push_front
(
item
);
sl_return
=
make_new_olap_select
(
lex
,
select_lex
,
new_fields
);
sl_return
=
make_new_olap_select
(
lex
,
select_lex
,
new_fields
);
}
}
else
else
{
{
if
(
item
)
if
(
item
)
new_fields
.
push_front
(
item
);
new_fields
.
push_front
(
item
);
while
((
num_fields
-
num_new_fields
>=
selection
-
position
)
&&
!
sl_return
)
while
((
num_fields
-
num_new_fields
>=
selection
-
position
)
&&
!
sl_return
)
{
{
...
@@ -170,12 +170,12 @@ int handle_olaps(LEX *lex, SELECT_LEX *select_lex)
...
@@ -170,12 +170,12 @@ int handle_olaps(LEX *lex, SELECT_LEX *select_lex)
if
(
select_lex
->
olap
==
CUBE_TYPE
)
if
(
select_lex
->
olap
==
CUBE_TYPE
)
{
{
for
(
int
i
=
count
-
1
;
i
>=
0
&&
!
sl_return
;
i
--
)
for
(
int
i
=
count
-
1
;
i
>=
0
&&
!
sl_return
;
i
--
)
sl_return
=
olap_combos
(
item_list_copy
,
new_item_list
,
(
Item
*
)
0
,
lex
,
select_lex
,
0
,
0
,
count
,
i
);
sl_return
=
olap_combos
(
item_list_copy
,
new_item_list
,
(
Item
*
)
0
,
lex
,
select_lex
,
0
,
0
,
count
,
i
);
}
}
else
if
(
select_lex
->
olap
==
ROLLUP_TYPE
)
else
if
(
select_lex
->
olap
==
ROLLUP_TYPE
)
{
{
for
(
int
i
=
count
-
1
;
i
>=
0
&&
!
sl_return
;
i
--
)
for
(
int
i
=
count
-
1
;
i
>=
0
&&
!
sl_return
;
i
--
)
{
{
Item
*
item
;
Item
*
item
;
item_list_copy
.
pop
();
item_list_copy
.
pop
();
...
...
sql/sql_select.cc
View file @
fe9e1390
...
@@ -1160,7 +1160,7 @@ mysql_select(THD *thd, TABLE_LIST *tables, List<Item> &fields, COND *conds,
...
@@ -1160,7 +1160,7 @@ mysql_select(THD *thd, TABLE_LIST *tables, List<Item> &fields, COND *conds,
if
(
thd
->
possible_loops
)
if
(
thd
->
possible_loops
)
{
{
Item
*
item
;
Item
*
item
;
while
(
thd
->
possible_loops
->
elements
)
while
(
thd
->
possible_loops
->
elements
)
{
{
item
=
thd
->
possible_loops
->
pop
();
item
=
thd
->
possible_loops
->
pop
();
if
(
item
->
check_loop
(
thd
->
check_loops_counter
++
))
if
(
item
->
check_loop
(
thd
->
check_loops_counter
++
))
...
...
sql/sql_show.cc
View file @
fe9e1390
...
@@ -1113,8 +1113,8 @@ store_create_info(THD *thd, TABLE *table, String *packet)
...
@@ -1113,8 +1113,8 @@ store_create_info(THD *thd, TABLE *table, String *packet)
packet
->
append
(
" USING BTREE"
,
12
);
packet
->
append
(
" USING BTREE"
,
12
);
// +BAR: send USING only in non-default case: non-spatial rtree
// +BAR: send USING only in non-default case: non-spatial rtree
if
((
key_info
->
algorithm
==
HA_KEY_ALG_RTREE
)
&&
if
((
key_info
->
algorithm
==
HA_KEY_ALG_RTREE
)
&&
!
(
key_info
->
flags
&
HA_SPATIAL
))
!
(
key_info
->
flags
&
HA_SPATIAL
))
packet
->
append
(
" USING RTREE"
,
12
);
packet
->
append
(
" USING RTREE"
,
12
);
packet
->
append
(
" ("
,
2
);
packet
->
append
(
" ("
,
2
);
...
...
sql/sql_string.cc
View file @
fe9e1390
...
@@ -254,7 +254,7 @@ bool String::copy(const char *str,uint32 arg_length, CHARSET_INFO *from, CHARSET
...
@@ -254,7 +254,7 @@ bool String::copy(const char *str,uint32 arg_length, CHARSET_INFO *from, CHARSET
break
;
break
;
outp:
outp:
if
((
cnvres
=
to
->
wc_mb
(
to
,
wc
,
d
,
de
))
>
0
)
if
((
cnvres
=
to
->
wc_mb
(
to
,
wc
,
d
,
de
))
>
0
)
{
{
d
+=
cnvres
;
d
+=
cnvres
;
}
}
...
...
sql/sql_table.cc
View file @
fe9e1390
...
@@ -398,7 +398,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
...
@@ -398,7 +398,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
it
.
rewind
();
it
.
rewind
();
while
((
sql_field
=
it
++
))
while
((
sql_field
=
it
++
))
{
{
if
(
!
sql_field
->
charset
)
if
(
!
sql_field
->
charset
)
sql_field
->
charset
=
create_info
->
table_charset
?
sql_field
->
charset
=
create_info
->
table_charset
?
create_info
->
table_charset
:
create_info
->
table_charset
:
thd
->
db_charset
?
thd
->
db_charset
:
thd
->
db_charset
?
thd
->
db_charset
:
...
...
sql/stacktrace.c
View file @
fe9e1390
...
@@ -38,7 +38,7 @@ void safe_print_str(const char* name, const char* val, int max_len)
...
@@ -38,7 +38,7 @@ void safe_print_str(const char* name, const char* val, int max_len)
}
}
fprintf
(
stderr
,
"= "
);
fprintf
(
stderr
,
"= "
);
for
(;
max_len
&&
PTR_SANE
(
val
)
&&
*
val
;
--
max_len
)
for
(;
max_len
&&
PTR_SANE
(
val
)
&&
*
val
;
--
max_len
)
fputc
(
*
val
++
,
stderr
);
fputc
(
*
val
++
,
stderr
);
fputc
(
'\n'
,
stderr
);
fputc
(
'\n'
,
stderr
);
}
}
...
@@ -59,7 +59,7 @@ void safe_print_str(const char* name, const char* val, int max_len)
...
@@ -59,7 +59,7 @@ void safe_print_str(const char* name, const char* val, int max_len)
inline
uchar
**
find_prev_fp
(
uint32
*
pc
,
uchar
**
fp
)
inline
uchar
**
find_prev_fp
(
uint32
*
pc
,
uchar
**
fp
)
{
{
int
i
;
int
i
;
for
(
i
=
0
;
i
<
MAX_INSTR_IN_FUNC
;
++
i
,
--
pc
)
for
(
i
=
0
;
i
<
MAX_INSTR_IN_FUNC
;
++
i
,
--
pc
)
{
{
uchar
*
p
=
(
uchar
*
)
pc
;
uchar
*
p
=
(
uchar
*
)
pc
;
if
(
p
[
2
]
==
222
&&
p
[
3
]
==
35
)
if
(
p
[
2
]
==
222
&&
p
[
3
]
==
35
)
...
@@ -73,7 +73,7 @@ inline uchar** find_prev_fp(uint32* pc, uchar** fp)
...
@@ -73,7 +73,7 @@ inline uchar** find_prev_fp(uint32* pc, uchar** fp)
inline
uint32
*
find_prev_pc
(
uint32
*
pc
,
uchar
**
fp
)
inline
uint32
*
find_prev_pc
(
uint32
*
pc
,
uchar
**
fp
)
{
{
int
i
;
int
i
;
for
(
i
=
0
;
i
<
MAX_INSTR_IN_FUNC
;
++
i
,
--
pc
)
for
(
i
=
0
;
i
<
MAX_INSTR_IN_FUNC
;
++
i
,
--
pc
)
{
{
char
*
p
=
(
char
*
)
pc
;
char
*
p
=
(
char
*
)
pc
;
if
(
p
[
1
]
==
0
&&
p
[
2
]
==
94
&&
p
[
3
]
==
-
73
)
if
(
p
[
1
]
==
0
&&
p
[
2
]
==
94
&&
p
[
3
]
==
-
73
)
...
...
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