Commit 3bef8482 authored by Nikita Malyavin's avatar Nikita Malyavin Committed by Sergei Golubchik

cleanup: reduce code duplication in read_extra2()

parent 8ab69384
...@@ -1516,6 +1516,14 @@ static size_t extra2_read_len(const uchar **extra2, const uchar *extra2_end) ...@@ -1516,6 +1516,14 @@ static size_t extra2_read_len(const uchar **extra2, const uchar *extra2_end)
return length; return length;
} }
static
bool read_extra2_section_once(const uchar *extra2, size_t len, LEX_CUSTRING *section)
{
if (section->str)
return true;
*section= {extra2, len};
return false;
}
static static
bool read_extra2(const uchar *frm_image, size_t len, extra2_fields *fields) bool read_extra2(const uchar *frm_image, size_t len, extra2_fields *fields)
...@@ -1535,6 +1543,8 @@ bool read_extra2(const uchar *frm_image, size_t len, extra2_fields *fields) ...@@ -1535,6 +1543,8 @@ bool read_extra2(const uchar *frm_image, size_t len, extra2_fields *fields)
size_t length= extra2_read_len(&extra2, e2end); size_t length= extra2_read_len(&extra2, e2end);
if (!length) if (!length)
DBUG_RETURN(true); DBUG_RETURN(true);
bool fail= false;
switch (type) { switch (type) {
case EXTRA2_TABLEDEF_VERSION: case EXTRA2_TABLEDEF_VERSION:
if (fields->version.str) // see init_from_sql_statement_string() if (fields->version.str) // see init_from_sql_statement_string()
...@@ -1549,49 +1559,35 @@ bool read_extra2(const uchar *frm_image, size_t len, extra2_fields *fields) ...@@ -1549,49 +1559,35 @@ bool read_extra2(const uchar *frm_image, size_t len, extra2_fields *fields)
} }
break; break;
case EXTRA2_ENGINE_TABLEOPTS: case EXTRA2_ENGINE_TABLEOPTS:
if (fields->options.str) fail= read_extra2_section_once(extra2, length, &fields->options);
DBUG_RETURN(true);
fields->options.str= extra2;
fields->options.length= length;
break; break;
case EXTRA2_DEFAULT_PART_ENGINE: case EXTRA2_DEFAULT_PART_ENGINE:
fields->engine.set((const char*)extra2, length); fields->engine.set((const char*)extra2, length);
break; break;
case EXTRA2_GIS: case EXTRA2_GIS:
if (fields->gis.str) fail= read_extra2_section_once(extra2, length, &fields->gis);
DBUG_RETURN(true);
fields->gis.str= extra2;
fields->gis.length= length;
break; break;
case EXTRA2_PERIOD_FOR_SYSTEM_TIME: case EXTRA2_PERIOD_FOR_SYSTEM_TIME:
if (fields->system_period.str || length != 2 * frm_fieldno_size) fail= read_extra2_section_once(extra2, length, &fields->system_period)
DBUG_RETURN(true); || length != 2 * frm_fieldno_size;
fields->system_period.str = extra2;
fields->system_period.length= length;
break; break;
case EXTRA2_FIELD_FLAGS: case EXTRA2_FIELD_FLAGS:
if (fields->field_flags.str) fail= read_extra2_section_once(extra2, length, &fields->field_flags);
DBUG_RETURN(true);
fields->field_flags.str= extra2;
fields->field_flags.length= length;
break; break;
case EXTRA2_APPLICATION_TIME_PERIOD: case EXTRA2_APPLICATION_TIME_PERIOD:
if (fields->application_period.str) fail= read_extra2_section_once(extra2, length, &fields->application_period);
DBUG_RETURN(true);
fields->application_period.str= extra2;
fields->application_period.length= length;
break; break;
case EXTRA2_FIELD_DATA_TYPE_INFO: case EXTRA2_FIELD_DATA_TYPE_INFO:
if (fields->field_data_type_info.str) fail= read_extra2_section_once(extra2, length, &fields->field_data_type_info);
DBUG_RETURN(true);
fields->field_data_type_info.str= extra2;
fields->field_data_type_info.length= length;
break; break;
default: default:
/* abort frm parsing if it's an unknown but important extra2 value */ /* abort frm parsing if it's an unknown but important extra2 value */
if (type >= EXTRA2_ENGINE_IMPORTANT) if (type >= EXTRA2_ENGINE_IMPORTANT)
DBUG_RETURN(true); DBUG_RETURN(true);
} }
if (fail)
DBUG_RETURN(true);
extra2+= length; extra2+= length;
} }
if (extra2 != e2end) if (extra2 != e2end)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment