config/check_utils.py
author Masayuki Nakano <masayuki@d-toybox.com>
Wed, 15 Mar 2017 19:09:30 +0900
changeset 347953 eaf379d6fc13817124ce58bac152028b277ceeda
parent 267943 0085266cdfd3c77dae0e2711bae9002246c65e36
permissions -rw-r--r--
Bug 1347433 part.3 TextEventDispatcher::PendingComposition::Flush() should replace native line breakers in the composition string before dispatching composition event r=m_kato So, finally, Flush() should replace native line breakers in the composition string before dispatching composition events. However, if the composition string was set by Set(), i.e., it's already been replaced with native line breakers, we shouldn't try to do it again due to performance reason. Therefore, this patch adds |mReplacedNativeLineBreakers| to manage if it's already been called. MozReview-Commit-ID: 5Y7ULWeP153

# vim: set ts=8 sts=4 et sw=4 tw=99:
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.

import subprocess

def get_all_toplevel_filenames():
    '''Get a list of all the files in the (Mercurial or Git) repository.'''
    failed_cmds = []
    try:
        cmd = ['hg', 'manifest', '-q']
        all_filenames = subprocess.check_output(cmd, universal_newlines=True,
                                                stderr=subprocess.PIPE).split('\n')
        return all_filenames
    except:
        failed_cmds.append(cmd)

    try:
        # Get the relative path to the top-level directory.
        cmd = ['git', 'rev-parse', '--show-cdup']
        top_level = subprocess.check_output(cmd, universal_newlines=True,
                                                stderr=subprocess.PIPE).split('\n')[0]
        cmd = ['git', 'ls-files', '--full-name', top_level]
        all_filenames = subprocess.check_output(cmd, universal_newlines=True,
                                                stderr=subprocess.PIPE).split('\n')
        return all_filenames
    except:
        failed_cmds.append(cmd)

    raise Exception('failed to run any of the repo manifest commands', failed_cmds)