From c09b5b7f6d8fd8aa0cf176521bae39a62d795dea Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期四, 18 七月 2019 16:44:52 +0800
Subject: [PATCH] ---

---
 ruleserver/ruleToformula.go |   31 +++++++++++++++++--------------
 1 files changed, 17 insertions(+), 14 deletions(-)

diff --git a/ruleserver/ruleToformula.go b/ruleserver/ruleToformula.go
index 75e8050..0c48495 100644
--- a/ruleserver/ruleToformula.go
+++ b/ruleserver/ruleToformula.go
@@ -101,6 +101,7 @@
 		// 鎷垮埌鏈憚鍍忔満鐨勫尯鍩�
 		cameraPolygons := GetPolygons(args.CameraId)
 		// 鎶婃墍鏈夌殑sdk鎻愬彇鐨勬暟鎹兘鎸夋墍灞炴憚鍍忔満鐨勫尯鍩熷綊缃�
+		logger.Debug("褰撳墠鎽勫儚鏈篿d涓猴細",message.Cid,"褰撳墠鎽勫儚鏈烘墽琛岀殑浠诲姟鏄細",message.Tasklab.Taskname)
 		for _, arg := range args.Sdkdata {
 			SdkDataFormat(args.CameraId, arg, cameraPolygons)
 		}
@@ -111,18 +112,20 @@
 		args.RuleResult = make(map[string]interface{})
 		args.RuleResult["yolo"] = []Result{}
 		args.RuleResult["face"] = []Arg{}
-		for _, group := range taskGroup.GroupRules {
-			//logger.Println("------------------------------浠诲姟瑙勫垯锛�",taskRule)
-			taskId := taskGroup.TaskId
-			//logger.Println("------------鏈粍浠诲姟涓嬬殑瑙勫垯缁勭殑鏁伴噺锛�",len(ruleList))
-			temp := group.Rules // temp涓轰竴缁勫畬鏁磋鍒� 鍦ㄦ闇�瑕佸垽鏂鍒欐槸鍚︽槸鑱斿姩瑙勫垯
-			if len(temp) > 0 {
-				if group.SetType == "linkTask" {
-					// groupId涓惈鏈塴ink鍒欎负鑱斿姩浠诲姟
-					LinkTask(args, group, taskId, message)
-				} else {
-					// 鐙珛浠诲姟鐨勫鐞�
-					RunRule(args, group, taskId, message)
+		if taskGroup != nil && len(taskGroup.GroupRules) > 0 {
+			for _, group := range taskGroup.GroupRules {
+				//logger.Println("------------------------------浠诲姟瑙勫垯锛�",taskRule)
+				taskId := taskGroup.TaskId
+				//logger.Println("------------鏈粍浠诲姟涓嬬殑瑙勫垯缁勭殑鏁伴噺锛�",len(ruleList))
+				temp := group.Rules // temp涓轰竴缁勫畬鏁磋鍒� 鍦ㄦ闇�瑕佸垽鏂鍒欐槸鍚︽槸鑱斿姩瑙勫垯
+				if len(temp) > 0 {
+					if group.SetType == "linkTask" {
+						// groupId涓惈鏈塴ink鍒欎负鑱斿姩浠诲姟
+						LinkTask(args, group, taskId, message)
+					} else {
+						// 鐙珛浠诲姟鐨勫鐞�
+						RunRule(args, group, taskId, message)
+					}
 				}
 			}
 		}
@@ -252,8 +255,8 @@
 	}
 	if completeFormula != "" {
 		logger.Info("缁撴灉鍏紡-----------锛�", completeFormula)
-		expression, _ := govaluate.NewEvaluableExpression(completeFormula)
-		if strings.HasPrefix(completeFormula, "&&") || strings.HasPrefix(completeFormula, "||") {
+		expression, err := govaluate.NewEvaluableExpression(completeFormula)
+		if strings.HasPrefix(completeFormula, "&&") || strings.HasPrefix(completeFormula, "||") || err != nil{
 			panic("瑙勫垯鏈夎锛屽緱鍒扮殑鏁板鍏紡涓嶅彲瑙f瀽")
 		}
 		result, _ := expression.Evaluate(nil) // 寰楀埌鏁板鍏紡鐨勭粨鏋�

--
Gitblit v1.8.0