本文整理匯總了TypeScript中neuroglancer/util/cancellation.CancellationToken.add方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript CancellationToken.add方法的具體用法?TypeScript CancellationToken.add怎麽用?TypeScript CancellationToken.add使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類neuroglancer/util/cancellation.CancellationToken
的用法示例。
在下文中一共展示了CancellationToken.add方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: reject
return new Promise<any>((resolve, reject) => {
const abort = () => {
let origXhr = xhr;
xhr = null;
if (origXhr != null) {
origXhr.abort();
}
reject(CANCELED);
};
cancellationToken.add(abort);
function start(credentials: CredentialsWithGeneration<BossToken>) {
if (xhr === null) {
--numPendingRequests;
return;
}
xhr = openShardedHttpRequest(baseUrls, httpCall.path, httpCall.method);
xhr.responseType = httpCall.responseType;
xhr.setRequestHeader('Authorization', `Bearer ${credentials.credentials}`);
if (httpCall.headers !== undefined) {
for (let i = 0; i < httpCall.headers.length; i++) {
let header = httpCall.headers[i];
xhr.setRequestHeader(header.key, header.value);
}
}
xhr.onloadend = function(this: XMLHttpRequest) {
if (xhr === null) {
--numPendingRequests;
return;
}
let status = this.status;
if (status >= 200 && status < 300) {
--numPendingRequests;
resolve(this.response);
} else if (status === 403 || status === 401) {
// Authorization needed.
credentialsProvider.get(credentials, cancellationToken).then(start);
} else if (status === 504) {
// Gateway timeout can occur if the server takes too long to reply. Retry.
credentialsProvider.get(credentials, cancellationToken).then(start);
} else {
--numPendingRequests;
cancellationToken.remove(abort);
reject(HttpError.fromXhr(this));
}
};
xhr.send(httpCall.payload);
}
credentialsProvider.get(/*invalidToken=*/undefined, cancellationToken).then(start);
});
示例2: reject
return new Promise<any>((resolve, reject) => {
const abort = () => {
let origXhr = xhr;
xhr = null;
if (origXhr != null) {
origXhr.abort();
}
reject(CANCELED);
};
cancellationToken.add(abort);
function start(token: Token) {
if (xhr === null) {
--numPendingRequests;
return;
}
xhr = openShardedHttpRequest(INSTANCE_BASE_URLS[instance], httpCall.path, httpCall.method);
xhr.responseType = httpCall.responseType;
xhr.setRequestHeader('Authorization', `${token['tokenType']} ${token['accessToken']}`);
xhr.onloadend = function(this: XMLHttpRequest) {
if (xhr === null) {
--numPendingRequests;
return;
}
let status = this.status;
if (status >= 200 && status < 300) {
--numPendingRequests;
cancellationToken.remove(abort);
resolve(this.response);
} else if (status === 401) {
// Authorization needed.
getToken(token).then(start);
} else if (status === 504) {
// Gateway timeout can occur if the server takes too long to reply. Retry.
getToken().then(start);
} else {
--numPendingRequests;
cancellationToken.remove(abort);
reject(HttpError.fromXhr(this));
}
};
xhr.send(httpCall.payload);
}
getToken().then(start);
});