Changed Automation's autoload to ignore files of unknown extensions, instead of complaining about being unable to load them. This is necessary for the optional Perl support.
Originally committed to SVN as r1762.
This commit is contained in:
parent
7ffc21cc7e
commit
85e100c4f7
4 changed files with 33 additions and 8 deletions
|
@ -674,10 +674,13 @@ namespace Automation4 {
|
||||||
while (more) {
|
while (more) {
|
||||||
script_path.SetName(fn);
|
script_path.SetName(fn);
|
||||||
try {
|
try {
|
||||||
Script *s = ScriptFactory::CreateFromFile(script_path.GetFullPath(), true);
|
wxString fullpath = script_path.GetFullPath();
|
||||||
|
if (ScriptFactory::CanHandleScriptFormat(fullpath)) {
|
||||||
|
Script *s = ScriptFactory::CreateFromFile(fullpath, true);
|
||||||
Add(s);
|
Add(s);
|
||||||
if (!s->GetLoadedState()) error_count++;
|
if (!s->GetLoadedState()) error_count++;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
catch (const wchar_t *e) {
|
catch (const wchar_t *e) {
|
||||||
error_count++;
|
error_count++;
|
||||||
wxLogError(_T("Error loading Automation script: %s\n%s"), fn.c_str(), e);
|
wxLogError(_T("Error loading Automation script: %s\n%s"), fn.c_str(), e);
|
||||||
|
@ -764,6 +767,21 @@ namespace Automation4 {
|
||||||
return new UnknownScript(filename);
|
return new UnknownScript(filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ScriptFactory::CanHandleScriptFormat(const wxString &filename)
|
||||||
|
{
|
||||||
|
// Just make this always return true to bitch about unknown script formats in autoload
|
||||||
|
|
||||||
|
if (!factories)
|
||||||
|
factories = new std::vector<ScriptFactory*>();
|
||||||
|
|
||||||
|
for (std::vector<ScriptFactory*>::iterator i = factories->begin(); i != factories->end(); ++i) {
|
||||||
|
wxString pattern = (*i)->GetFilenamePattern();
|
||||||
|
if (filename.Matches(pattern)) return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
const std::vector<ScriptFactory*>& ScriptFactory::GetFactories()
|
const std::vector<ScriptFactory*>& ScriptFactory::GetFactories()
|
||||||
{
|
{
|
||||||
if (!factories)
|
if (!factories)
|
||||||
|
|
|
@ -352,6 +352,7 @@ namespace Automation4 {
|
||||||
static void Register(ScriptFactory *factory);
|
static void Register(ScriptFactory *factory);
|
||||||
static void Unregister(ScriptFactory *factory);
|
static void Unregister(ScriptFactory *factory);
|
||||||
static Script* CreateFromFile(const wxString &filename, bool log_errors);
|
static Script* CreateFromFile(const wxString &filename, bool log_errors);
|
||||||
|
static bool CanHandleScriptFormat(const wxString &filename);
|
||||||
static const std::vector<ScriptFactory*>& GetFactories();
|
static const std::vector<ScriptFactory*>& GetFactories();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -69,11 +69,13 @@ namespace Automation4 {
|
||||||
class PerlScriptFactory : public ScriptFactory {
|
class PerlScriptFactory : public ScriptFactory {
|
||||||
private:
|
private:
|
||||||
PerlInterpreter *parser;
|
PerlInterpreter *parser;
|
||||||
|
bool loaded;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
PerlScriptFactory()
|
PerlScriptFactory()
|
||||||
{
|
{
|
||||||
// Script engine properties
|
// Script engine properties
|
||||||
|
loaded = false;
|
||||||
engine_name = _T("Perl");
|
engine_name = _T("Perl");
|
||||||
filename_pattern = _T("*") _T(PERL_SCRIPT_EXTENSION);
|
filename_pattern = _T("*") _T(PERL_SCRIPT_EXTENSION);
|
||||||
|
|
||||||
|
@ -103,17 +105,20 @@ namespace Automation4 {
|
||||||
|
|
||||||
// Let's register the perl script factory \o/
|
// Let's register the perl script factory \o/
|
||||||
Register(this);
|
Register(this);
|
||||||
|
loaded = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
~PerlScriptFactory()
|
~PerlScriptFactory()
|
||||||
{
|
{
|
||||||
// Perl interpreter deinitialization
|
// Perl interpreter deinitialization
|
||||||
|
if (loaded) {
|
||||||
perl_destruct(parser);
|
perl_destruct(parser);
|
||||||
perl_free(parser);
|
perl_free(parser);
|
||||||
#ifdef __VISUALC__
|
#ifdef __VISUALC__
|
||||||
PERL_SYS_TERM();
|
PERL_SYS_TERM();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
virtual Script* Produce(const wxString &filename) const
|
virtual Script* Produce(const wxString &filename) const
|
||||||
{
|
{
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
;
|
;
|
||||||
|
|
||||||
#define MyAppName "Aegisub"
|
#define MyAppName "Aegisub"
|
||||||
#define MyAppVerName "Aegisub 2.00 alpha r1760"
|
#define MyAppVerName "Aegisub 2.00 alpha r1762"
|
||||||
#define MyAppPublisher "Aegisub Team"
|
#define MyAppPublisher "Aegisub Team"
|
||||||
#define MyAppURL "http://aegisub.net/"
|
#define MyAppURL "http://aegisub.net/"
|
||||||
#define MyAppExeName "Aegisub.exe"
|
#define MyAppExeName "Aegisub.exe"
|
||||||
|
@ -68,7 +68,7 @@ PrivilegesRequired=poweruser
|
||||||
DisableProgramGroupPage=true
|
DisableProgramGroupPage=true
|
||||||
UsePreviousGroup=false
|
UsePreviousGroup=false
|
||||||
AlwaysShowComponentsList=true
|
AlwaysShowComponentsList=true
|
||||||
AppVersion=2.00 alpha r1760
|
AppVersion=2.00 alpha r1762
|
||||||
AppID={{24BC8B57-716C-444F-B46B-A3349B9164C5}
|
AppID={{24BC8B57-716C-444F-B46B-A3349B9164C5}
|
||||||
UninstallDisplayIcon={app}\Aegisub.exe
|
UninstallDisplayIcon={app}\Aegisub.exe
|
||||||
|
|
||||||
|
@ -115,6 +115,7 @@ DestDir: {app}\automation\autoload; Source: ..\automation\autoload\cleantags-aut
|
||||||
; perl
|
; perl
|
||||||
#if IncludePerl != 0
|
#if IncludePerl != 0
|
||||||
DestDir: {app}\automation\docs; Source: ..\automation\v4-docs\perl-api.txt; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
DestDir: {app}\automation\docs; Source: ..\automation\v4-docs\perl-api.txt; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
||||||
|
DestDir: {app}\automation\include; Source: ..\automation\include\Aegisub.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
||||||
DestDir: {app}\automation\include; Source: ..\automation\include\Auto4Utils.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
DestDir: {app}\automation\include; Source: ..\automation\include\Auto4Utils.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
||||||
DestDir: {app}\automation\include\Aegisub; Source: ..\automation\include\Aegisub\PerlConsole.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
DestDir: {app}\automation\include\Aegisub; Source: ..\automation\include\Aegisub\PerlConsole.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
||||||
DestDir: {app}\automation\include\Aegisub; Source: ..\automation\include\Aegisub\Script.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
DestDir: {app}\automation\include\Aegisub; Source: ..\automation\include\Aegisub\Script.pm; Flags: ignoreversion overwritereadonly uninsremovereadonly; Components: auto/perl; Attribs: readonly
|
||||||
|
|
Loading…
Reference in a new issue