mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
SCRUM:
WL#1163 (Making spatial code optional) Pack of changes to do in sql/ code.
This commit is contained in:
10
sql/field.cc
10
sql/field.cc
@ -4470,7 +4470,7 @@ Field_blob::Field_blob(char *ptr_arg, uchar *null_ptr_arg, uchar null_bit_arg,
|
||||
:Field_str(ptr_arg, (1L << min(blob_pack_length,3)*8)-1L,
|
||||
null_ptr_arg, null_bit_arg, unireg_check_arg, field_name_arg,
|
||||
table_arg, cs),
|
||||
geom_flag(true), packlength(blob_pack_length)
|
||||
packlength(blob_pack_length)
|
||||
{
|
||||
flags|= BLOB_FLAG;
|
||||
if (table)
|
||||
@ -4705,6 +4705,7 @@ void Field_blob::get_key_image(char *buff,uint length,
|
||||
uint32 blob_length= get_length(ptr);
|
||||
char *blob;
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
if (type == itMBR)
|
||||
{
|
||||
if (!blob_length)
|
||||
@ -4721,6 +4722,7 @@ void Field_blob::get_key_image(char *buff,uint length,
|
||||
float8store(buff+24, mbr.ymax);
|
||||
return;
|
||||
}
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
|
||||
if ((uint32) length > blob_length)
|
||||
{
|
||||
@ -4930,6 +4932,7 @@ uint Field_blob::max_packed_col_length(uint max_length)
|
||||
return (max_length > 255 ? 2 : 1)+max_length;
|
||||
}
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
|
||||
void Field_geom::get_key_image(char *buff, uint length, CHARSET_INFO *cs,
|
||||
imagetype type)
|
||||
@ -5013,6 +5016,7 @@ int Field_geom::store(const char *from, uint length, CHARSET_INFO *cs)
|
||||
return 0;
|
||||
}
|
||||
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
|
||||
/****************************************************************************
|
||||
** enum type.
|
||||
@ -5488,10 +5492,12 @@ Field *make_field(char *ptr, uint32 field_length,
|
||||
f_packtype(pack_flag),
|
||||
field_length);
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
if (f_is_geom(pack_flag))
|
||||
return new Field_geom(ptr,null_pos,null_bit,
|
||||
unireg_check, field_name, table,
|
||||
pack_length, geom_type);
|
||||
#endif
|
||||
if (f_is_blob(pack_flag))
|
||||
return new Field_blob(ptr,null_pos,null_bit,
|
||||
unireg_check, field_name, table,
|
||||
@ -5651,10 +5657,12 @@ create_field::create_field(Field *old_field,Field *orig_field)
|
||||
def=new Item_string(pos,tmp.length(), charset);
|
||||
}
|
||||
}
|
||||
#ifdef HAVE_SPATIAL
|
||||
if (sql_type == FIELD_TYPE_GEOMETRY)
|
||||
{
|
||||
geom_type= ((Field_geom*)old_field)->geom_type;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
|
@ -913,7 +913,6 @@ public:
|
||||
|
||||
|
||||
class Field_blob :public Field_str {
|
||||
bool geom_flag;
|
||||
protected:
|
||||
uint packlength;
|
||||
String value; // For temporaries
|
||||
@ -926,7 +925,7 @@ public:
|
||||
struct st_table *table_arg, CHARSET_INFO *cs)
|
||||
:Field_str((char*) 0,len_arg, maybe_null_arg ? (uchar*) "": 0,0,
|
||||
NONE, field_name_arg, table_arg, cs),
|
||||
geom_flag(true), packlength(4)
|
||||
packlength(4)
|
||||
{
|
||||
flags|= BLOB_FLAG;
|
||||
}
|
||||
@ -1001,7 +1000,7 @@ public:
|
||||
field_cast_enum field_cast_type() { return FIELD_CAST_BLOB; }
|
||||
};
|
||||
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
class Field_geom :public Field_blob {
|
||||
public:
|
||||
enum geometry_type geom_type;
|
||||
@ -1029,7 +1028,7 @@ public:
|
||||
void set_key_image(char *buff,uint length, CHARSET_INFO *cs);
|
||||
field_cast_enum field_cast_type() { return FIELD_CAST_GEOM; }
|
||||
};
|
||||
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
|
||||
class Field_enum :public Field_str {
|
||||
protected:
|
||||
|
@ -487,6 +487,7 @@ Item *create_func_quote(Item* a)
|
||||
return new Item_func_quote(a);
|
||||
}
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
Item *create_func_as_wkt(Item *a)
|
||||
{
|
||||
return new Item_func_as_wkt(a);
|
||||
@ -646,6 +647,7 @@ Item *create_func_point(Item *a, Item *b)
|
||||
{
|
||||
return new Item_func_point(a, b);
|
||||
}
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
|
||||
Item *create_func_crc32(Item* a)
|
||||
{
|
||||
|
@ -99,6 +99,8 @@ Item *create_func_is_free_lock(Item* a);
|
||||
Item *create_func_is_used_lock(Item* a);
|
||||
Item *create_func_quote(Item* a);
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
|
||||
Item *create_func_geometry_from_text(Item *a);
|
||||
Item *create_func_as_wkt(Item *a);
|
||||
Item *create_func_as_wkb(Item *a);
|
||||
@ -138,6 +140,8 @@ Item *create_func_numgeometries(Item *a);
|
||||
|
||||
Item *create_func_point(Item *a, Item *b);
|
||||
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
|
||||
Item *create_func_compress(Item *a);
|
||||
Item *create_func_uncompress(Item *a);
|
||||
Item *create_func_uncompressed_length(Item *a);
|
||||
|
@ -17,6 +17,8 @@
|
||||
|
||||
/* This file defines all spatial functions */
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
|
||||
#ifdef __GNUC__
|
||||
#pragma implementation // gcc: Class implementation
|
||||
#endif
|
||||
@ -651,3 +653,5 @@ longlong Item_func_srid::val_int()
|
||||
uint32 res= uint4korr(swkb->ptr());
|
||||
return (longlong) res;
|
||||
}
|
||||
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
|
@ -17,6 +17,8 @@
|
||||
|
||||
/* This file defines all spatial functions */
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
|
||||
#ifdef __GNUC__
|
||||
#pragma interface /* gcc class implementation */
|
||||
#endif
|
||||
@ -338,3 +340,12 @@ public:
|
||||
const char *func_name() const { return "srid"; }
|
||||
void fix_length_and_dec() { max_length= 10; }
|
||||
};
|
||||
|
||||
#define GEOM_NEW(obj_constructor) new obj_constructor
|
||||
|
||||
#else /*HAVE_SPATIAL*/
|
||||
|
||||
#define GEOM_NEW(obj_constructor) NULL
|
||||
|
||||
#endif
|
||||
|
||||
|
@ -20,11 +20,17 @@
|
||||
#ifndef _lex_symbol_h
|
||||
#define _lex_symbol_h
|
||||
|
||||
typedef struct st_sym_group {
|
||||
const char *name;
|
||||
const char *needed_define;
|
||||
} SYM_GROUP;
|
||||
|
||||
typedef struct st_symbol {
|
||||
const char *name;
|
||||
uint tok;
|
||||
uint length;
|
||||
void *create_func;
|
||||
SYM_GROUP *group;
|
||||
} SYMBOL;
|
||||
|
||||
typedef struct st_lex_symbol
|
||||
|
@ -510,6 +510,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
blob_columns++;
|
||||
break;
|
||||
case FIELD_TYPE_GEOMETRY:
|
||||
#ifdef HAVE_SPATIAL
|
||||
if (!(file->table_flags() & HA_HAS_GEOMETRY))
|
||||
{
|
||||
my_printf_error(ER_CHECK_NOT_IMPLEMENTED, ER(ER_CHECK_NOT_IMPLEMENTED),
|
||||
@ -525,6 +526,11 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
sql_field->unireg_check=Field::BLOB_FIELD;
|
||||
blob_columns++;
|
||||
break;
|
||||
#else
|
||||
my_printf_error(ER_FEATURE_DISABLED,ER(ER_FEATURE_DISABLED), MYF(0),
|
||||
"Spatial extentions", "HAVE_SPATIAL");
|
||||
DBUG_RETURN(-1);
|
||||
#endif /*HAVE_SPATIAL*/
|
||||
case FIELD_TYPE_VAR_STRING:
|
||||
case FIELD_TYPE_STRING:
|
||||
sql_field->pack_flag=0;
|
||||
@ -658,8 +664,14 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
key_info->flags = HA_FULLTEXT;
|
||||
break;
|
||||
case Key::SPATIAL:
|
||||
#ifdef HAVE_SPATIAL
|
||||
key_info->flags = HA_SPATIAL;
|
||||
break;
|
||||
#else
|
||||
my_printf_error(ER_FEATURE_DISABLED,ER(ER_FEATURE_DISABLED),MYF(0),
|
||||
"Spatial extentions", "HAVE_SPATIAL");
|
||||
DBUG_RETURN(-1);
|
||||
#endif
|
||||
case Key::FOREIGN_KEY:
|
||||
key_number--; // Skip this key
|
||||
continue;
|
||||
@ -688,6 +700,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
checking for proper key parts number:
|
||||
*/
|
||||
|
||||
#ifdef HAVE_SPATIAL
|
||||
/* TODO: Add proper checks if handler supports key_type and algorithm */
|
||||
if (key_info->flags == HA_SPATIAL)
|
||||
{
|
||||
@ -698,8 +711,11 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
DBUG_RETURN(-1);
|
||||
}
|
||||
}
|
||||
else if (key_info->algorithm == HA_KEY_ALG_RTREE)
|
||||
else
|
||||
#endif
|
||||
if (key_info->algorithm == HA_KEY_ALG_RTREE)
|
||||
{
|
||||
#ifdef HAVE_RTREE_KEYS
|
||||
if ((key_info->key_parts & 1) == 1)
|
||||
{
|
||||
my_printf_error(ER_WRONG_ARGUMENTS,
|
||||
@ -710,6 +726,11 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
my_printf_error(ER_NOT_SUPPORTED_YET, ER(ER_NOT_SUPPORTED_YET),
|
||||
MYF(0), "RTREE INDEX");
|
||||
DBUG_RETURN(-1);
|
||||
#else
|
||||
my_printf_error(ER_FEATURE_DISABLED,ER(ER_FEATURE_DISABLED),MYF(0),
|
||||
"Spatial extentions", "HAVE_SPATIAL");
|
||||
DBUG_RETURN(-1);
|
||||
#endif
|
||||
}
|
||||
|
||||
List_iterator<key_part_spec> cols(key->columns);
|
||||
@ -779,6 +800,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
DBUG_RETURN(-1);
|
||||
}
|
||||
}
|
||||
#ifdef HAVE_SPATIAL
|
||||
if (key->type == Key::SPATIAL)
|
||||
{
|
||||
if (!column->length )
|
||||
@ -790,6 +812,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
column->length=4*sizeof(double);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
if (!(sql_field->flags & NOT_NULL_FLAG))
|
||||
{
|
||||
if (key->type == Key::PRIMARY)
|
||||
@ -806,11 +829,13 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
MYF(0),column->field_name);
|
||||
DBUG_RETURN(-1);
|
||||
}
|
||||
#ifdef HAVE_SPATIAL
|
||||
if (key->type == Key::SPATIAL)
|
||||
{
|
||||
my_error(ER_SPATIAL_CANT_HAVE_NULL, MYF(0));
|
||||
DBUG_RETURN(-1);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
if (MTYP_TYPENR(sql_field->unireg_check) == Field::NEXT_NUMBER)
|
||||
{
|
||||
@ -834,9 +859,11 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
||||
DBUG_RETURN(-1);
|
||||
}
|
||||
}
|
||||
#ifdef HAVE_SPATIAL //TODO HF What's this for???
|
||||
else if (f_is_geom(sql_field->pack_flag))
|
||||
{
|
||||
}
|
||||
#endif
|
||||
else if (column->length > length ||
|
||||
((f_is_packed(sql_field->pack_flag) ||
|
||||
((file->table_flags() & HA_NO_PREFIX_CHAR_KEYS) &&
|
||||
|
289
sql/sql_yacc.yy
289
sql/sql_yacc.yy
@ -611,7 +611,7 @@ bool my_yyoverflow(short **a, YYSTYPE **b,int *yystacksize);
|
||||
udf_type if_exists opt_local opt_table_options table_options
|
||||
table_option opt_if_not_exists opt_no_write_to_binlog opt_var_type
|
||||
opt_var_ident_type delete_option opt_temporary all_or_any opt_distinct
|
||||
opt_ignore_leaves fulltext_options
|
||||
opt_ignore_leaves fulltext_options spatial_type
|
||||
|
||||
%type <ulong_num>
|
||||
ULONG_NUM raid_types merge_insert_types
|
||||
@ -628,7 +628,7 @@ bool my_yyoverflow(short **a, YYSTYPE **b,int *yystacksize);
|
||||
table_wild no_in_expr expr_expr simple_expr no_and_expr
|
||||
using_list expr_or_default set_expr_or_default interval_expr
|
||||
param_marker singlerow_subselect singlerow_subselect_init
|
||||
exists_subselect exists_subselect_init
|
||||
exists_subselect exists_subselect_init geometry_function
|
||||
signed_literal NUM_literal
|
||||
|
||||
%type <item_list>
|
||||
@ -1244,8 +1244,8 @@ field_spec:
|
||||
(enum enum_field_types) $3,
|
||||
lex->length,lex->dec,lex->type,
|
||||
lex->default_value, lex->comment,
|
||||
lex->change,lex->interval,lex->charset,
|
||||
lex->uint_geom_type))
|
||||
lex->change,lex->interval,lex->charset
|
||||
,lex->uint_geom_type))
|
||||
YYABORT;
|
||||
};
|
||||
|
||||
@ -1297,30 +1297,19 @@ type:
|
||||
$$=FIELD_TYPE_TINY_BLOB; }
|
||||
| BLOB_SYM opt_len { Lex->charset=&my_charset_bin;
|
||||
$$=FIELD_TYPE_BLOB; }
|
||||
| GEOMETRY_SYM { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_GEOMETRY;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| GEOMETRYCOLLECTION { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_GEOMETRYCOLLECTION;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| POINT_SYM { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_POINT;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| MULTIPOINT { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_MULTIPOINT;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| LINESTRING { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_LINESTRING;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| MULTILINESTRING { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_MULTILINESTRING;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| POLYGON { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_POLYGON;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| MULTIPOLYGON { Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint) Field::GEOM_MULTIPOLYGON;
|
||||
$$=FIELD_TYPE_GEOMETRY; }
|
||||
| spatial_type {
|
||||
#ifdef HAVE_SPATIAL
|
||||
Lex->charset=&my_charset_bin;
|
||||
Lex->uint_geom_type= (uint)$1;
|
||||
$$=FIELD_TYPE_GEOMETRY;
|
||||
#else
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), "Spatial extentions",
|
||||
"HAVE_SPATIAL");
|
||||
YYABORT;
|
||||
#endif
|
||||
}
|
||||
| MEDIUMBLOB { Lex->charset=&my_charset_bin;
|
||||
$$=FIELD_TYPE_MEDIUM_BLOB; }
|
||||
| LONGBLOB { Lex->charset=&my_charset_bin;
|
||||
@ -1359,6 +1348,17 @@ type:
|
||||
}
|
||||
;
|
||||
|
||||
spatial_type:
|
||||
GEOMETRY_SYM { $$= Field::GEOM_GEOMETRY; }
|
||||
| GEOMETRYCOLLECTION { $$= Field::GEOM_GEOMETRYCOLLECTION; }
|
||||
| POINT_SYM { $$= Field::GEOM_POINT; }
|
||||
| MULTIPOINT { $$= Field::GEOM_MULTIPOINT; }
|
||||
| LINESTRING { $$= Field::GEOM_LINESTRING; }
|
||||
| MULTILINESTRING { $$= Field::GEOM_MULTILINESTRING; }
|
||||
| POLYGON { $$= Field::GEOM_POLYGON; }
|
||||
| MULTIPOLYGON { $$= Field::GEOM_MULTIPOLYGON; }
|
||||
;
|
||||
|
||||
char:
|
||||
CHAR_SYM {}
|
||||
;
|
||||
@ -1591,8 +1591,30 @@ key_type:
|
||||
key_or_index { $$= Key::MULTIPLE; }
|
||||
| FULLTEXT_SYM { $$= Key::FULLTEXT; }
|
||||
| FULLTEXT_SYM key_or_index { $$= Key::FULLTEXT; }
|
||||
| SPATIAL_SYM { $$= Key::SPATIAL; }
|
||||
| SPATIAL_SYM key_or_index { $$= Key::SPATIAL; };
|
||||
| SPATIAL_SYM
|
||||
{
|
||||
#ifdef HAVE_SPATIAL
|
||||
$$= Key::SPATIAL;
|
||||
#else
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), "Spatial extentions",
|
||||
"HAVE_SPATIAL");
|
||||
YYABORT;
|
||||
#endif
|
||||
}
|
||||
| SPATIAL_SYM key_or_index
|
||||
{
|
||||
#ifdef HAVE_SPATIAL
|
||||
$$= Key::SPATIAL;
|
||||
#else
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), "Spatial extentions",
|
||||
"HAVE_SPATIAL");
|
||||
YYABORT;
|
||||
#endif
|
||||
};
|
||||
|
||||
constraint_key_type:
|
||||
PRIMARY_SYM KEY_SYM { $$= Key::PRIMARY; }
|
||||
@ -1617,7 +1639,18 @@ opt_unique_or_fulltext:
|
||||
/* empty */ { $$= Key::MULTIPLE; }
|
||||
| UNIQUE_SYM { $$= Key::UNIQUE; }
|
||||
| FULLTEXT_SYM { $$= Key::FULLTEXT;}
|
||||
| SPATIAL_SYM { $$= Key::SPATIAL; }
|
||||
| SPATIAL_SYM
|
||||
{
|
||||
#ifdef HAVE_SPATIAL
|
||||
$$= Key::SPATIAL;
|
||||
#else
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), "Spatial extentions",
|
||||
"HAVE_SPATIAL");
|
||||
YYABORT;
|
||||
#endif
|
||||
}
|
||||
;
|
||||
|
||||
key_alg:
|
||||
@ -1627,7 +1660,18 @@ key_alg:
|
||||
|
||||
opt_btree_or_rtree:
|
||||
BTREE_SYM { $$= HA_KEY_ALG_BTREE; }
|
||||
| RTREE_SYM { $$= HA_KEY_ALG_RTREE; }
|
||||
| RTREE_SYM
|
||||
{
|
||||
#ifdef HAVE_RTREE_KEYS
|
||||
$$= HA_KEY_ALG_RTREE;
|
||||
#else
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), "RTree keys",
|
||||
"HAVE_RTREE_KEYS");
|
||||
YYABORT;
|
||||
#endif
|
||||
}
|
||||
| HASH_SYM { $$= HA_KEY_ALG_HASH; };
|
||||
|
||||
key_list:
|
||||
@ -1725,8 +1769,8 @@ alter_list_item:
|
||||
(enum enum_field_types) $5,
|
||||
lex->length,lex->dec,lex->type,
|
||||
lex->default_value, lex->comment,
|
||||
$3.str, lex->interval, lex->charset,
|
||||
lex->uint_geom_type))
|
||||
$3.str, lex->interval, lex->charset
|
||||
,lex->uint_geom_type))
|
||||
YYABORT;
|
||||
}
|
||||
opt_place
|
||||
@ -2556,13 +2600,53 @@ simple_expr:
|
||||
| VALUES '(' simple_ident ')'
|
||||
{ $$= new Item_insert_value($3); }
|
||||
| FUNC_ARG0 '(' ')'
|
||||
{ $$= ((Item*(*)(void))($1.symbol->create_func))();}
|
||||
{
|
||||
if (!$1.symbol->create_func)
|
||||
{
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), $1.symbol->group->name,
|
||||
$1.symbol->group->needed_define);
|
||||
YYABORT;
|
||||
}
|
||||
$$= ((Item*(*)(void))($1.symbol->create_func))();
|
||||
}
|
||||
| FUNC_ARG1 '(' expr ')'
|
||||
{ $$= ((Item*(*)(Item*))($1.symbol->create_func))($3);}
|
||||
{
|
||||
if (!$1.symbol->create_func)
|
||||
{
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), $1.symbol->group->name,
|
||||
$1.symbol->group->needed_define);
|
||||
YYABORT;
|
||||
}
|
||||
$$= ((Item*(*)(Item*))($1.symbol->create_func))($3);
|
||||
}
|
||||
| FUNC_ARG2 '(' expr ',' expr ')'
|
||||
{ $$= ((Item*(*)(Item*,Item*))($1.symbol->create_func))($3,$5);}
|
||||
{
|
||||
if (!$1.symbol->create_func)
|
||||
{
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), $1.symbol->group->name,
|
||||
$1.symbol->group->needed_define);
|
||||
YYABORT;
|
||||
}
|
||||
$$= ((Item*(*)(Item*,Item*))($1.symbol->create_func))($3,$5);
|
||||
}
|
||||
| FUNC_ARG3 '(' expr ',' expr ',' expr ')'
|
||||
{ $$= ((Item*(*)(Item*,Item*,Item*))($1.symbol->create_func))($3,$5,$7);}
|
||||
{
|
||||
if (!$1.symbol->create_func)
|
||||
{
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), $1.symbol->group->name,
|
||||
$1.symbol->group->needed_define);
|
||||
YYABORT;
|
||||
}
|
||||
$$= ((Item*(*)(Item*,Item*,Item*))($1.symbol->create_func))($3,$5,$7);
|
||||
}
|
||||
| ADDDATE_SYM '(' expr ',' expr ')'
|
||||
{ $$= new Item_date_add_interval($3, $5, INTERVAL_DAY, 0);}
|
||||
| ADDDATE_SYM '(' expr ',' INTERVAL_SYM expr interval ')'
|
||||
@ -2645,18 +2729,18 @@ simple_expr:
|
||||
}
|
||||
| FIELD_FUNC '(' expr ',' expr_list ')'
|
||||
{ $5->push_front($3); $$= new Item_func_field(*$5); }
|
||||
| GEOMFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| GEOMFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| GEOMFROMWKB '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_wkb($3); }
|
||||
| GEOMFROMWKB '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_wkb($3, $5); }
|
||||
| GEOMETRYCOLLECTION '(' expr_list ')'
|
||||
{ $$= new Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbGeometryCollection,
|
||||
Geometry::wkbPoint); }
|
||||
| geometry_function
|
||||
{
|
||||
#ifdef HAVE_SPATIAL
|
||||
$$= $1;
|
||||
#else
|
||||
net_printf(Lex->thd, ER_FEATURE_DISABLED,
|
||||
ER(ER_FEATURE_DISABLED),
|
||||
MYF(0), "Spatial extentions",
|
||||
"HAVE_SPATIAL");
|
||||
YYABORT;
|
||||
#endif
|
||||
}
|
||||
| GET_FORMAT '(' date_time_type ',' expr ')'
|
||||
{ $$= new Item_func_get_format($3, $5); }
|
||||
| HOUR_SYM '(' expr ')'
|
||||
@ -2690,17 +2774,10 @@ simple_expr:
|
||||
}
|
||||
| LEFT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_left($3,$5); }
|
||||
| LINESTRING '(' expr_list ')'
|
||||
{ $$= new Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbLineString, Geometry::wkbPoint); }
|
||||
| LOCATE '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_locate($5,$3); }
|
||||
| LOCATE '(' expr ',' expr ',' expr ')'
|
||||
{ $$= new Item_func_locate($5,$3,$7); }
|
||||
| GEOMCOLLFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| GEOMCOLLFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| GREATEST_SYM '(' expr ',' expr_list ')'
|
||||
{ $5->push_front($3); $$= new Item_func_max(*$5); }
|
||||
| LEAST_SYM '(' expr ',' expr_list ')'
|
||||
@ -2709,10 +2786,6 @@ simple_expr:
|
||||
{ $$= new Item_func_log($3); }
|
||||
| LOG_SYM '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_log($3, $5); }
|
||||
| LINEFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| LINEFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| MASTER_POS_WAIT '(' expr ',' expr ')'
|
||||
{
|
||||
$$= new Item_master_pos_wait($3, $5);
|
||||
@ -2731,27 +2804,6 @@ simple_expr:
|
||||
{ $$ = new Item_func_mod( $3, $5); }
|
||||
| MONTH_SYM '(' expr ')'
|
||||
{ $$= new Item_func_month($3); }
|
||||
| MULTILINESTRING '(' expr_list ')'
|
||||
{ $$= new Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbMultiLineString, Geometry::wkbLineString); }
|
||||
| MLINEFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| MLINEFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| MPOINTFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| MPOINTFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| MPOLYFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| MPOLYFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| MULTIPOINT '(' expr_list ')'
|
||||
{ $$= new Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbMultiPoint, Geometry::wkbPoint); }
|
||||
| MULTIPOLYGON '(' expr_list ')'
|
||||
{ $$= new Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbMultiPolygon, Geometry::wkbPolygon ); }
|
||||
| NOW_SYM optional_braces
|
||||
{ $$= new Item_func_now_local(); Lex->safe_to_cache_query=0;}
|
||||
| NOW_SYM '(' expr ')'
|
||||
@ -2764,19 +2816,6 @@ simple_expr:
|
||||
}
|
||||
| OLD_PASSWORD '(' expr ')'
|
||||
{ $$= new Item_func_old_password($3); }
|
||||
| POINT_SYM '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_point($3,$5); }
|
||||
| POINTFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| POINTFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| POLYFROMTEXT '(' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3); }
|
||||
| POLYFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= new Item_func_geometry_from_text($3, $5); }
|
||||
| POLYGON '(' expr_list ')'
|
||||
{ $$= new Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbPolygon, Geometry::wkbLineString); }
|
||||
| POSITION_SYM '(' no_in_expr IN_SYM expr ')'
|
||||
{ $$ = new Item_func_locate($5,$3); }
|
||||
| RAND '(' expr ')'
|
||||
@ -2914,6 +2953,66 @@ simple_expr:
|
||||
| EXTRACT_SYM '(' interval FROM expr ')'
|
||||
{ $$=new Item_extract( $3, $5); };
|
||||
|
||||
geometry_function:
|
||||
GEOMFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| GEOMFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| GEOMFROMWKB '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_wkb($3)); }
|
||||
| GEOMFROMWKB '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_wkb($3, $5)); }
|
||||
| GEOMETRYCOLLECTION '(' expr_list ')'
|
||||
{ $$= GEOM_NEW(Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbGeometryCollection,
|
||||
Geometry::wkbPoint)); }
|
||||
| LINESTRING '(' expr_list ')'
|
||||
{ $$= GEOM_NEW(Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbLineString, Geometry::wkbPoint)); }
|
||||
| MULTILINESTRING '(' expr_list ')'
|
||||
{ $$= GEOM_NEW( Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbMultiLineString, Geometry::wkbLineString)); }
|
||||
| MLINEFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| MLINEFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| MPOINTFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| MPOINTFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| MPOLYFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| MPOLYFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| MULTIPOINT '(' expr_list ')'
|
||||
{ $$= GEOM_NEW(Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbMultiPoint, Geometry::wkbPoint)); }
|
||||
| MULTIPOLYGON '(' expr_list ')'
|
||||
{ $$= GEOM_NEW(Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbMultiPolygon, Geometry::wkbPolygon)); }
|
||||
| POINT_SYM '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_point($3,$5)); }
|
||||
| POINTFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| POINTFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| POLYFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| POLYFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| POLYGON '(' expr_list ')'
|
||||
{ $$= GEOM_NEW(Item_func_spatial_collection(* $3,
|
||||
Geometry::wkbPolygon, Geometry::wkbLineString)); }
|
||||
| GEOMCOLLFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| GEOMCOLLFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
| LINEFROMTEXT '(' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3)); }
|
||||
| LINEFROMTEXT '(' expr ',' expr ')'
|
||||
{ $$= GEOM_NEW(Item_func_geometry_from_text($3, $5)); }
|
||||
;
|
||||
|
||||
fulltext_options:
|
||||
/* nothing */ { $$= FT_NL; }
|
||||
| WITH QUERY_SYM EXPANSION_SYM { $$= FT_NL | FT_EXPAND; }
|
||||
|
@ -405,8 +405,13 @@ int openfrm(const char *name, const char *alias, uint db_stat, uint prgflag,
|
||||
// charset and geometry_type share the same byte in frm
|
||||
if (field_type == FIELD_TYPE_GEOMETRY)
|
||||
{
|
||||
#ifdef HAVE_SPATIAL
|
||||
geom_type= (Field::geometry_type) strpos[14];
|
||||
charset= &my_charset_bin;
|
||||
#else
|
||||
error= 4; // unsupported field type
|
||||
goto err_not_open;
|
||||
#endif
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -471,7 +471,12 @@ static bool pack_fields(File file,List<create_field> &create_fields)
|
||||
buff[12]= (uchar) field->interval_id;
|
||||
buff[13]= (uchar) field->sql_type;
|
||||
if (field->sql_type == FIELD_TYPE_GEOMETRY)
|
||||
{
|
||||
buff[14]= (uchar) field->geom_type;
|
||||
#ifndef HAVE_SPATIAL
|
||||
DBUG_ASSERT(0); // Should newer happen
|
||||
#endif
|
||||
}
|
||||
else if (field->charset)
|
||||
buff[14]= (uchar) field->charset->number;
|
||||
else
|
||||
|
Reference in New Issue
Block a user