| # Copyright (C) 2009 Kevin Ollivier All rights reserved. |
| # |
| # Redistribution and use in source and binary forms, with or without |
| # modification, are permitted provided that the following conditions |
| # are met: |
| # 1. Redistributions of source code must retain the above copyright |
| # notice, this list of conditions and the following disclaimer. |
| # 2. Redistributions in binary form must reproduce the above copyright |
| # notice, this list of conditions and the following disclaimer in the |
| # documentation and/or other materials provided with the distribution. |
| # |
| # THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY |
| # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR |
| # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| # PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| # OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| # |
| # This module is for code where we override waf's default behavior or extend waf |
| |
| import os |
| import subprocess |
| import sys |
| |
| import Utils |
| |
| # version of exec_command that handles Windows command lines longer than 32000 chars |
| def exec_command(s, **kw): |
| filename = '' |
| if sys.platform.startswith('win') and len(' '.join(s)) > 32000: |
| import tempfile |
| (fd, filename) = tempfile.mkstemp() |
| t = [] |
| for i in s: |
| if i.find(" ") != -1: |
| i = '"%s"' % i |
| t.append(i) |
| |
| t1 = t[1:] |
| # Fix for LNK1170 error |
| filename_str = '@' + filename |
| filename2_str = None |
| if len(' '.join(s)) > 131070: |
| t2 = t[len(t) / 2:] |
| t1 = t[1:len(t) / 2] |
| (fd2, filename2) = tempfile.mkstemp() |
| os.write(fd2, ' '.join(t2)) |
| os.close(fd2) |
| filename2_str = '@' + filename2 |
| os.write(fd, ' '.join(t1)) |
| os.close(fd) |
| |
| s = [s[0]] |
| s.append(filename_str) |
| if filename2_str: |
| s.append(filename2_str) |
| |
| if 'log' in kw: |
| kw['stdout'] = kw['stderr'] = kw['log'] |
| del(kw['log']) |
| kw['shell'] = isinstance(s, str) |
| |
| def cleanup(): |
| try: |
| if os.path.exists(filename): |
| os.remove(filename) |
| except: |
| pass |
| |
| try: |
| proc = subprocess.Popen(s, **kw) |
| result = proc.wait() |
| cleanup() |
| return result |
| |
| except OSError: |
| cleanup() |
| raise |
| |
| Utils.exec_command = exec_command |
| |
| # Better performing h_file to keep hashing from consuming lots of time |
| import stat |
| def h_file(filename): |
| st = os.stat(filename) |
| if stat.S_ISDIR(st[stat.ST_MODE]): raise IOError('not a file') |
| m = Utils.md5() |
| m.update(str(st.st_mtime)) |
| m.update(str(st.st_size)) |
| m.update(filename) |
| return m.digest() |
| |
| Utils.h_file = h_file |