Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(53)

Side by Side Diff: sdk/lib/io/http.dart

Issue 12440002: Make instances of HeaderValue and ContentType immutable (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Updated pkg/http Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 part of dart.io; 5 part of dart.io;
6 6
7 /** 7 /**
8 * HTTP status codes. 8 * HTTP status codes.
9 */ 9 */
10 abstract class HttpStatus { 10 abstract class HttpStatus {
(...skipping 381 matching lines...) Expand 10 before | Expand all | Expand 10 after
392 * [HeaderValue] can be used to conveniently build and parse header 392 * [HeaderValue] can be used to conveniently build and parse header
393 * values on this form. 393 * values on this form.
394 * 394 *
395 * To build an [:accepts:] header with the value 395 * To build an [:accepts:] header with the value
396 * 396 *
397 * text/plain; q=0.3, text/html 397 * text/plain; q=0.3, text/html
398 * 398 *
399 * use code like this: 399 * use code like this:
400 * 400 *
401 * HttpClientRequest request = ...; 401 * HttpClientRequest request = ...;
402 * var v = new HeaderValue(); 402 * var v = new HeaderValue("text/plain", {"q": "0.3"});
403 * v.value = "text/plain";
404 * v.parameters["q"] = "0.3"
405 * request.headers.add(HttpHeaders.ACCEPT, v); 403 * request.headers.add(HttpHeaders.ACCEPT, v);
406 * request.headers.add(HttpHeaders.ACCEPT, "text/html"); 404 * request.headers.add(HttpHeaders.ACCEPT, "text/html");
407 * 405 *
408 * To parse the header values use the [:fromString:] constructor. 406 * To parse the header values use the [:fromString:] constructor.
409 * 407 *
410 * HttpRequest request = ...; 408 * HttpRequest request = ...;
411 * List<String> values = request.headers[HttpHeaders.ACCEPT]; 409 * List<String> values = request.headers[HttpHeaders.ACCEPT];
412 * values.forEach((value) { 410 * values.forEach((value) {
413 * HeaderValue v = new HeaderValue.fromString(value); 411 * HeaderValue v = new HeaderValue.fromString(value);
414 * // Use v.value and v.parameters 412 * // Use v.value and v.parameters
415 * }); 413 * });
414 *
415 * An instance of [HeaderValue] is immutable.
416 */ 416 */
417 abstract class HeaderValue { 417 abstract class HeaderValue {
418 /** 418 /**
419 * Creates a new header value object setting the value part. 419 * Creates a new header value object setting the value part.
420 */ 420 */
421 factory HeaderValue([String value = ""]) => new _HeaderValue(value); 421 factory HeaderValue([String value = "", Map<String, String> parameters]) {
422 return new _HeaderValue(value, parameters);
423 }
422 424
423 /** 425 /**
424 * Creates a new header value object from parsing a header value 426 * Creates a new header value object from parsing a header value
425 * string with both value and optional parameters. 427 * string with both value and optional parameters.
426 */ 428 */
427 factory HeaderValue.fromString(String value, 429 factory HeaderValue.fromString(String value,
428 {String parameterSeparator: ";"}) { 430 {String parameterSeparator: ";"}) {
429 return new _HeaderValue.fromString( 431 return new _HeaderValue.fromString(
430 value, parameterSeparator: parameterSeparator); 432 value, parameterSeparator: parameterSeparator);
431 } 433 }
432 434
433 /** 435 /**
434 * Gets and sets the header value. 436 * Gets the header value.
435 */ 437 */
436 String value; 438 String get value;
437 439
438 /** 440 /**
439 * Gets the map of parameters. 441 * Gets the map of parameters.
440 */ 442 */
441 Map<String, String> get parameters; 443 Map<String, String> get parameters;
442 444
443 /** 445 /**
444 * Returns the formatted string representation in the form: 446 * Returns the formatted string representation in the form:
445 * 447 *
446 * value; parameter1=value1; parameter2=value2 448 * value; parameter1=value1; parameter2=value2
(...skipping 19 matching lines...) Expand all
466 void set onTimeout(void callback()); 468 void set onTimeout(void callback());
467 469
468 /** 470 /**
469 * Is true if the session has not been sent to the client yet. 471 * Is true if the session has not been sent to the client yet.
470 */ 472 */
471 bool get isNew; 473 bool get isNew;
472 } 474 }
473 475
474 476
475 /** 477 /**
476 * Representation of a content type. 478 * Representation of a content type. An instance of [ContentType] is
479 * immutable.
477 */ 480 */
478 abstract class ContentType implements HeaderValue { 481 abstract class ContentType implements HeaderValue {
479 /** 482 /**
480 * Creates a new content type object setting the primary type and 483 * Creates a new content type object setting the primary type and
481 * sub type. 484 * sub type and the charset parameter.
482 */ 485 */
483 factory ContentType([String primaryType = "", String subType = ""]) { 486 factory ContentType([String primaryType = "",
484 return new _ContentType(primaryType, subType); 487 String subType = "",
488 String charset]) {
489 return new _ContentType(primaryType, subType, charset);
485 } 490 }
486 491
487 /** 492 /**
488 * Creates a new content type object from parsing a Content-Type 493 * Creates a new content type object from parsing a Content-Type
489 * header value. As primary type, sub type and parameter names and 494 * header value. As primary type, sub type and parameter names and
490 * values are not case sensitive all these values will be converted 495 * values are not case sensitive all these values will be converted
491 * to lower case. Parsing this string 496 * to lower case. Parsing this string
492 * 497 *
493 * text/html; charset=utf-8 498 * text/html; charset=utf-8
494 * 499 *
495 * will create a content type object with primary type [:text:], sub 500 * will create a content type object with primary type [:text:], sub
496 * type [:html:] and parameter [:charset:] with value [:utf-8:]. 501 * type [:html:] and parameter [:charset:] with value [:utf-8:].
497 */ 502 */
498 factory ContentType.fromString(String value) { 503 factory ContentType.fromString(String value) {
499 return new _ContentType.fromString(value); 504 return new _ContentType.fromString(value);
500 } 505 }
501 506
502 /** 507 /**
503 * Gets and sets the content type in the form "primaryType/subType". 508 * Gets the primary type.
504 */ 509 */
505 String value; 510 String get primaryType;
506 511
507 /** 512 /**
508 * Gets and sets the primary type. 513 * Gets the sub type.
509 */ 514 */
510 String primaryType; 515 String get subType;
511 516
512 /** 517 /**
513 * Gets and sets the sub type. 518 * Gets the character set.
514 */ 519 */
515 String subType; 520 String get charset;
516
517 /**
518 * Gets and sets the character set.
519 */
520 String charset;
521 } 521 }
522 522
523 523
524 /** 524 /**
525 * Representation of a cookie. For cookies received by the server as 525 * Representation of a cookie. For cookies received by the server as
526 * Cookie header values only [:name:] and [:value:] fields will be 526 * Cookie header values only [:name:] and [:value:] fields will be
527 * set. When building a cookie for the 'set-cookie' header in the server 527 * set. When building a cookie for the 'set-cookie' header in the server
528 * and when receiving cookies in the client as 'set-cookie' headers all 528 * and when receiving cookies in the client as 'set-cookie' headers all
529 * fields can be used. 529 * fields can be used.
530 */ 530 */
(...skipping 586 matching lines...) Expand 10 before | Expand all | Expand 10 after
1117 class RedirectLimitExceededException extends RedirectException { 1117 class RedirectLimitExceededException extends RedirectException {
1118 const RedirectLimitExceededException(List<RedirectInfo> redirects) 1118 const RedirectLimitExceededException(List<RedirectInfo> redirects)
1119 : super("Redirect limit exceeded", redirects); 1119 : super("Redirect limit exceeded", redirects);
1120 } 1120 }
1121 1121
1122 1122
1123 class RedirectLoopException extends RedirectException { 1123 class RedirectLoopException extends RedirectException {
1124 const RedirectLoopException(List<RedirectInfo> redirects) 1124 const RedirectLoopException(List<RedirectInfo> redirects)
1125 : super("Redirect loop detected", redirects); 1125 : super("Redirect loop detected", redirects);
1126 } 1126 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698