2

鉴于NSAppleScript对象总是应该在主线程上运行,我创建了一个小的“代理”对象来使用:

@interface AppleScriptProxy : NSObject {
    NSAppleScript *m_script;
    NSDictionary *m_errorDict;
}

- (id) init;

- (void) compileScript:
    (NSString*)script;

- (void) dealloc;

- (NSDictionary*) errorDict;

- (BOOL) failed;

- (void) runScript:
    (id)notUsed;

@end

@implementation AppleScriptProxy

- (id) init
{
    self = [super init];
    m_errorDict = nil;
    m_script = nil;
    return self;
}

- (void) dealloc
{
    //[m_errorDict release];
    [m_script release];
    [super dealloc];
}

- (void) compileScript:
    (NSString*)source
{
    m_script = [[NSAppleScript alloc] initWithSource:source];
    if ( m_script )
        if ( [m_script compileAndReturnError:&m_errorDict] ) {
            cerr << "compiled" << endl;
            [m_script retain];
        } else {
            cerr << "not compiled" << endl;
            m_script = nil;
        }
}

- (NSDictionary*) errorDict
{
    return m_errorDict;
}

- (BOOL) failed
{
    return !m_script || m_errorDict;
}

- (void) runScript:
    (id)notUsed
{
    [m_script executeAndReturnError:nil];
}

@end

然后,编译并执行 AppleScript:

NSString *const script = /* some script */;

[proxy
    performSelectorOnMainThread:@selector(compileScript:)
    withObject:script waitUntilDone:YES];

if ( [proxy failed] ) {
    NSDictionary *errorDict = [proxy errorDict];
    NSString const *const errorMsg = errorDict ?
        [errorDict objectForKey:NSAppleScriptErrorMessage] :
        @"NSAppleScript initWithSource failed";
    cerr << [errorMsg UTF8String] << endl;
    return 1;
}

[proxy retain];
[proxy
    performSelectorOnMainThread:@selector(runScript:)
    withObject:nil waitUntilDone:NO];
[proxy autorelease];

如果我编译了一个有效的脚本,它会按预期工作;但是,如果我编译一个乱码脚本,例如“foo”,compileAndReturnError它不会失败,也就是说,它会返回YES并且m_errorDict仍然是nil.

为什么?

4

1 回答 1

1

在脚本编辑器中尝试。“foo”编译得很好;它只是不运行。

尝试将“<code>*”作为您的编译测试脚本。

顺便说一句,运行脚本也会引发错误(如您在脚本编辑器中所见)。确保你处理好。

于 2009-06-04T04:08:27.253 回答