You've already forked cpp-httplib
							
							Made code more readable
This commit is contained in:
		
							
								
								
									
										42
									
								
								httplib.h
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								httplib.h
									
									
									
									
									
								
							| @@ -1114,6 +1114,11 @@ public: | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   bool end_with_crlf() const { | ||||||
|  |     auto end = ptr() + size(); | ||||||
|  |     return size() >= 2 && end[-2] == '\r' && end[-1] == '\n'; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   bool getline() { |   bool getline() { | ||||||
|     fixed_buffer_used_size_ = 0; |     fixed_buffer_used_size_ = 0; | ||||||
|     glowable_buffer_.clear(); |     glowable_buffer_.clear(); | ||||||
| @@ -1562,34 +1567,33 @@ inline uint64_t get_header_value_uint64(const Headers &headers, const char *key, | |||||||
| } | } | ||||||
|  |  | ||||||
| inline bool read_headers(Stream &strm, Headers &headers) { | inline bool read_headers(Stream &strm, Headers &headers) { | ||||||
|   // Horizontal tab and ' ' are considered whitespace and are ignored when on |  | ||||||
|   // the left or right side of the header value: |  | ||||||
|   //  - https://stackoverflow.com/questions/50179659/ |  | ||||||
|   //  - https://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html |  | ||||||
|   static std::regex re(R"((.+?):[\t ]*(.+))"); |  | ||||||
|  |  | ||||||
|   const auto bufsiz = 2048; |   const auto bufsiz = 2048; | ||||||
|   char buf[bufsiz]; |   char buf[bufsiz]; | ||||||
|  |  | ||||||
|   stream_line_reader line_reader(strm, buf, bufsiz); |   stream_line_reader line_reader(strm, buf, bufsiz); | ||||||
|  |  | ||||||
|   for (;;) { |   for (;;) { | ||||||
|     if (!line_reader.getline()) { return false; } |     if (!line_reader.getline()) { return false; } | ||||||
|     const char *end = line_reader.ptr() + line_reader.size(); |  | ||||||
|     auto erase_last_char = [&](char c) { |     // Check if the line ends with CRLF. | ||||||
|       if (line_reader.ptr() == end || end[-1] != c) { |     if (line_reader.end_with_crlf()) { | ||||||
|         return false; |       // Blank line indicates end of headers. | ||||||
|       } |       if (line_reader.size() == 2) { break; } | ||||||
|  |     } else { | ||||||
|  |       continue; // Skip invalid line. | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Skip trailing spaces and tabs. | ||||||
|  |     auto end = line_reader.ptr() + line_reader.size() - 2; | ||||||
|  |     while (line_reader.ptr() < end && (end[-1] == ' ' || end[-1] == '\t')) { | ||||||
|       end--; |       end--; | ||||||
|       return true; |     } | ||||||
|     }; |  | ||||||
|     if (!erase_last_char('\n')) { continue; } |  | ||||||
|     if (!erase_last_char('\r')) { continue; } |  | ||||||
|  |  | ||||||
|     // Blank line indicates end of headers. |     // Horizontal tab and ' ' are considered whitespace and are ignored when on | ||||||
|     if (line_reader.ptr() == end) { break; } |     // the left or right side of the header value: | ||||||
|  |     //  - https://stackoverflow.com/questions/50179659/ | ||||||
|  |     //  - https://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html | ||||||
|  |     static const std::regex re(R"((.+?):[\t ]*(.+))"); | ||||||
|  |  | ||||||
|     while (erase_last_char(' ') || erase_last_char('\t')) {} |  | ||||||
|     std::cmatch m; |     std::cmatch m; | ||||||
|     if (std::regex_match(line_reader.ptr(), end, m, re)) { |     if (std::regex_match(line_reader.ptr(), end, m, re)) { | ||||||
|       auto key = std::string(m[1]); |       auto key = std::string(m[1]); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user