mirror of
https://github.com/irssi/irssi.git
synced 2025-01-03 14:56:47 -05:00
return value wasn't a good idea after all - added Irssi::timeout_add_once()
instead. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@2758 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
parent
0d76b65381
commit
c1384d919b
src/perl
@ -193,7 +193,22 @@ CODE:
|
||||
croak("Irssi::timeout() : msecs must be >= 10");
|
||||
RETVAL = -1;
|
||||
} else {
|
||||
RETVAL = perl_timeout_add(msecs, func, data);
|
||||
RETVAL = perl_timeout_add(msecs, func, data, FALSE);
|
||||
}
|
||||
OUTPUT:
|
||||
RETVAL
|
||||
|
||||
int
|
||||
timeout_add_once(msecs, func, data)
|
||||
int msecs
|
||||
SV *func
|
||||
SV *data
|
||||
CODE:
|
||||
if (msecs < 10) {
|
||||
croak("Irssi::timeout_once() : msecs must be >= 10");
|
||||
RETVAL = -1;
|
||||
} else {
|
||||
RETVAL = perl_timeout_add(msecs, func, data, TRUE);
|
||||
}
|
||||
OUTPUT:
|
||||
RETVAL
|
||||
|
@ -29,6 +29,7 @@ typedef struct {
|
||||
PERL_SCRIPT_REC *script;
|
||||
int tag;
|
||||
int refcount;
|
||||
int once; /* run only once */
|
||||
|
||||
SV *func;
|
||||
SV *data;
|
||||
@ -41,14 +42,15 @@ static void perl_source_ref(PERL_SOURCE_REC *rec)
|
||||
rec->refcount++;
|
||||
}
|
||||
|
||||
static void perl_source_unref(PERL_SOURCE_REC *rec)
|
||||
static int perl_source_unref(PERL_SOURCE_REC *rec)
|
||||
{
|
||||
if (--rec->refcount != 0)
|
||||
return;
|
||||
return TRUE;
|
||||
|
||||
SvREFCNT_dec(rec->data);
|
||||
SvREFCNT_dec(rec->func);
|
||||
g_free(rec);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static void perl_source_destroy(PERL_SOURCE_REC *rec)
|
||||
@ -81,12 +83,10 @@ static int perl_source_event(PERL_SOURCE_REC *rec)
|
||||
char *error = g_strdup(SvPV(ERRSV, PL_na));
|
||||
signal_emit("script error", 2, rec->script, error);
|
||||
g_free(error);
|
||||
} else if (retcount > 0 && POPi != 0) {
|
||||
/* stopped */
|
||||
perl_source_destroy(rec);
|
||||
}
|
||||
|
||||
perl_source_unref(rec);
|
||||
if (perl_source_unref(rec) && rec->once)
|
||||
perl_source_destroy(rec);
|
||||
|
||||
PUTBACK;
|
||||
FREETMPS;
|
||||
@ -95,7 +95,7 @@ static int perl_source_event(PERL_SOURCE_REC *rec)
|
||||
return 1;
|
||||
}
|
||||
|
||||
int perl_timeout_add(int msecs, SV *func, SV *data)
|
||||
int perl_timeout_add(int msecs, SV *func, SV *data, int once)
|
||||
{
|
||||
PERL_SCRIPT_REC *script;
|
||||
PERL_SOURCE_REC *rec;
|
||||
@ -117,7 +117,7 @@ int perl_timeout_add(int msecs, SV *func, SV *data)
|
||||
return rec->tag;
|
||||
}
|
||||
|
||||
int perl_input_add(int source, int condition, SV *func, SV *data)
|
||||
int perl_input_add(int source, int condition, SV *func, SV *data, int once)
|
||||
{
|
||||
PERL_SCRIPT_REC *script;
|
||||
PERL_SOURCE_REC *rec;
|
||||
|
Loading…
Reference in New Issue
Block a user