Show More
@@ -635,21 +635,35 b' if pycompat.iswindows:' | |||||
635 | stderr=None, |
|
635 | stderr=None, | |
636 | ensurestart=True, |
|
636 | ensurestart=True, | |
637 | record_wait=None, |
|
637 | record_wait=None, | |
|
638 | stdin_bytes=None, | |||
638 | ): |
|
639 | ): | |
639 | '''Spawn a command without waiting for it to finish.''' |
|
640 | '''Spawn a command without waiting for it to finish.''' | |
640 | # we can't use close_fds *and* redirect stdin. I'm not sure that we |
|
641 | # we can't use close_fds *and* redirect stdin. I'm not sure that we | |
641 | # need to because the detached process has no console connection. |
|
642 | # need to because the detached process has no console connection. | |
|
643 | ||||
|
644 | try: | |||
|
645 | stdin = None | |||
|
646 | if stdin_bytes is not None: | |||
|
647 | stdin = pycompat.unnamedtempfile() | |||
|
648 | stdin.write(stdin_bytes) | |||
|
649 | stdin.flush() | |||
|
650 | stdin.seek(0) | |||
|
651 | ||||
642 | p = subprocess.Popen( |
|
652 | p = subprocess.Popen( | |
643 | tonativestr(script), |
|
653 | tonativestr(script), | |
644 | shell=shell, |
|
654 | shell=shell, | |
645 | env=tonativeenv(env), |
|
655 | env=tonativeenv(env), | |
646 | close_fds=True, |
|
656 | close_fds=True, | |
647 | creationflags=_creationflags, |
|
657 | creationflags=_creationflags, | |
|
658 | stdin=stdin, | |||
648 | stdout=stdout, |
|
659 | stdout=stdout, | |
649 | stderr=stderr, |
|
660 | stderr=stderr, | |
650 | ) |
|
661 | ) | |
651 | if record_wait is not None: |
|
662 | if record_wait is not None: | |
652 | record_wait(p.wait) |
|
663 | record_wait(p.wait) | |
|
664 | finally: | |||
|
665 | if stdin is not None: | |||
|
666 | stdin.close() | |||
653 |
|
667 | |||
654 |
|
668 | |||
655 | else: |
|
669 | else: | |
@@ -662,6 +676,7 b' else:' | |||||
662 | stderr=None, |
|
676 | stderr=None, | |
663 | ensurestart=True, |
|
677 | ensurestart=True, | |
664 | record_wait=None, |
|
678 | record_wait=None, | |
|
679 | stdin_bytes=None, | |||
665 | ): |
|
680 | ): | |
666 | '''Spawn a command without waiting for it to finish. |
|
681 | '''Spawn a command without waiting for it to finish. | |
667 |
|
682 | |||
@@ -722,15 +737,21 b' else:' | |||||
722 | if record_wait is None: |
|
737 | if record_wait is None: | |
723 | # Start a new session |
|
738 | # Start a new session | |
724 | os.setsid() |
|
739 | os.setsid() | |
|
740 | # connect stdin to devnull to make sure the subprocess can't | |||
|
741 | # muck up that stream for mercurial. | |||
|
742 | if stdin_bytes is None: | |||
|
743 | stdin = open(os.devnull, b'r') | |||
|
744 | else: | |||
|
745 | stdin = pycompat.unnamedtempfile() | |||
|
746 | stdin.write(stdin_bytes) | |||
|
747 | stdin.flush() | |||
|
748 | stdin.seek(0) | |||
725 |
|
749 | |||
726 | stdin = open(os.devnull, b'r') |
|
|||
727 | if stdout is None: |
|
750 | if stdout is None: | |
728 | stdout = open(os.devnull, b'w') |
|
751 | stdout = open(os.devnull, b'w') | |
729 | if stderr is None: |
|
752 | if stderr is None: | |
730 | stderr = open(os.devnull, b'w') |
|
753 | stderr = open(os.devnull, b'w') | |
731 |
|
754 | |||
732 | # connect stdin to devnull to make sure the subprocess can't |
|
|||
733 | # muck up that stream for mercurial. |
|
|||
734 | p = subprocess.Popen( |
|
755 | p = subprocess.Popen( | |
735 | cmd, |
|
756 | cmd, | |
736 | shell=shell, |
|
757 | shell=shell, | |
@@ -754,5 +775,6 b' else:' | |||||
754 | finally: |
|
775 | finally: | |
755 | # mission accomplished, this child needs to exit and not |
|
776 | # mission accomplished, this child needs to exit and not | |
756 | # continue the hg process here. |
|
777 | # continue the hg process here. | |
|
778 | stdin.close() | |||
757 | if record_wait is None: |
|
779 | if record_wait is None: | |
758 | os._exit(returncode) |
|
780 | os._exit(returncode) |
General Comments 0
You need to be logged in to leave comments.
Login now