Commit 0f9b2523 authored by sunny's avatar sunny

branches/zip: Handle rename of variables. If the statically linked in engine

has a config variable that has since been renamed, we use a mapping table
to check for matches.
parent 1407e199
...@@ -8901,6 +8901,45 @@ struct st_mysql_sys_var ...@@ -8901,6 +8901,45 @@ struct st_mysql_sys_var
void* value; void* value;
}; };
struct param_mapping
{
const char* server; /* Parameter name in the server. */
const char* plugin; /* Paramater name in the plugin. */
};
/********************************************************************
Match the parameters from the static and dynamic versions. */
static
bool
innobase_match_parameter(
/*=====================*/
/* out: true if names match */
const char* from_server, /* in: variable name from server */
const char* from_plugin) /* in: variable name from plugin */
{
static const param_mapping param_map[] = {
{"use_adaptive_hash_indexes", "adaptive_hash_index"}
};
if (strcmp(from_server, from_plugin) == 0) {
return(true);
}
const param_mapping* param = param_map;
int n_elems = sizeof(param_map) / sizeof(param_map[0]);
for (int i = 0; i < n_elems; ++i, ++param) {
if (strcmp(param->server, from_server) == 0
&& strcmp(param->plugin, from_plugin) == 0) {
return(true);
}
}
return(false);
}
/******************************************************************** /********************************************************************
Copy InnoDB system variables from the static InnoDB to the dynamic Copy InnoDB system variables from the static InnoDB to the dynamic
plugin. */ plugin. */
...@@ -8915,11 +8954,11 @@ innodb_plugin_init(void) ...@@ -8915,11 +8954,11 @@ innodb_plugin_init(void)
# endif # endif
switch (builtin_innobase_plugin) { switch (builtin_innobase_plugin) {
case 0: case 0:
return(TRUE); return(true);
case MYSQL_STORAGE_ENGINE_PLUGIN: case MYSQL_STORAGE_ENGINE_PLUGIN:
break; break;
default: default:
return(FALSE); return(false);
} }
/* Copy the system variables. */ /* Copy the system variables. */
...@@ -8929,30 +8968,24 @@ innodb_plugin_init(void) ...@@ -8929,30 +8968,24 @@ innodb_plugin_init(void)
struct st_mysql_sys_var** w = innobase_system_variables; struct st_mysql_sys_var** w = innobase_system_variables;
for (; *v; v++, w++) { for (; *v; v++, w++) {
if (UNIV_UNLIKELY(!*w)) { if (!*w) {
fprintf(stderr, "InnoDB: unknown parameter %s,0x%x\n", fprintf(stderr, "InnoDB: unknown parameter %s,0x%x\n",
(*v)->name, (*v)->flags); (*v)->name, (*v)->flags);
return(FALSE); return(false);
} } else if (!innobase_match_parameter((*v)->name, (*w)->name)) {
if (UNIV_UNLIKELY(strcmp((*v)->name, (*w)->name))) {
/* Skip the destination parameter, since it doesn't /* Skip the destination parameter, since it doesn't
exist in the source. */ exist in the source. */
v--; v--;
continue; continue;
} /* Ignore changes that affect the READONLY flag. */
} else if (((*v)->flags ^ (*w)->flags) & ~PLUGIN_VAR_READONLY) {
if (UNIV_UNLIKELY(((*v)->flags ^ (*w)->flags))
& ~PLUGIN_VAR_READONLY) {
fprintf(stderr, fprintf(stderr,
"InnoDB: parameter mismatch:" "InnoDB: parameter mismatch:"
" %s,%s,0x%x,0x%x\n", " %s,%s,0x%x,0x%x\n",
(*v)->name, (*w)->name, (*v)->name, (*w)->name,
(*v)->flags, (*w)->flags); (*v)->flags, (*w)->flags);
return(FALSE); return(false);
} } else if ((*v)->flags & PLUGIN_VAR_THDLOCAL) {
if ((*v)->flags & PLUGIN_VAR_THDLOCAL) {
/* Do not copy session variables. */ /* Do not copy session variables. */
continue; continue;
} }
...@@ -8979,7 +9012,7 @@ innodb_plugin_init(void) ...@@ -8979,7 +9012,7 @@ innodb_plugin_init(void)
(*v)->value = (*w)->value; (*v)->value = (*w)->value;
} }
return(TRUE); return(true);
} }
#endif /* MYSQL_DYNAMIC_PLUGIN */ #endif /* MYSQL_DYNAMIC_PLUGIN */
......
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