Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "net/tools/flip_server/balsa_headers.h" | 5 #include "net/tools/flip_server/balsa_headers.h" |
| 6 | 6 |
| 7 #include <emmintrin.h> | 7 #include <emmintrin.h> |
| 8 | 8 |
| 9 #include <algorithm> | 9 #include <algorithm> |
| 10 #include <ext/hash_set> | 10 #include <ext/hash_set> |
| (...skipping 592 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 603 } else if (transfer_encoding_is_chunked_) { | 603 } else if (transfer_encoding_is_chunked_) { |
| 604 const base::StringPiece transfer_encoding(kTransferEncoding, | 604 const base::StringPiece transfer_encoding(kTransferEncoding, |
| 605 sizeof(kTransferEncoding) - 1); | 605 sizeof(kTransferEncoding) - 1); |
| 606 RemoveAllOfHeader(transfer_encoding); | 606 RemoveAllOfHeader(transfer_encoding); |
| 607 transfer_encoding_is_chunked_ = false; | 607 transfer_encoding_is_chunked_ = false; |
| 608 } | 608 } |
| 609 content_length_status_ = BalsaHeadersEnums::VALID_CONTENT_LENGTH; | 609 content_length_status_ = BalsaHeadersEnums::VALID_CONTENT_LENGTH; |
| 610 content_length_ = length; | 610 content_length_ = length; |
| 611 // FastUInt64ToBuffer is supposed to use a maximum of kFastToBufferSize bytes. | 611 // FastUInt64ToBuffer is supposed to use a maximum of kFastToBufferSize bytes. |
| 612 char buffer[kFastToBufferSize]; | 612 char buffer[kFastToBufferSize]; |
| 613 int len_converted = snprintf(buffer, sizeof(buffer), "%ld", length); | 613 int len_converted = snprintf(buffer, sizeof(buffer), "%ld", (long int)length); |
|
Mike Belshe
2010/04/02 19:41:28
nit: static_cast<long int>(length)
| |
| 614 CHECK_GT(len_converted, 0); | 614 CHECK_GT(len_converted, 0); |
| 615 const base::StringPiece length_str(buffer, len_converted); | 615 const base::StringPiece length_str(buffer, len_converted); |
| 616 AppendHeader(content_length, length_str); | 616 AppendHeader(content_length, length_str); |
| 617 } | 617 } |
| 618 | 618 |
| 619 void BalsaHeaders::SetChunkEncoding(bool chunk_encode) { | 619 void BalsaHeaders::SetChunkEncoding(bool chunk_encode) { |
| 620 if (transfer_encoding_is_chunked_ == chunk_encode) { | 620 if (transfer_encoding_is_chunked_ == chunk_encode) { |
| 621 return; | 621 return; |
| 622 } | 622 } |
| 623 if (content_length_status_ != BalsaHeadersEnums::NO_CONTENT_LENGTH && | 623 if (content_length_status_ != BalsaHeadersEnums::NO_CONTENT_LENGTH && |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 712 // Thus, a function to set one is equivalent to a function to set the other. | 712 // Thus, a function to set one is equivalent to a function to set the other. |
| 713 // We maintain two functions for this as it is much more descriptive, and | 713 // We maintain two functions for this as it is much more descriptive, and |
| 714 // makes code more understandable. | 714 // makes code more understandable. |
| 715 SetRequestUri(code); | 715 SetRequestUri(code); |
| 716 } | 716 } |
| 717 | 717 |
| 718 void BalsaHeaders::SetParsedResponseCodeAndUpdateFirstline( | 718 void BalsaHeaders::SetParsedResponseCodeAndUpdateFirstline( |
| 719 size_t parsed_response_code) { | 719 size_t parsed_response_code) { |
| 720 char buffer[kFastToBufferSize]; | 720 char buffer[kFastToBufferSize]; |
| 721 int len_converted = snprintf(buffer, sizeof(buffer), | 721 int len_converted = snprintf(buffer, sizeof(buffer), |
| 722 "%ld", parsed_response_code); | 722 "%ld", (long int)parsed_response_code); |
|
Mike Belshe
2010/04/02 19:41:28
nit: static_cast.
| |
| 723 CHECK_GT(len_converted, 0); | 723 CHECK_GT(len_converted, 0); |
| 724 SetResponseCode(base::StringPiece(buffer, len_converted)); | 724 SetResponseCode(base::StringPiece(buffer, len_converted)); |
| 725 } | 725 } |
| 726 | 726 |
| 727 void BalsaHeaders::SetRequestVersion(const base::StringPiece& version) { | 727 void BalsaHeaders::SetRequestVersion(const base::StringPiece& version) { |
| 728 // This is the last of the three parts of the firstline. | 728 // This is the last of the three parts of the firstline. |
| 729 // Since whitespace_3_idx and non_whitespace_3_idx may point to the same | 729 // Since whitespace_3_idx and non_whitespace_3_idx may point to the same |
| 730 // place, we ensure below that any available space includes space for a | 730 // place, we ensure below that any available space includes space for a |
| 731 // litteral space (' ') character between the second component and the third | 731 // litteral space (' ') character between the second component and the third |
| 732 // component. If the space between whitespace_3_idx_ and | 732 // component. If the space between whitespace_3_idx_ and |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 749 | 749 |
| 750 void BalsaHeaders::SetResponseReasonPhrase(const base::StringPiece& reason) { | 750 void BalsaHeaders::SetResponseReasonPhrase(const base::StringPiece& reason) { |
| 751 // Note: There is no difference between request_version() and | 751 // Note: There is no difference between request_version() and |
| 752 // response_reason_phrase(). Thus, a function to set one is equivalent to a | 752 // response_reason_phrase(). Thus, a function to set one is equivalent to a |
| 753 // function to set the other. We maintain two functions for this as it is | 753 // function to set the other. We maintain two functions for this as it is |
| 754 // much more descriptive, and makes code more understandable. | 754 // much more descriptive, and makes code more understandable. |
| 755 SetRequestVersion(reason); | 755 SetRequestVersion(reason); |
| 756 } | 756 } |
| 757 | 757 |
| 758 } // namespace net | 758 } // namespace net |
| OLD | NEW |