| 
					
				 | 
			
			
				@@ -298,13 +298,18 @@ namespace WCS.Service.Works.Station 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                           .Where(v => v.ROUTES.Any(p => p.NEXT == item)) //下一个点为当前巷道的取货点 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                           .Select(v => v.CODE) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                           .ToList(); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                        var putStation = Device.Where(v => v.IsConv() && v.ROUTES.Any(p => p.NEXT != null && allIn.Contains(p.NEXT.CODE))) //下一个目标地址包含取货点的设备 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        //下一个目标地址包含取货点的设备,此时获得的数据是旋转台 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        var turntable = Device.Where(v => v.IsConv() && v.ROUTES.Any(p => p.NEXT != null && allIn.Contains(p.NEXT.CODE))).Select(v => v.CODE); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        //获得RGV的交货点 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        var rgvDeliveryPoint = Device.Where(v => v.IsConv() && v.ROUTES.Any(p => p.NEXT != null && turntable.Contains(p.NEXT.CODE))) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                       .Select(v => v.Create<StationDevice>()) //取所有可以到达取货点设备的信息 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                       .Where(v => !v.Data3.Status.HasFlag(StationStatus.运行状态位) && !v.Data2.Status.HasFlag(IstationStatus.光电状态) && v.Data2.Tasknum < 10000)//筛选出空闲的路径点,此处因输送机都是一个动力,因此可以先找路径点再找设备组 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                       .Distinct() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                                       .FirstOrDefault();//去一次重 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                        if (putStation == null) continue; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                        var taskInStation = Device.Where(p => p.CODE.StartsWith("G") && p.DEVICEGROUP.Any(d => d.MEMBER == putStation.Entity)).OrderBy(p => p.CODE).FirstOrDefault(); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        if (rgvDeliveryPoint == null) continue; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        var taskInStation = Device.Where(p => p.CODE.StartsWith("G") && p.DEVICEGROUP.Any(d => d.MEMBER == rgvDeliveryPoint.Entity)).OrderBy(p => p.CODE).FirstOrDefault(); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                         //RGV是否有正在前往这个地址的任务 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                         var rgvList = Device.Where(v => v.Is(DF.涂布RGV)).Select(v => v.Create<RGVDevice>()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                         if (rgvList.Any(v => !v.Data2.SystemStatus.HasFlag(WCS.Entity.Protocol.RGV.RGVRunStatus.空闲) 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -391,7 +396,7 @@ namespace WCS.Service.Works.Station 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                 DB.Do(db => 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                 { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                     var devs = obj.Items.Where(v => v.Data2.Status.HasFlag(IstationStatus.光电状态) && v.Data2.Request == IstationRequest.请求分配目标地址) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                                           .Where(v => v.Data2.Tasknum > 10000 ); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                                           .Where(v => v.Data2.Tasknum > 10000); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                     if (!devs.Any()) return; //无可执行任务 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                     var taskIds = devs.Select(dev => dev.Data2.Tasknum).ToList(); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				                     var taskList = db.Default.Set<WCS_TASK>().Where(v => taskIds.Contains(v.ID)).ToList(); 
			 |