`parameters` varchar(100) NOT NULL,
`chan_access` varchar(256) DEFAULT NULL,
`global_access` int(3) DEFAULT NULL,
- `flags` tinyint(4) NOT NULL,
+ `flags` int(10) NOT NULL,
PRIMARY KEY (`id`),
KEY `botid` (`botid`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
char flags[MAXLEN];
int flagpos = 0;
int ret = 0;
+ unsigned int visible_flags = 0;
int i = 0;
while(global_cmd_modcmd_show_flags[i].name) {
if(cbind->func->flags & global_cmd_modcmd_show_flags[i].flag) {
flagpos += sprintf(flags + flagpos, (flagpos ? " %s" : "\00314%s"), global_cmd_modcmd_show_flags[i].name);
}
+ visible_flags |= global_cmd_modcmd_show_flags[i].flag;
i++;
}
if(flagpos)
else
cbind->flags &= ~current_flag;
if(cbind->botid == 0)
- printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '0' AND `botid` = '%d' AND `command` = '%s'", cbind->flags, cbind->clientid, escape_string(cbind->cmd));
+ printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '0' AND `botid` = '%d' AND `command` = '%s'", (cbind->flags & visible_flags), cbind->clientid, escape_string(cbind->cmd));
else
- printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '%d' AND `command` = '%s'", cbind->flags, cbind->botid, escape_string(cbind->cmd));
+ printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '%d' AND `command` = '%s'", (cbind->flags & visible_flags), cbind->botid, escape_string(cbind->cmd));
ret = 1;
}
i = 0;