116 references to BuildRequest
Microsoft.Build (116)
BackEnd\Components\Scheduler\SchedulableRequest.cs (10)
344BlockingRequestKey key = new BlockingRequestKey(blockingRequest.BuildRequest); 468public bool IsProxyBuildRequest() => BuildRequest.IsProxyBuildRequest(); 519SchedulableRequest alternateRequest = _schedulingData.GetBlockedRequestIfAny(blockingRequest.BuildRequest.GlobalRequestId); 534if (requestToEvaluate.BuildRequest.GlobalRequestId == this.BuildRequest.GlobalRequestId) 545requestToEvaluate = _schedulingData.GetBlockedRequestIfAny(requestToEvaluate.BuildRequest.GlobalRequestId); 595if (currentRequest.BuildRequest.GlobalRequestId == blockingRequest.BuildRequest.GlobalRequestId) 616BlockingRequestKey key = new BlockingRequestKey(requestWeAreBlockedBy.BuildRequest); 633throw new SchedulerCircularDependencyException(requestCausingFailure.BuildRequest, ancestors);
BackEnd\Components\Scheduler\Scheduler.cs (72)
328return request.BuildRequest; 380TraceScheduler("Circular dependency caused by request {0}({1}) (nr {2}), parent {3}({4}) (nr {5})", ex.Request.GlobalRequestId, ex.Request.ConfigurationId, ex.Request.NodeRequestId, parentRequest.BuildRequest.GlobalRequestId, parentRequest.BuildRequest.ConfigurationId, parentRequest.BuildRequest.NodeRequestId); 381responses.Add(ScheduleResponse.CreateCircularDependencyResponse(nodeId, parentRequest.BuildRequest, ex.Request)); 393TraceScheduler("Circular dependency caused by request {0}({1}) (nr {2}), parent {3}({4}) (nr {5})", ex.Request.GlobalRequestId, ex.Request.ConfigurationId, ex.Request.NodeRequestId, parentRequest.BuildRequest.GlobalRequestId, parentRequest.BuildRequest.ConfigurationId, parentRequest.BuildRequest.NodeRequestId); 394responses.Add(ScheduleResponse.CreateCircularDependencyResponse(nodeId, parentRequest.BuildRequest, ex.Request)); 432ErrorUtilities.VerifyThrow(result.ParentGlobalRequestId == request.Parent.BuildRequest.GlobalRequestId, "Result's parent doesn't match request's parent."); 441ScheduleResponse response = TrySatisfyRequestFromCache(request.Parent.AssignedNode, request.BuildRequest, skippedResultsDoNotCauseCacheMiss: _componentHost.BuildParameters.SkippedResultsDoNotCauseCacheMiss()); 469if (unscheduledRequest.BuildRequest.GlobalRequestId == result.GlobalRequestId) 471TraceScheduler("Request {0} (node request {1}) also satisfied by result.", unscheduledRequest.BuildRequest.GlobalRequestId, unscheduledRequest.BuildRequest.NodeRequestId); 472BuildResult newResult = new BuildResult(unscheduledRequest.BuildRequest, result, null); 485ScheduleResponse response = TrySatisfyRequestFromCache(parentNode, unscheduledRequest.BuildRequest, skippedResultsDoNotCauseCacheMiss: true); 490LogRequestHandledFromCache(unscheduledRequest.BuildRequest, response.BuildResult); 512_noLoggingCompletedSubmissionDetails = $"SubmissionId: {unscheduledRequest.BuildRequest.SubmissionId}; BuildRequestDataFlags: {unscheduledRequest.BuildRequest.BuildRequestDataFlags}"; 608if (request.BuildRequest.SubmissionId == submissionId) 896ReadSchedulingPlan(_schedulingData.GetRequestsByHierarchy(null).First().BuildRequest.SubmissionId); 991SchedulingPlan.PlanConfigData configToConsider = _schedulingPlan.GetConfiguration(request.BuildRequest.ConfigurationId); 1024AssignUnscheduledRequestsToInProcNode(responses, idleNodes, request => IsTraversalRequest(request.BuildRequest)); 1125int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(unscheduledRequest.BuildRequest.ConfigurationId); 1129System.IO.FileInfo f = new FileInfo(_configCache[unscheduledRequest.BuildRequest.ConfigurationId].ProjectFullPath); 1167int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(unscheduledRequest.BuildRequest.ConfigurationId); 1171System.IO.FileInfo f = new FileInfo(_configCache[unscheduledRequest.BuildRequest.ConfigurationId].ProjectFullPath); 1209BuildRequest currentRequest = currentSchedulableRequest.BuildRequest; 1383int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(request.BuildRequest.ConfigurationId); 1395TraceScheduler("Chose not to assign request {0} to node {2} because its count of configurations ({3}) exceeds the current limit ({4}).", request.BuildRequest.GlobalRequestId, request.BuildRequest.ConfigurationId, nodeId, configurationCountsByNode[nodeId], configurationCountLimit); 1417bool mustSendConfigurationToNode = _availableNodes[nodeId].AssignConfiguration(request.BuildRequest.ConfigurationId); 1421BuildRequestConfiguration config = _configCache[request.BuildRequest.ConfigurationId]; 1429responses.Add(ScheduleResponse.CreateScheduleResponse(nodeId, request.BuildRequest, mustSendConfigurationToNode)); 1430TraceScheduler("Executing request {0} on node {1} with parent {2}", request.BuildRequest.GlobalRequestId, nodeId, (request.Parent == null) ? -1 : request.Parent.BuildRequest.GlobalRequestId); 1507NodeAffinity affinity = GetNodeAffinityForRequest(request.BuildRequest); 1544int assignedNodeForConfiguration = _schedulingData.GetAssignedNodeForRequestConfiguration(request.BuildRequest.ConfigurationId); 1554NodeAffinity affinityRequired = GetNodeAffinityForRequest(request.BuildRequest); 1670_resultsCache.AddResult(new BuildResult(request.BuildRequest, new BuildAbortedException())); 1697blockingRequest.BuildRequest.ConfigurationId == blockedRequest.BuildRequest.ConfigurationId && 1716BuildRequest newRequest = new BuildRequest(parentRequest.BuildRequest.SubmissionId, BuildRequest.ResultsTransferNodeRequestId, parentRequest.BuildRequest.ConfigurationId, [], null, parentRequest.BuildRequest.BuildEventContext, parentRequest.BuildRequest, parentRequest.BuildRequest.BuildRequestDataFlags); 1728BuildRequestConfiguration configuration = _configCache[parentRequest.BuildRequest.ConfigurationId]; 1811existingRequestAffinity = GetNodeAffinityForRequest(existingRequest.BuildRequest); 1862responses.Add(ScheduleResponse.CreateResumeExecutionResponse(parentRequest.AssignedNode, parentRequest.BuildRequest.GlobalRequestId)); 1887TraceScheduler("Unblocking request {0} on node {1}", request.BuildRequest.GlobalRequestId, nodeId); 1890ScheduleResponse response = ScheduleResponse.CreateResumeExecutionResponse(nodeId, request.BuildRequest.GlobalRequestId); 1907ScheduleResponse response = TrySatisfyRequestFromCache(nodeForResults, request.BuildRequest, skippedResultsDoNotCauseCacheMiss: _componentHost.BuildParameters.SkippedResultsDoNotCauseCacheMiss()); 1913LogRequestHandledFromCache(request.BuildRequest, response.BuildResult); 1924LogRequestHandledFromCache(request.BuildRequest, response.Unblocker.Result); 1927TraceScheduler("Reporting results for request {0} with parent {1} to node {2} from cache.", request.BuildRequest.GlobalRequestId, request.BuildRequest.ParentGlobalRequestId, response.NodeId); 1942CheckIfCacheMissOnReferencedProjectIsAllowedAndErrorIfNot(nodeForResults, request.BuildRequest, responses, emitNonErrorLogs: false); 2092if (blockedRequest.BuildRequest.GlobalRequestId == request.ParentGlobalRequestId) 2094configurationId = blockedRequest.BuildRequest.ConfigurationId; 2103if (executingRequest.BuildRequest.GlobalRequestId == request.ParentGlobalRequestId) 2105configurationId = executingRequest.BuildRequest.ConfigurationId; 2336if (TargetsMatch(requestTargetsSet, existingRequest.BuildRequest.Targets)) 2338request.GlobalRequestId = existingRequest.BuildRequest.GlobalRequestId; 2441int workId = useConfigurations ? buildEvent.Request.BuildRequest.ConfigurationId : buildEvent.Request.BuildRequest.GlobalRequestId; 2637useConfigurations ? request.BuildRequest.ConfigurationId : request.BuildRequest.GlobalRequestId, 2641_configCache[request.BuildRequest.ConfigurationId].ProjectFullPath, 2642String.Join(", ", request.BuildRequest.Targets)); 2735.BuildRequest.GlobalRequestId) 2930var buildRequest = request.BuildRequest;
BackEnd\Components\Scheduler\SchedulingData.cs (28)
265if (!_configurationToRequests.TryGetValue(request.BuildRequest.ConfigurationId, out requests)) 268_configurationToRequests[request.BuildRequest.ConfigurationId] = requests; 281ErrorUtilities.VerifyThrow(_buildHierarchy.ContainsKey(parent), "Parent doesn't exist in build hierarchy for request {0}", request.BuildRequest.GlobalRequestId); 297_blockedRequests.Remove(request.BuildRequest.GlobalRequestId); 301_yieldingRequests.Remove(request.BuildRequest.GlobalRequestId); 309_executingRequests.Remove(request.BuildRequest.GlobalRequestId); 314_readyRequests.Remove(request.BuildRequest.GlobalRequestId); 333ErrorUtilities.VerifyThrow(!requestsAssignedToNode.Contains(request), "Request {0} is already scheduled to node {1}", request.BuildRequest.GlobalRequestId, request.AssignedNode); 344if (!configurationsAssignedToNode.Contains(request.BuildRequest.ConfigurationId)) 346configurationsAssignedToNode.Add(request.BuildRequest.ConfigurationId); 357ErrorUtilities.VerifyThrow(!_blockedRequests.ContainsKey(request.BuildRequest.GlobalRequestId), "Request with global id {0} is already blocked!"); 358_blockedRequests[request.BuildRequest.GlobalRequestId] = request; 362ErrorUtilities.VerifyThrow(!_yieldingRequests.ContainsKey(request.BuildRequest.GlobalRequestId), "Request with global id {0} is already yielded!"); 363_yieldingRequests[request.BuildRequest.GlobalRequestId] = request; 367ErrorUtilities.VerifyThrow(_configurationToRequests.ContainsKey(request.BuildRequest.ConfigurationId), "Configuration {0} never had requests assigned to it.", request.BuildRequest.ConfigurationId); 368ErrorUtilities.VerifyThrow(_configurationToRequests[request.BuildRequest.ConfigurationId].Count > 0, "Configuration {0} has no requests assigned to it.", request.BuildRequest.ConfigurationId); 369_configurationToRequests[request.BuildRequest.ConfigurationId].Remove(request); 379ErrorUtilities.VerifyThrow(!_executingRequests.ContainsKey(request.BuildRequest.GlobalRequestId), "Request with global id {0} is already executing!"); 382_executingRequests[request.BuildRequest.GlobalRequestId] = request; 384_configurationToNode[request.BuildRequest.ConfigurationId] = request.AssignedNode; 393ErrorUtilities.VerifyThrow(!_readyRequests.ContainsKey(request.BuildRequest.GlobalRequestId), "Request with global id {0} is already ready!"); 394_readyRequests[request.BuildRequest.GlobalRequestId] = request; 402ErrorUtilities.VerifyThrow(!readyRequestsOnNode.Contains(request), "Request with global id {0} is already marked as ready on node {1}", request.BuildRequest.GlobalRequestId, request.AssignedNode); 407ErrorUtilities.ThrowInternalError("Request with global id {0} cannot transition to the Unscheduled state", request.BuildRequest.GlobalRequestId); 550return InternalGetScheduledRequestByGlobalRequestId(request.BuildRequest.GlobalRequestId) != null; 639return CanScheduleConfigurationToNode(request.BuildRequest.ConfigurationId, nodeId);
BackEnd\Components\Scheduler\SchedulingPlan.cs (6)
211return _configCache[rootRequest.BuildRequest.ConfigurationId].ProjectFullPath + ".buildplan"; 428if (request.BuildRequest.SubmissionId == submissionId) 442file.Write(request.BuildRequest.ConfigurationId); 445file.Write(" {0}", child.BuildRequest.ConfigurationId); 465accumulatedTimeByConfiguration.TryGetValue(request.BuildRequest.ConfigurationId, out accumulatedTime); 466accumulatedTimeByConfiguration[request.BuildRequest.ConfigurationId] = accumulatedTime + request.GetTimeSpentInState(SchedulableRequestState.Executing).TotalMilliseconds;