forked from mia/Aegisub
Various improvements to autoperl
Originally committed to SVN as r1858.
This commit is contained in:
parent
05a87703ed
commit
5fd966f0f3
4 changed files with 53 additions and 44 deletions
|
@ -100,7 +100,7 @@ namespace Automation4 {
|
||||||
text = wxString(SvPV_nolen(ST(1)), pl2wx);
|
text = wxString(SvPV_nolen(ST(1)), pl2wx);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* TODO maybe: emit warning */
|
PerlLogWarning(_("Not enough parameters for Aegisub::text_extents()"));
|
||||||
// We needed 2 parameters at least!
|
// We needed 2 parameters at least!
|
||||||
XSRETURN_UNDEF;
|
XSRETURN_UNDEF;
|
||||||
}
|
}
|
||||||
|
@ -251,7 +251,7 @@ namespace Automation4 {
|
||||||
XS(perl_progress_cancelled)
|
XS(perl_progress_cancelled)
|
||||||
{
|
{
|
||||||
wxTRACE_FUNC(Aegisub::Progress::is_cancelled);
|
wxTRACE_FUNC(Aegisub::Progress::is_cancelled);
|
||||||
dXSARGS;
|
dMARK; dAX;
|
||||||
|
|
||||||
if(PerlProgressSink *ps = PerlProgressSink::GetProgressSink()) {
|
if(PerlProgressSink *ps = PerlProgressSink::GetProgressSink()) {
|
||||||
if(ps->IsCancelled()) XSRETURN_YES;
|
if(ps->IsCancelled()) XSRETURN_YES;
|
||||||
|
@ -266,8 +266,8 @@ namespace Automation4 {
|
||||||
XS(perl_console_register)
|
XS(perl_console_register)
|
||||||
{
|
{
|
||||||
wxTRACE_FUNC(Aegisub::PerlConsole::register_console);
|
wxTRACE_FUNC(Aegisub::PerlConsole::register_console);
|
||||||
dXSARGS;
|
|
||||||
#ifdef WITH_PERLCONSOLE
|
#ifdef WITH_PERLCONSOLE
|
||||||
|
dXSARGS;
|
||||||
|
|
||||||
PerlScript *script = PerlScript::GetScript();
|
PerlScript *script = PerlScript::GetScript();
|
||||||
if(script) {
|
if(script) {
|
||||||
|
@ -286,6 +286,7 @@ namespace Automation4 {
|
||||||
}
|
}
|
||||||
XSRETURN_YES;
|
XSRETURN_YES;
|
||||||
#else
|
#else
|
||||||
|
dMARK; dAX;
|
||||||
PerlLogWarning(_("Tried to register PerlConsole, but support for it was disabled in this version.")); // Warning or Hint?
|
PerlLogWarning(_("Tried to register PerlConsole, but support for it was disabled in this version.")); // Warning or Hint?
|
||||||
XSRETURN_UNDEF;
|
XSRETURN_UNDEF;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -68,7 +68,7 @@
|
||||||
|
|
||||||
// Debug support
|
// Debug support
|
||||||
/* define the following to activate tracing for the perl engine */
|
/* define the following to activate tracing for the perl engine */
|
||||||
//#define WXTRACE_AUTOPERL
|
#define WXTRACE_AUTOPERL
|
||||||
#define wxTRACE_AutoPerl _T("auto4_perl")
|
#define wxTRACE_AutoPerl _T("auto4_perl")
|
||||||
|
|
||||||
#define wxTRACE_METH(name) \
|
#define wxTRACE_METH(name) \
|
||||||
|
|
|
@ -249,6 +249,7 @@ namespace Automation4 {
|
||||||
return diag;
|
return diag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* TODO: report progress */
|
||||||
AV *PerlAss::MakeHasshLines(AV *lines, AssFile *ass)
|
AV *PerlAss::MakeHasshLines(AV *lines, AssFile *ass)
|
||||||
{
|
{
|
||||||
if(!lines) {
|
if(!lines) {
|
||||||
|
@ -436,6 +437,7 @@ namespace Automation4 {
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* TODO: report progress */
|
||||||
AssFile *PerlAss::MakeAssLines(AssFile *ass, AV *lines)
|
AssFile *PerlAss::MakeAssLines(AssFile *ass, AV *lines)
|
||||||
{
|
{
|
||||||
if(!ass) {
|
if(!ass) {
|
||||||
|
@ -443,9 +445,13 @@ namespace Automation4 {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// There may be a progress sink to report to
|
||||||
|
PerlProgressSink *ps = PerlProgressSink::GetProgressSink();
|
||||||
|
|
||||||
dAV;
|
dAV;
|
||||||
std::list<AssEntry*>::iterator it = ass->Line.begin();
|
std::list<AssEntry*>::iterator it = ass->Line.begin();
|
||||||
for(I32 i = 0; i <= av_len(lines); i++) {
|
I32 len = av_len(lines);
|
||||||
|
for(I32 i = 0; i <= len; i++) {
|
||||||
if(!av_exists(lines, i)) continue;
|
if(!av_exists(lines, i)) continue;
|
||||||
if(i < (I32)ass->Line.size()) {
|
if(i < (I32)ass->Line.size()) {
|
||||||
if(*it) delete *it;
|
if(*it) delete *it;
|
||||||
|
@ -456,6 +462,9 @@ namespace Automation4 {
|
||||||
AV_FETCH(lines, i)
|
AV_FETCH(lines, i)
|
||||||
ass->Line.push_back(MakeAssEntry((HV*)SvRV(AV_VAL)));
|
ass->Line.push_back(MakeAssEntry((HV*)SvRV(AV_VAL)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Report progress
|
||||||
|
if(ps) ps->SetProgress((i+1)/(len+1) * 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(; it != ass->Line.end();) {
|
for(; it != ass->Line.end();) {
|
||||||
|
|
|
@ -125,7 +125,6 @@ namespace Automation4 {
|
||||||
// and check on errors
|
// and check on errors
|
||||||
if(SvTRUE(_err)) {
|
if(SvTRUE(_err)) {
|
||||||
description = wxString(SvPV_nolen(_err), pl2wx);
|
description = wxString(SvPV_nolen(_err), pl2wx);
|
||||||
//wxLogError(description); // Remove?
|
|
||||||
loaded = false;
|
loaded = false;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -159,20 +158,6 @@ namespace Automation4 {
|
||||||
wxTRACE_FUNC(PerlScript::activate);
|
wxTRACE_FUNC(PerlScript::activate);
|
||||||
wxLogTrace(wxTRACE_AutoPerl, _T("name = '%s', package = '%s'"), script->GetName().c_str(), script->GetPackage().c_str());
|
wxLogTrace(wxTRACE_AutoPerl, _T("name = '%s', package = '%s'"), script->GetName().c_str(), script->GetPackage().c_str());
|
||||||
|
|
||||||
// Check if the source file is newer
|
|
||||||
/* FIX */
|
|
||||||
if(script->reload) {
|
|
||||||
// struct stat s;
|
|
||||||
// stat(script->GetFilename().mb_str(wxConvLibc), &s);
|
|
||||||
wxFileName fn(script->GetFilename());
|
|
||||||
wxDateTime mod;
|
|
||||||
fn.GetTimes(NULL,&mod,NULL);
|
|
||||||
if(script->mtime != mod.GetTicks()) {
|
|
||||||
PerlLogVerbose(wxString::Format(_("Reloading %s because the file on disk (%s) changed"), script->GetName().c_str(), script->GetFilename().c_str()));
|
|
||||||
script->Reload();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hooking $SIG{__WARN__}
|
// Hooking $SIG{__WARN__}
|
||||||
wxLogTrace(wxTRACE_AutoPerl, _T("$SIG{__WARN__} = \\&Aegisub::warn"));
|
wxLogTrace(wxTRACE_AutoPerl, _T("$SIG{__WARN__} = \\&Aegisub::warn"));
|
||||||
eval_pv("$SIG{__WARN__} = \\&Aegisub::warn", 1);
|
eval_pv("$SIG{__WARN__} = \\&Aegisub::warn", 1);
|
||||||
|
@ -200,11 +185,6 @@ namespace Automation4 {
|
||||||
PerlLogWarning(_("Unable to add the automation include path(s) to @INC: the script's code may not compile or execute properly."));
|
PerlLogWarning(_("Unable to add the automation include path(s) to @INC: the script's code may not compile or execute properly."));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Require the core modules
|
|
||||||
//load_module(PERL_LOADMOD_NOIMPORT, newSVpvn("Aegisub", 7), NULL);
|
|
||||||
//load_module(PERL_LOADMOD_NOIMPORT, newSVpvn("Aegisub::Progress", 17), NULL);
|
|
||||||
//load_module(PERL_LOADMOD_NOIMPORT, newSVpvn("Aegisub::Script", 15), NULL);
|
|
||||||
|
|
||||||
// Set the values of script vars
|
// Set the values of script vars
|
||||||
script->WriteVars();
|
script->WriteVars();
|
||||||
|
|
||||||
|
@ -234,6 +214,20 @@ namespace Automation4 {
|
||||||
// Read the values of script vars
|
// Read the values of script vars
|
||||||
active->ReadVars();
|
active->ReadVars();
|
||||||
|
|
||||||
|
// If reload flag is set...
|
||||||
|
/* STILL BROKEN :< */
|
||||||
|
if(active->reload) {
|
||||||
|
// check if the source file on disk changed
|
||||||
|
wxFileName fn(active->GetFilename());
|
||||||
|
wxDateTime mod;
|
||||||
|
fn.GetTimes(NULL,&mod,NULL);
|
||||||
|
if(active->mtime != mod.GetTicks()) {
|
||||||
|
// and reload the script
|
||||||
|
PerlLogVerbose(wxString::Format(_("Reloading %s because the file on disk (%s) changed."), active->GetName().c_str(), active->GetFilename().c_str()));
|
||||||
|
active->Reload();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Unhooking $SIG{__WARN__}
|
// Unhooking $SIG{__WARN__}
|
||||||
wxLogTrace(wxTRACE_AutoPerl, _T("undef $SIG{__WARN__}"));
|
wxLogTrace(wxTRACE_AutoPerl, _T("undef $SIG{__WARN__}"));
|
||||||
eval_pv("undef $SIG{__WARN__}", 1);
|
eval_pv("undef $SIG{__WARN__}", 1);
|
||||||
|
@ -284,9 +278,9 @@ namespace Automation4 {
|
||||||
whore = get_sv(bitch.mb_str(wx2pl), 0);
|
whore = get_sv(bitch.mb_str(wx2pl), 0);
|
||||||
if(whore) version = wxString(SvPV_nolen(whore), pl2wx);
|
if(whore) version = wxString(SvPV_nolen(whore), pl2wx);
|
||||||
|
|
||||||
bitch = package + _T("::_script_reload");
|
//bitch = package + _T("::_script_reload");
|
||||||
whore = get_sv(bitch.mb_str(wx2pl), 0);
|
//whore = get_sv(bitch.mb_str(wx2pl), 0);
|
||||||
if(whore) reload = SvTRUE(whore);
|
//if(whore) reload = SvTRUE(whore);
|
||||||
}
|
}
|
||||||
|
|
||||||
void PerlScript::WriteVars() const
|
void PerlScript::WriteVars() const
|
||||||
|
@ -423,47 +417,52 @@ namespace Automation4 {
|
||||||
AV *selected_av = newAV();
|
AV *selected_av = newAV();
|
||||||
VECTOR_AV(selected, selected_av, int, iv);
|
VECTOR_AV(selected, selected_av, int, iv);
|
||||||
|
|
||||||
script->Activate();
|
|
||||||
|
|
||||||
// Prepare the stack
|
// Prepare the stack
|
||||||
dSP;
|
dSP;
|
||||||
|
|
||||||
ENTER;
|
ENTER;
|
||||||
SAVETMPS;
|
SAVETMPS;
|
||||||
|
|
||||||
// Push the parameters on the stack
|
// Push the arguments onto the stack
|
||||||
PUSHMARK(SP);
|
PUSHMARK(SP);
|
||||||
XPUSHs(sv_2mortal(newRV_noinc((SV*)lines)));
|
SV* lines_ref = sv_2mortal(newRV_noinc((SV*)lines));
|
||||||
XPUSHs(sv_2mortal(newRV_noinc((SV*)selected_av)));
|
XPUSHs(lines_ref);
|
||||||
|
SV* selected_ref = sv_2mortal(newRV_noinc((SV*)selected_av));
|
||||||
|
XPUSHs(selected_ref);
|
||||||
XPUSHs(sv_2mortal(newSViv(active)));
|
XPUSHs(sv_2mortal(newSViv(active)));
|
||||||
PUTBACK;
|
PUTBACK;
|
||||||
|
|
||||||
// Create a progress window
|
// Create a progress window
|
||||||
PerlProgressSink *ps = new PerlProgressSink(progress_parent, GetName());
|
PerlProgressSink *ps = new PerlProgressSink(progress_parent, GetName());
|
||||||
// Start the callback thread
|
// Start the callback thread
|
||||||
|
script->Activate();
|
||||||
PerlThread call(processing_sub, G_EVAL | G_VOID);
|
PerlThread call(processing_sub, G_EVAL | G_VOID);
|
||||||
// Show the progress window
|
// Show the progress window until it is dismissed
|
||||||
ps->ShowModal();
|
ps->ShowModal();
|
||||||
// And wait unitl it's dismessed
|
|
||||||
delete ps;
|
|
||||||
// Now wait the thread to return
|
// Now wait the thread to return
|
||||||
call.Wait();
|
call.Wait();
|
||||||
|
script->Deactivate();
|
||||||
|
|
||||||
if(!SvTRUE(ERRSV)) {
|
if(!SvTRUE(ERRSV)) {
|
||||||
// Non-error: recreate the hassh :S
|
// Show progress sink again
|
||||||
|
ps->Show(true);
|
||||||
|
ps->SetTask(_("Saving changes"));
|
||||||
|
|
||||||
|
// Recreate the ass :S
|
||||||
subs->FlagAsModified(GetName());
|
subs->FlagAsModified(GetName());
|
||||||
PerlAss::MakeAssLines(subs, lines);
|
PerlAss::MakeAssLines(subs, (AV*)SvRV(lines_ref));
|
||||||
// And reset selection vector
|
// And reset selection vector
|
||||||
selected.clear();
|
selected.clear();
|
||||||
AV_VECTOR(selected_av, selected, IV);
|
AV_VECTOR((AV*)SvRV(selected_ref), selected, IV);
|
||||||
CHOP_SELECTED(subs, selected);
|
CHOP_SELECTED(subs, selected);
|
||||||
}
|
|
||||||
|
|
||||||
// Clean everything
|
ps->Hide();
|
||||||
|
}
|
||||||
|
// Delete the progress sink
|
||||||
|
ps->Destroy();
|
||||||
|
|
||||||
|
// Clean the call stack
|
||||||
FREETMPS;
|
FREETMPS;
|
||||||
LEAVE;
|
LEAVE;
|
||||||
|
|
||||||
script->Deactivate();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue