mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
thread_win32.c: set thread name
* thread_win32.c (native_set_another_thread_name): set thread name by SetThreadDescription. * win32/win32.c (rb_w32_set_thread_description): dynamically try SetThreadDescription. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59660 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
c150c7877d
commit
19d692920d
4 changed files with 59 additions and 9 deletions
10
thread.c
10
thread.c
|
@ -2932,9 +2932,6 @@ rb_thread_getname(VALUE thread)
|
||||||
static VALUE
|
static VALUE
|
||||||
rb_thread_setname(VALUE thread, VALUE name)
|
rb_thread_setname(VALUE thread, VALUE name)
|
||||||
{
|
{
|
||||||
#ifdef SET_ANOTHER_THREAD_NAME
|
|
||||||
const char *s = "";
|
|
||||||
#endif
|
|
||||||
rb_thread_t *target_th = rb_thread_ptr(thread);
|
rb_thread_t *target_th = rb_thread_ptr(thread);
|
||||||
|
|
||||||
if (!NIL_P(name)) {
|
if (!NIL_P(name)) {
|
||||||
|
@ -2946,16 +2943,11 @@ rb_thread_setname(VALUE thread, VALUE name)
|
||||||
rb_enc_name(enc));
|
rb_enc_name(enc));
|
||||||
}
|
}
|
||||||
name = rb_str_new_frozen(name);
|
name = rb_str_new_frozen(name);
|
||||||
#ifdef SET_ANOTHER_THREAD_NAME
|
|
||||||
s = RSTRING_PTR(name);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
target_th->name = name;
|
target_th->name = name;
|
||||||
#if defined(SET_ANOTHER_THREAD_NAME)
|
|
||||||
if (threadptr_initialized(target_th)) {
|
if (threadptr_initialized(target_th)) {
|
||||||
SET_ANOTHER_THREAD_NAME(target_th->thread_id, s);
|
native_set_another_thread_name(target_th->thread_id, name);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1540,6 +1540,17 @@ native_set_thread_name(rb_thread_t *th)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static VALUE
|
||||||
|
native_set_another_thread_name(rb_nativethread_id_t thread_id, VALUE name)
|
||||||
|
{
|
||||||
|
#ifdef SET_ANOTHER_THREAD_NAME
|
||||||
|
const char *s = "";
|
||||||
|
if (!NIL_P(name)) s = RSTRING_PTR(name);
|
||||||
|
SET_ANOTHER_THREAD_NAME(thread_id, s);
|
||||||
|
#endif
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
static void *
|
static void *
|
||||||
thread_timer(void *p)
|
thread_timer(void *p)
|
||||||
{
|
{
|
||||||
|
|
|
@ -669,6 +669,10 @@ ubf_handle(void *ptr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int rb_w32_set_thread_description(HANDLE th, const WCHAR *name);
|
||||||
|
int rb_w32_set_thread_description_str(HANDLE th, VALUE name);
|
||||||
|
#define native_set_another_thread_name rb_w32_set_thread_description_str
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
HANDLE id;
|
HANDLE id;
|
||||||
HANDLE lock;
|
HANDLE lock;
|
||||||
|
@ -679,6 +683,7 @@ static unsigned long __stdcall
|
||||||
timer_thread_func(void *dummy)
|
timer_thread_func(void *dummy)
|
||||||
{
|
{
|
||||||
thread_debug("timer_thread\n");
|
thread_debug("timer_thread\n");
|
||||||
|
rb_w32_set_thread_description(GetCurrentThread(), L"ruby-timer-thread");
|
||||||
while (WaitForSingleObject(timer_thread.lock, TIME_QUANTUM_USEC/1000) ==
|
while (WaitForSingleObject(timer_thread.lock, TIME_QUANTUM_USEC/1000) ==
|
||||||
WAIT_TIMEOUT) {
|
WAIT_TIMEOUT) {
|
||||||
timer_thread_function(dummy);
|
timer_thread_function(dummy);
|
||||||
|
|
|
@ -7857,6 +7857,48 @@ rb_w32_pow(double x, double y)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
int
|
||||||
|
rb_w32_set_thread_description(HANDLE th, const WCHAR *name)
|
||||||
|
{
|
||||||
|
int result = FALSE;
|
||||||
|
typedef HRESULT (WINAPI *set_thread_description_func)(HANDLE, PCWSTR);
|
||||||
|
static set_thread_description_func set_thread_description =
|
||||||
|
(set_thread_description_func)-1;
|
||||||
|
if (set_thread_description == (set_thread_description_func)-1) {
|
||||||
|
set_thread_description = (set_thread_description_func)
|
||||||
|
get_proc_address("kernel32", "SetThreadDescription", NULL);
|
||||||
|
}
|
||||||
|
if (set_thread_description != (set_thread_description_func)-1) {
|
||||||
|
result = set_thread_description(th, name);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
rb_w32_set_thread_description_str(HANDLE th, VALUE name)
|
||||||
|
{
|
||||||
|
int idx, result = FALSE;
|
||||||
|
WCHAR *s;
|
||||||
|
|
||||||
|
if (NIL_P(name)) {
|
||||||
|
rb_w32_set_thread_description(th, L"");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
s = (WCHAR *)StringValueCStr(name);
|
||||||
|
idx = rb_enc_get_index(name);
|
||||||
|
if (idx == ENCINDEX_UTF_16LE) {
|
||||||
|
result = rb_w32_set_thread_description(th, s);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
name = rb_str_conv_enc(name, rb_enc_from_index(idx), rb_utf8_encoding());
|
||||||
|
s = mbstr_to_wstr(CP_UTF8, RSTRING_PTR(name), RSTRING_LEN(name)+1, NULL);
|
||||||
|
result = rb_w32_set_thread_description(th, s);
|
||||||
|
free(s);
|
||||||
|
}
|
||||||
|
RB_GC_GUARD(name);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
VALUE (*const rb_f_notimplement_)(int, const VALUE *, VALUE) = rb_f_notimplement;
|
VALUE (*const rb_f_notimplement_)(int, const VALUE *, VALUE) = rb_f_notimplement;
|
||||||
|
|
||||||
#if RUBY_MSVCRT_VERSION < 120
|
#if RUBY_MSVCRT_VERSION < 120
|
||||||
|
|
Loading…
Add table
Reference in a new issue