运行过程并在完成时通知

时间:2018-10-22 17:29:44

标签: go

我正在使用以下正常工作的代码, 现在,我想通知该过程何时完成

我尝试在wait之后添加另一个功能,但这没有帮助

我需要知道所有命令何时成功完成并将消息发送到其他程序包,我该怎么办? 或仅在Invoke函数完成所有执行

时调用其他函数
 cmdParams := [][]string{
        {filepath.Join(dir, path), "npm", "install"},
        {filepath.Join(pdir, n.path), "gulp"},
    }

func Invoke(cmdParams [][]string) error {
    for _, cp := range cmdParams {
        log.Printf("Starting %s in folder %s...", cp[1:], cp[0])
        cmd := exec.Command(cp[1], cp[2:]...)
        cmd.Dir = cp[0]

        stdout, err := cmd.StdoutPipe()
        if err != nil {
            log.Printf("%s cmd.StdoutPipe() error: %v\n", cp[1:], err)
            return
        }
        // Start command:
        if err = cmd.Start(); err != nil {
            log.Printf("%s start error: %v\n", cp[1:], err)
            return
        }

        // Stream command output:
        scanner := bufio.NewScanner(stdout)
        scanner.Split(bufio.ScanRunes)
        for scanner.Scan() {
            fmt.Print(scanner.Text())
        }
        if scanner.Err() != nil {
            log.Printf("Reading %s stdout error: %v\n", cp[1:], err)
            return
        }

        // Get execution success or failure:
        if err = cmd.Wait(); err != nil {
            log.Printf("Error running %s: %v\n", cp[1:], err)
            return
        }
        log.Printf("Finished %s", cp[1:])
    } 

0 个答案:

没有答案