派生自 libgowrapper/face

zhangmeng
2020-01-15 54dfcb8da5af779453051ab2f9657115083eb57d
run.go
@@ -2,7 +2,6 @@
import (
   "context"
   "os"
   "sync"
   "time"
   "unsafe"
@@ -13,8 +12,6 @@
   "basic.com/valib/gogpu.git"
   "github.com/gogo/protobuf/proto"
)
const maxTryBeforeReboot = 10
type face struct {
   handle *SDKFace
@@ -34,39 +31,7 @@
   ruleMsgMaxCacheSize int
   reserved            map[string]interface{}
   running     bool
   rebootUntil int
   mtxRunning  sync.Mutex
}
func (f *face) maybeReboot(ctx context.Context) {
   for {
      select {
      case <-ctx.Done():
         return
      default:
         f.mtxRunning.Lock()
         running := f.running
         f.mtxRunning.Unlock()
         if running {
            f.rebootUntil = 0
            f.mtxRunning.Lock()
            f.running = false
            f.mtxRunning.Unlock()
         } else {
            f.rebootUntil++
            f.fnLogger("Face No Running: ", f.rebootUntil)
            if f.rebootUntil > maxTryBeforeReboot {
               f.fnLogger("Face Too Long Running, Reboot")
               os.Exit(0)
            }
         }
         time.Sleep(time.Second)
      }
   }
   stopper *common.Disturber
}
// Create create sdk
@@ -153,8 +118,7 @@
      ruleMsgMaxCacheSize: ruleMaxSize,
      reserved:            reserved,
      running:     true,
      rebootUntil: maxTryBeforeReboot,
      stopper: common.NewDisturber(),
   }
}
@@ -189,7 +153,7 @@
   go s.run(ctx, chRcv, chSnd)
   go s.maybeReboot(ctx)
   go s.stopper.MaybeReboot(ctx, s.fnLogger)
}
//////////////////////////////////////////////////////////////////
@@ -352,9 +316,7 @@
         // f.fnLogger("Face~~~EjectResult", dtchn)
         common.EjectResult(data, rMsg, out)
         // f.fnLogger("Face~~~EjectResult Over", dtchn)
         f.mtxRunning.Lock()
         f.running = true
         f.mtxRunning.Unlock()
         f.stopper.Prevent()
         var id, name string
         if rMsg.Msg.Tasklab != nil {