| // Copyright (c) 2016 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | // Decodes the packet HandshakeFailureReason from the chromium histogram | 
 | // Net.QuicClientHelloRejectReasons | 
 |  | 
 | #include <iostream> | 
 |  | 
 | #include "net/third_party/quiche/src/quic/core/crypto/crypto_handshake.h" | 
 | #include "net/third_party/quiche/src/quic/core/crypto/crypto_utils.h" | 
 | #include "net/third_party/quiche/src/quic/platform/api/quic_flags.h" | 
 | #include "net/third_party/quiche/src/common/platform/api/quiche_text_utils.h" | 
 |  | 
 | using quic::CryptoUtils; | 
 | using quic::HandshakeFailureReason; | 
 | using quic::MAX_FAILURE_REASON; | 
 |  | 
 | int main(int argc, char* argv[]) { | 
 |   const char* usage = "Usage: quic_reject_reason_decoder <packed_reason>"; | 
 |   std::vector<std::string> args = | 
 |       quic::QuicParseCommandLineFlags(usage, argc, argv); | 
 |  | 
 |   if (args.size() != 1) { | 
 |     std::cerr << usage << std::endl; | 
 |     return 1; | 
 |   } | 
 |  | 
 |   uint32_t packed_error = 0; | 
 |   if (!quiche::QuicheTextUtils::StringToUint32(args[0], &packed_error)) { | 
 |     std::cerr << "Unable to parse: " << args[0] << "\n"; | 
 |     return 2; | 
 |   } | 
 |  | 
 |   for (int i = 1; i < MAX_FAILURE_REASON; ++i) { | 
 |     if ((packed_error & (1 << (i - 1))) == 0) { | 
 |       continue; | 
 |     } | 
 |     HandshakeFailureReason reason = static_cast<HandshakeFailureReason>(i); | 
 |     std::cout << CryptoUtils::HandshakeFailureReasonToString(reason) << "\n"; | 
 |   } | 
 |   return 0; | 
 | } |