116 references to BuildRequest
Microsoft.Build (116)
BackEnd\Components\Scheduler\SchedulableRequest.cs (10)
344
BlockingRequestKey key = new BlockingRequestKey(blockingRequest.
BuildRequest
);
468
public bool IsProxyBuildRequest() =>
BuildRequest
.IsProxyBuildRequest();
519
SchedulableRequest alternateRequest = _schedulingData.GetBlockedRequestIfAny(blockingRequest.
BuildRequest
.GlobalRequestId);
534
if (requestToEvaluate.
BuildRequest
.GlobalRequestId == this.
BuildRequest
.GlobalRequestId)
545
requestToEvaluate = _schedulingData.GetBlockedRequestIfAny(requestToEvaluate.
BuildRequest
.GlobalRequestId);
595
if (currentRequest.
BuildRequest
.GlobalRequestId == blockingRequest.
BuildRequest
.GlobalRequestId)
616
BlockingRequestKey key = new BlockingRequestKey(requestWeAreBlockedBy.
BuildRequest
);
633
throw new SchedulerCircularDependencyException(requestCausingFailure.
BuildRequest
, ancestors);
BackEnd\Components\Scheduler\Scheduler.cs (72)
327
return request.
BuildRequest
;
379
TraceScheduler("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);
380
responses.Add(ScheduleResponse.CreateCircularDependencyResponse(nodeId, parentRequest.
BuildRequest
, ex.Request));
392
TraceScheduler("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);
393
responses.Add(ScheduleResponse.CreateCircularDependencyResponse(nodeId, parentRequest.
BuildRequest
, ex.Request));
431
ErrorUtilities.VerifyThrow(result.ParentGlobalRequestId == request.Parent.
BuildRequest
.GlobalRequestId, "Result's parent doesn't match request's parent.");
440
ScheduleResponse response = TrySatisfyRequestFromCache(request.Parent.AssignedNode, request.
BuildRequest
, skippedResultsDoNotCauseCacheMiss: _componentHost.BuildParameters.SkippedResultsDoNotCauseCacheMiss());
468
if (unscheduledRequest.
BuildRequest
.GlobalRequestId == result.GlobalRequestId)
470
TraceScheduler("Request {0} (node request {1}) also satisfied by result.", unscheduledRequest.
BuildRequest
.GlobalRequestId, unscheduledRequest.
BuildRequest
.NodeRequestId);
471
BuildResult newResult = new BuildResult(unscheduledRequest.
BuildRequest
, result, null);
484
ScheduleResponse response = TrySatisfyRequestFromCache(parentNode, unscheduledRequest.
BuildRequest
, skippedResultsDoNotCauseCacheMiss: true);
489
LogRequestHandledFromCache(unscheduledRequest.
BuildRequest
, response.BuildResult);
511
_noLoggingCompletedSubmissionDetails = $"SubmissionId: {unscheduledRequest.
BuildRequest
.SubmissionId}; BuildRequestDataFlags: {unscheduledRequest.
BuildRequest
.BuildRequestDataFlags}";
607
if (request.
BuildRequest
.SubmissionId == submissionId)
895
ReadSchedulingPlan(_schedulingData.GetRequestsByHierarchy(null).First().
BuildRequest
.SubmissionId);
990
SchedulingPlan.PlanConfigData configToConsider = _schedulingPlan.GetConfiguration(request.
BuildRequest
.ConfigurationId);
1023
AssignUnscheduledRequestsToInProcNode(responses, idleNodes, request => IsTraversalRequest(request.
BuildRequest
));
1124
int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(unscheduledRequest.
BuildRequest
.ConfigurationId);
1128
System.IO.FileInfo f = new FileInfo(_configCache[unscheduledRequest.
BuildRequest
.ConfigurationId].ProjectFullPath);
1166
int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(unscheduledRequest.
BuildRequest
.ConfigurationId);
1170
System.IO.FileInfo f = new FileInfo(_configCache[unscheduledRequest.
BuildRequest
.ConfigurationId].ProjectFullPath);
1208
BuildRequest currentRequest = currentSchedulableRequest.
BuildRequest
;
1382
int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(request.
BuildRequest
.ConfigurationId);
1394
TraceScheduler("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);
1416
bool mustSendConfigurationToNode = _availableNodes[nodeId].AssignConfiguration(request.
BuildRequest
.ConfigurationId);
1420
BuildRequestConfiguration config = _configCache[request.
BuildRequest
.ConfigurationId];
1428
responses.Add(ScheduleResponse.CreateScheduleResponse(nodeId, request.
BuildRequest
, mustSendConfigurationToNode));
1429
TraceScheduler("Executing request {0} on node {1} with parent {2}", request.
BuildRequest
.GlobalRequestId, nodeId, (request.Parent == null) ? -1 : request.Parent.
BuildRequest
.GlobalRequestId);
1506
NodeAffinity affinity = GetNodeAffinityForRequest(request.
BuildRequest
);
1543
int assignedNodeForConfiguration = _schedulingData.GetAssignedNodeForRequestConfiguration(request.
BuildRequest
.ConfigurationId);
1553
NodeAffinity affinityRequired = GetNodeAffinityForRequest(request.
BuildRequest
);
1669
_resultsCache.AddResult(new BuildResult(request.
BuildRequest
, new BuildAbortedException()));
1696
blockingRequest.
BuildRequest
.ConfigurationId == blockedRequest.
BuildRequest
.ConfigurationId &&
1715
BuildRequest newRequest = new BuildRequest(parentRequest.
BuildRequest
.SubmissionId, BuildRequest.ResultsTransferNodeRequestId, parentRequest.
BuildRequest
.ConfigurationId, [], null, parentRequest.
BuildRequest
.BuildEventContext, parentRequest.
BuildRequest
, parentRequest.
BuildRequest
.BuildRequestDataFlags);
1727
BuildRequestConfiguration configuration = _configCache[parentRequest.
BuildRequest
.ConfigurationId];
1810
existingRequestAffinity = GetNodeAffinityForRequest(existingRequest.
BuildRequest
);
1861
responses.Add(ScheduleResponse.CreateResumeExecutionResponse(parentRequest.AssignedNode, parentRequest.
BuildRequest
.GlobalRequestId));
1886
TraceScheduler("Unblocking request {0} on node {1}", request.
BuildRequest
.GlobalRequestId, nodeId);
1889
ScheduleResponse response = ScheduleResponse.CreateResumeExecutionResponse(nodeId, request.
BuildRequest
.GlobalRequestId);
1906
ScheduleResponse response = TrySatisfyRequestFromCache(nodeForResults, request.
BuildRequest
, skippedResultsDoNotCauseCacheMiss: _componentHost.BuildParameters.SkippedResultsDoNotCauseCacheMiss());
1912
LogRequestHandledFromCache(request.
BuildRequest
, response.BuildResult);
1923
LogRequestHandledFromCache(request.
BuildRequest
, response.Unblocker.Result);
1926
TraceScheduler("Reporting results for request {0} with parent {1} to node {2} from cache.", request.
BuildRequest
.GlobalRequestId, request.
BuildRequest
.ParentGlobalRequestId, response.NodeId);
1941
CheckIfCacheMissOnReferencedProjectIsAllowedAndErrorIfNot(nodeForResults, request.
BuildRequest
, responses, emitNonErrorLogs: false);
2091
if (blockedRequest.
BuildRequest
.GlobalRequestId == request.ParentGlobalRequestId)
2093
configurationId = blockedRequest.
BuildRequest
.ConfigurationId;
2102
if (executingRequest.
BuildRequest
.GlobalRequestId == request.ParentGlobalRequestId)
2104
configurationId = executingRequest.
BuildRequest
.ConfigurationId;
2335
if (TargetsMatch(requestTargetsSet, existingRequest.
BuildRequest
.Targets))
2337
request.GlobalRequestId = existingRequest.
BuildRequest
.GlobalRequestId;
2440
int workId = useConfigurations ? buildEvent.Request.
BuildRequest
.ConfigurationId : buildEvent.Request.
BuildRequest
.GlobalRequestId;
2636
useConfigurations ? request.
BuildRequest
.ConfigurationId : request.
BuildRequest
.GlobalRequestId,
2640
_configCache[request.
BuildRequest
.ConfigurationId].ProjectFullPath,
2641
String.Join(", ", request.
BuildRequest
.Targets));
2734
.
BuildRequest
.GlobalRequestId)
2929
var buildRequest = request.
BuildRequest
;
BackEnd\Components\Scheduler\SchedulingData.cs (28)
265
if (!_configurationToRequests.TryGetValue(request.
BuildRequest
.ConfigurationId, out requests))
268
_configurationToRequests[request.
BuildRequest
.ConfigurationId] = requests;
281
ErrorUtilities.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);
333
ErrorUtilities.VerifyThrow(!requestsAssignedToNode.Contains(request), "Request {0} is already scheduled to node {1}", request.
BuildRequest
.GlobalRequestId, request.AssignedNode);
344
if (!configurationsAssignedToNode.Contains(request.
BuildRequest
.ConfigurationId))
346
configurationsAssignedToNode.Add(request.
BuildRequest
.ConfigurationId);
357
ErrorUtilities.VerifyThrow(!_blockedRequests.ContainsKey(request.
BuildRequest
.GlobalRequestId), "Request with global id {0} is already blocked!");
358
_blockedRequests[request.
BuildRequest
.GlobalRequestId] = request;
362
ErrorUtilities.VerifyThrow(!_yieldingRequests.ContainsKey(request.
BuildRequest
.GlobalRequestId), "Request with global id {0} is already yielded!");
363
_yieldingRequests[request.
BuildRequest
.GlobalRequestId] = request;
367
ErrorUtilities.VerifyThrow(_configurationToRequests.ContainsKey(request.
BuildRequest
.ConfigurationId), "Configuration {0} never had requests assigned to it.", request.
BuildRequest
.ConfigurationId);
368
ErrorUtilities.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);
379
ErrorUtilities.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;
393
ErrorUtilities.VerifyThrow(!_readyRequests.ContainsKey(request.
BuildRequest
.GlobalRequestId), "Request with global id {0} is already ready!");
394
_readyRequests[request.
BuildRequest
.GlobalRequestId] = request;
402
ErrorUtilities.VerifyThrow(!readyRequestsOnNode.Contains(request), "Request with global id {0} is already marked as ready on node {1}", request.
BuildRequest
.GlobalRequestId, request.AssignedNode);
407
ErrorUtilities.ThrowInternalError("Request with global id {0} cannot transition to the Unscheduled state", request.
BuildRequest
.GlobalRequestId);
550
return InternalGetScheduledRequestByGlobalRequestId(request.
BuildRequest
.GlobalRequestId) != null;
639
return CanScheduleConfigurationToNode(request.
BuildRequest
.ConfigurationId, nodeId);
BackEnd\Components\Scheduler\SchedulingPlan.cs (6)
211
return _configCache[rootRequest.
BuildRequest
.ConfigurationId].ProjectFullPath + ".buildplan";
428
if (request.
BuildRequest
.SubmissionId == submissionId)
442
file.Write(request.
BuildRequest
.ConfigurationId);
445
file.Write(" {0}", child.
BuildRequest
.ConfigurationId);
465
accumulatedTimeByConfiguration.TryGetValue(request.
BuildRequest
.ConfigurationId, out accumulatedTime);
466
accumulatedTimeByConfiguration[request.
BuildRequest
.ConfigurationId] = accumulatedTime + request.GetTimeSpentInState(SchedulableRequestState.Executing).TotalMilliseconds;