mirror of
https://github.com/angular/angular
synced 2026-05-24 09:28:37 +00:00
These wrappers are not natively understood by ts2dart. Removing them will improve Dart2JS compilation due to fewer megamorphic calls to List functions. It also makes Angular code more succinct and improves type safety in Angular due to better type inference of the Array component type. This change exposed several bugs in Angular.
79 lines
2.3 KiB
TypeScript
79 lines
2.3 KiB
TypeScript
import {
|
|
isPresent,
|
|
isBlank,
|
|
isJsObject,
|
|
isType,
|
|
StringWrapper,
|
|
BaseException
|
|
} from 'angular2/src/facade/lang';
|
|
import {
|
|
isListLikeIterable,
|
|
List,
|
|
Map,
|
|
MapWrapper,
|
|
ListWrapper
|
|
} from 'angular2/src/facade/collection';
|
|
|
|
/**
|
|
* Polyfill for [Headers](https://developer.mozilla.org/en-US/docs/Web/API/Headers/Headers), as
|
|
* specified in the [Fetch Spec](https://fetch.spec.whatwg.org/#headers-class). The only known
|
|
* difference from the spec is the lack of an `entries` method.
|
|
*/
|
|
export class Headers {
|
|
_headersMap: Map<string, List<string>>;
|
|
constructor(headers?: Headers | Object) {
|
|
if (isBlank(headers)) {
|
|
this._headersMap = MapWrapper.create();
|
|
return;
|
|
}
|
|
|
|
if (isPresent((<Headers>headers)._headersMap)) {
|
|
this._headersMap = (<Headers>headers)._headersMap;
|
|
} else if (isJsObject(headers)) {
|
|
this._headersMap = MapWrapper.createFromStringMap(headers);
|
|
MapWrapper.forEach(this._headersMap, (v, k) => {
|
|
if (!isListLikeIterable(v)) {
|
|
var list = [];
|
|
list.push(v);
|
|
MapWrapper.set(this._headersMap, k, list);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
append(name: string, value: string): void {
|
|
var list = MapWrapper.get(this._headersMap, name) || [];
|
|
list.push(value);
|
|
MapWrapper.set(this._headersMap, name, list);
|
|
}
|
|
|
|
delete (name: string): void { MapWrapper.delete(this._headersMap, name); }
|
|
|
|
forEach(fn: Function) { return MapWrapper.forEach(this._headersMap, fn); }
|
|
|
|
get(header: string): string {
|
|
return ListWrapper.first(MapWrapper.get(this._headersMap, header));
|
|
}
|
|
|
|
has(header: string) { return MapWrapper.contains(this._headersMap, header); }
|
|
|
|
keys() { return MapWrapper.keys(this._headersMap); }
|
|
|
|
// TODO: this implementation seems wrong. create list then check if it's iterable?
|
|
set(header: string, value: string | List<string>): void {
|
|
var list = [];
|
|
if (!isListLikeIterable(value)) {
|
|
list.push(value);
|
|
} else {
|
|
list.push(ListWrapper.toString((<List<string>>value)));
|
|
}
|
|
|
|
MapWrapper.set(this._headersMap, header, list);
|
|
}
|
|
|
|
values() { return MapWrapper.values(this._headersMap); }
|
|
|
|
getAll(header: string): Array<string> { return MapWrapper.get(this._headersMap, header) || []; }
|
|
|
|
entries() { throw new BaseException('"entries" method is not implemented on Headers class'); }
|
|
}
|