Merge
This commit is contained in:
commit
8e3322098a
@ -38852,6 +38852,12 @@ Reset status variable which could cause problem if one used @code{--slow-log}.
|
|||||||
@appendixsubsec Changes in release 3.23.28
|
@appendixsubsec Changes in release 3.23.28
|
||||||
@itemize @bullet
|
@itemize @bullet
|
||||||
@item
|
@item
|
||||||
|
Added new options @code{--pager[=...]}, @code{--no-pager},
|
||||||
|
@code{--tee=...} and @code{--no-tee} to the @code{mysql} client. The
|
||||||
|
new corresponding interactive commands are @code{pager}, @code{nopager},
|
||||||
|
@code{tee} and @code{notee}. @xref{mysql}, @code{mysql --help} and the
|
||||||
|
interactive help for more information.
|
||||||
|
@item
|
||||||
Fixed crash when automatic repair of @code{MyISAM} table failed.
|
Fixed crash when automatic repair of @code{MyISAM} table failed.
|
||||||
@item
|
@item
|
||||||
Fixed a major performance bug in the table locking code when one
|
Fixed a major performance bug in the table locking code when one
|
||||||
|
89
client/thimble.cc
Normal file
89
client/thimble.cc
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
#include <pthread.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
static void spawn_stern_thread(pthread_t *t);
|
||||||
|
static int act_goofy(void);
|
||||||
|
static void *be_stern(void *);
|
||||||
|
|
||||||
|
static struct {
|
||||||
|
pthread_mutex_t lock;
|
||||||
|
pthread_cond_t cond;
|
||||||
|
int msg;
|
||||||
|
} comm = { PTHREAD_MUTEX_INITIALIZER, PTHREAD_COND_INITIALIZER, 0 };
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
pthread_t t;
|
||||||
|
spawn_stern_thread(&t);
|
||||||
|
|
||||||
|
while (act_goofy() != 0)
|
||||||
|
/* do nothing */;
|
||||||
|
|
||||||
|
pthread_exit(NULL);
|
||||||
|
|
||||||
|
/* notreached */
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void spawn_stern_thread(pthread_t *t)
|
||||||
|
{
|
||||||
|
pthread_attr_t attr;
|
||||||
|
|
||||||
|
pthread_attr_init(&attr);
|
||||||
|
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
|
||||||
|
|
||||||
|
if (pthread_create(t, &attr, be_stern, NULL) != 0)
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
|
||||||
|
pthread_attr_destroy(&attr);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int act_goofy(void)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
char buf[30];
|
||||||
|
|
||||||
|
fputs("Are you ready to act goofy (Y/n)? ", stdout); fflush(stdout);
|
||||||
|
fgets(buf, sizeof(buf), stdin);
|
||||||
|
pthread_mutex_lock(&comm.lock);
|
||||||
|
if (buf[0] == 'y' || buf[0] == '\n') {
|
||||||
|
fputs("** Waawlwalkwwwaa!!\n", stdout); fflush(stdout);
|
||||||
|
++comm.msg;
|
||||||
|
ret = 1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
fputs("OK, I hate you. Let me go.\n", stdout); fflush(stdout);
|
||||||
|
comm.msg = -1;
|
||||||
|
ret = 0;
|
||||||
|
}
|
||||||
|
pthread_mutex_unlock(&comm.lock);
|
||||||
|
pthread_cond_signal(&comm.cond);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void *be_stern(void *v __attribute((unused)))
|
||||||
|
{
|
||||||
|
int msg;
|
||||||
|
for (;;) {
|
||||||
|
pthread_mutex_lock(&comm.lock);
|
||||||
|
while (comm.msg == 0)
|
||||||
|
pthread_cond_wait(&comm.cond, &comm.lock);
|
||||||
|
msg = comm.msg;
|
||||||
|
comm.msg = 0;
|
||||||
|
pthread_mutex_unlock(&comm.lock);
|
||||||
|
|
||||||
|
if (msg < 0)
|
||||||
|
break; /* the goofy one learned a lesson! */
|
||||||
|
|
||||||
|
fputs("I HAVE TO BE STERN WITH YOU!\n", stderr);
|
||||||
|
fprintf(stderr, "I should give you %d lashes.\n", msg);
|
||||||
|
sleep(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
fputs("You are NOTHING!\n", stderr);
|
||||||
|
return NULL;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user