1

我不完全知道我做了什么,但似乎我破坏了我的构建系统。

$ scons install
scons: Reading SConscript files ...
File "<string>", line 1

I_���.�K
        H�4����Ǐ��U)�f���R�f���ў�U)�f���R�f���ў�

   ^

SyntaxError: invalid syntax

不可打印的字符是有意的。

坏事是:即使在“已知的工作”版本上重置也无济于事,以及使用--debug=stacktrace. 我的版本控制系统(mercurial)没有显示SCons文件中的更改,我不知道如何继续。任何提示如何让 mercurial 打印它正在处理的文件的名称以找出发生了什么?

我的下一步是对该项目进行新的克隆(希望能够构建),但我很好奇这里出了什么问题。

更新

当我更新到 Ubuntu 12.04 时问题消失了。在这种情况下,“消失”意味着我突然能够执行scons --clean命令,之后我能够再次重建我的项目。可悲的是,我无法重现该错误,因此最后我不知道是什么原因造成的,因为它工作了几个月,而且我的同事之前都没有遇到过如此奇怪的错误。

这是我的脚本的摘录:

vars = Variables( "variables.cache" )
vars.Add( "CXX", "use this c++ compiler", "/usr/bin/g++" )
# (other stuff added to vars)

env = Environment( variables = vars )  # <-- this line caused the error

在解决这个问题的过程中,我得到的印象是,在更新之后,Python 能够给我一个更好的错误消息,并且该消息(试图记住它)vars在某种程度上是无效的。所以也许问题出在variables.cache,我不知道。也许我应该删除这个文件(我没有删除)以消除错误。

4

1 回答 1

1

尝试执行带有警告的 scons,如下所示:

# scons --warn=all

如果这没有帮助,您可以尝试一种更老式的方法,并在 SConstruct 中放置一些打印语句,以查看发生了什么以及问题发生的时间/地点。

您还可以尝试清理整个项目并删除/重命名根项目中的 .sconsdb.lite。

更新:

我最近遇到了一个问题,因为 Python 的版本从 2.6 更改为 2.7,并且错误处理完全改变了。因此,尝试在 SConstruct 中的所有内容(或至少是战略部分)周围放置一个 python try/except 块,并打印抛出的异常(如果有)。

如果这些都不起作用,请尝试在此处发布 SConstruct。

我的代码示例SConstruct演示了我如何使用 Python try/except 块发现我的错误。BuildError 异常给了我一个堆栈跟踪。您可以“捕捉”更多例外情况。

...
try:
    SConscript(
        os.path.join(moduleDir, 'SConscript'),                        # sub-directory SConscript to load
        variant_dir = '#%s' % os.path.join(env['variantDir'], dir),   # path relative to this script where to put built files
        exports = ['env'],                                         # which variables to export to sub-directory build
        duplicate = 0)                                             # dont duplicate source files in variant_dir
except SCons.Errors.BuildError as be:
    print "*** BuildError exception processing module: %s, %s" % (moduleDir, be.__str__())
    raise
except:
    print "*** Unhandled exception processing module: %s" % moduleDir
    raise
于 2012-05-21T16:15:19.607 回答