Enable '-Wimplicit-fallthrough' and fix issues

Change-Id: I9e1e09f3924dcd8f59af2fbc952456b81e2d7c4e
This commit is contained in:
KongQun Yang 2016-01-06 15:52:18 -08:00
parent bb073cef51
commit b3e85ff810
10 changed files with 76 additions and 21 deletions

View File

@ -12,7 +12,7 @@
#include <set> #include <set>
#include <string> #include <string>
#include "media/base/container_names.h" #include "packager/media/base/container_names.h"
namespace edash_packager { namespace edash_packager {
namespace media { namespace media {

View File

@ -10,6 +10,7 @@
#include "packager/app/validate_flag.h" #include "packager/app/validate_flag.h"
#include "packager/base/logging.h" #include "packager/base/logging.h"
#include "packager/base/strings/string_piece.h"
#include "packager/base/strings/string_util.h" #include "packager/base/strings/string_util.h"
DEFINE_bool(enable_widevine_encryption, DEFINE_bool(enable_widevine_encryption,
@ -76,7 +77,7 @@ bool ValidateWidevineCryptoFlags() {
success = false; success = false;
} }
if (widevine_crypto && FLAGS_signer.empty() && if (widevine_crypto && FLAGS_signer.empty() &&
base::StartsWith(FLAGS_key_server_url, "http", base::StartsWith(base::StringPiece(FLAGS_key_server_url), "http",
base::CompareCase::INSENSITIVE_ASCII)) { base::CompareCase::INSENSITIVE_ASCII)) {
LOG(WARNING) << "--signer is likely required with " LOG(WARNING) << "--signer is likely required with "
"--enable_widevine_encryption/decryption."; "--enable_widevine_encryption/decryption.";

View File

@ -19,8 +19,7 @@
'conditions': [ 'conditions': [
['clang==1', { ['clang==1', {
'cflags': [ 'cflags': [
# Temporary workaround a gtest bug on ImplicitCast_. '-Wimplicit-fallthrough',
'-Wno-pessimizing-move',
], ],
# Revert the relevant settings in Chromium's common.gypi. # Revert the relevant settings in Chromium's common.gypi.
'cflags!': [ 'cflags!': [

View File

@ -7,6 +7,8 @@
#include "packager/media/base/http_key_fetcher.h" #include "packager/media/base/http_key_fetcher.h"
#include <curl/curl.h> #include <curl/curl.h>
#include "packager/base/logging.h"
#include "packager/base/strings/stringprintf.h" #include "packager/base/strings/stringprintf.h"
#include "packager/base/synchronization/lock.h" #include "packager/base/synchronization/lock.h"

View File

@ -0,0 +1,54 @@
// Copyright 2016 Google Inc. All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file or at
// https://developers.google.com/open-source/licenses/bsd
#ifndef MEDIA_BASE_MACROS_H_
#define MEDIA_BASE_MACROS_H_
// The FALLTHROUGH_INTENDED macro can be used to annotate implicit fall-through
// between switch labels:
// switch (x) {
// case 40:
// case 41:
// if (truth_is_out_there) {
// ++x;
// FALLTHROUGH_INTENDED; // Use instead of/along with annotations in
// // comments.
// } else {
// return x;
// }
// case 42:
// ...
//
// As shown in the example above, the FALLTHROUGH_INTENDED macro should be
// followed by a semicolon. It is designed to mimic control-flow statements
// like 'break;', so it can be placed in most places where 'break;' can, but
// only if there are no statements on the execution path between it and the
// next switch label.
//
// When compiled with clang in C++11 mode, the FALLTHROUGH_INTENDED macro is
// expanded to [[clang::fallthrough]] attribute, which is analysed when
// performing switch labels fall-through diagnostic ('-Wimplicit-fallthrough').
// See clang documentation on language extensions for details:
// http://clang.llvm.org/docs/AttributeReference.html#fallthrough-clang-fallthrough
//
// When used with unsupported compilers, the FALLTHROUGH_INTENDED macro has no
// effect on diagnostics.
//
// In either case this macro has no effect on runtime behavior and performance
// of code.
#if defined(__clang__) && __cplusplus >= 201103L && defined(__has_warning)
#if __has_feature(cxx_attributes) && __has_warning("-Wimplicit-fallthrough")
#define FALLTHROUGH_INTENDED [[clang::fallthrough]] // NOLINT
#endif
#endif
#ifndef FALLTHROUGH_INTENDED
#define FALLTHROUGH_INTENDED \
do { \
} while (0)
#endif
#endif // MEDIA_BASE_MACROS_H_

View File

@ -43,6 +43,7 @@
'key_source.cc', 'key_source.cc',
'key_source.h', 'key_source.h',
'limits.h', 'limits.h',
'macros.h',
'media_parser.h', 'media_parser.h',
'media_sample.cc', 'media_sample.cc',
'media_sample.h', 'media_sample.h',

View File

@ -16,6 +16,7 @@
#include "packager/media/base/buffer_reader.h" #include "packager/media/base/buffer_reader.h"
#include "packager/media/base/decrypt_config.h" #include "packager/media/base/decrypt_config.h"
#include "packager/media/base/key_source.h" #include "packager/media/base/key_source.h"
#include "packager/media/base/macros.h"
#include "packager/media/base/media_sample.h" #include "packager/media/base/media_sample.h"
#include "packager/media/base/video_stream_info.h" #include "packager/media/base/video_stream_info.h"
#include "packager/media/file/file.h" #include "packager/media/file/file.h"
@ -393,10 +394,15 @@ bool MP4MediaParser::ParseMoov(BoxReader* reader) {
<< actual_format << " in stsd box."; << actual_format << " in stsd box.";
return false; return false;
} }
break;
case FOURCC_DTSC: case FOURCC_DTSC:
FALLTHROUGH_INTENDED;
case FOURCC_DTSH: case FOURCC_DTSH:
FALLTHROUGH_INTENDED;
case FOURCC_DTSL: case FOURCC_DTSL:
FALLTHROUGH_INTENDED;
case FOURCC_DTSE: case FOURCC_DTSE:
FALLTHROUGH_INTENDED;
case FOURCC_DTSM: case FOURCC_DTSM:
extra_data = entry.ddts.extra_data; extra_data = entry.ddts.extra_data;
max_bitrate = entry.ddts.max_bitrate; max_bitrate = entry.ddts.max_bitrate;

View File

@ -13,6 +13,7 @@
#include "packager/base/strings/string_number_conversions.h" #include "packager/base/strings/string_number_conversions.h"
#include "packager/base/strings/string_split.h" #include "packager/base/strings/string_split.h"
#include "packager/base/strings/string_util.h" #include "packager/base/strings/string_util.h"
#include "packager/media/base/macros.h"
#include "packager/media/base/media_sample.h" #include "packager/media/base/media_sample.h"
#include "packager/media/base/text_stream_info.h" #include "packager/media/base/text_stream_info.h"
@ -67,6 +68,7 @@ bool ReadLine(std::string* data, std::string* line) {
bool TimestampToMilliseconds(const std::string& original_str, bool TimestampToMilliseconds(const std::string& original_str,
uint64_t* time_ms) { uint64_t* time_ms) {
const size_t kMinimalHoursLength = 2;
const size_t kMinutesLength = 2; const size_t kMinutesLength = 2;
const size_t kSecondsLength = 2; const size_t kSecondsLength = 2;
const size_t kMillisecondsLength = 3; const size_t kMillisecondsLength = 3;
@ -90,6 +92,8 @@ bool TimestampToMilliseconds(const std::string& original_str,
// Check if hours is in the right format, if so get the number. // Check if hours is in the right format, if so get the number.
// -1 for excluding colon for splitting hours and minutes. // -1 for excluding colon for splitting hours and minutes.
const size_t hours_length = str.size() - kMinimalLength - 1; const size_t hours_length = str.size() - kMinimalLength - 1;
if (hours_length < kMinimalHoursLength)
return false;
if (!base::StringToInt(str.substr(0, hours_length), &hours)) if (!base::StringToInt(str.substr(0, hours_length), &hours))
return false; return false;
str_index += hours_length; str_index += hours_length;
@ -333,6 +337,7 @@ bool WebVttMediaParser::Parse(const uint8_t* buf, int size) {
// timing, so fall thru. Setting state_ to kCueTiming so that the state // timing, so fall thru. Setting state_ to kCueTiming so that the state
// always matches the case. // always matches the case.
state_ = kCueTiming; state_ = kCueTiming;
FALLTHROUGH_INTENDED;
} }
case kCueTiming: { case kCueTiming: {
DCHECK(has_arrow); DCHECK(has_arrow);

View File

@ -146,7 +146,7 @@ TEST_F(WebVttMediaParserTest, MalformedHourTimestamp) {
TEST_F(WebVttMediaParserTest, SpacesInTimestamp) { TEST_F(WebVttMediaParserTest, SpacesInTimestamp) {
EXPECT_CALL(new_sample_callback_, Call(_, _)).Times(0); EXPECT_CALL(new_sample_callback_, Call(_, _)).Times(0);
const char kHourStringTooShort[] = const char kSpacesInTimestamp[] =
"WEBVTT\n" "WEBVTT\n"
"\n" "\n"
"0:01: 1.004 --> 0 :04:25.092\n" "0:01: 1.004 --> 0 :04:25.092\n"
@ -154,8 +154,8 @@ TEST_F(WebVttMediaParserTest, SpacesInTimestamp) {
InitializeParser(); InitializeParser();
EXPECT_FALSE( EXPECT_FALSE(
parser_.Parse(reinterpret_cast<const uint8_t*>(kHourStringTooShort), parser_.Parse(reinterpret_cast<const uint8_t*>(kSpacesInTimestamp),
arraysize(kHourStringTooShort) - 1)); arraysize(kSpacesInTimestamp) - 1));
} }
MATCHER_P(MatchesPayload, data, "") { MATCHER_P(MatchesPayload, data, "") {

View File

@ -89,20 +89,6 @@
'testing/gtest.gyp:gtest', 'testing/gtest.gyp:gtest',
], ],
}, },
{
'target_name': 'All',
'type': 'none',
'dependencies': [
'media/base/media_base.gyp:*',
'media/event/media_event.gyp:*',
'media/file/file.gyp:*',
'media/formats/mp2t/mp2t.gyp:*',
'media/formats/mp4/mp4.gyp:*',
'media/formats/webm/webm.gyp:*',
'media/formats/wvm/wvm.gyp:*',
'mpd/mpd.gyp:*',
],
},
{ {
'target_name': 'packager_builder_tests', 'target_name': 'packager_builder_tests',
'type': 'none', 'type': 'none',
@ -114,6 +100,7 @@
'media/formats/mp2t/mp2t.gyp:mp2t_unittest', 'media/formats/mp2t/mp2t.gyp:mp2t_unittest',
'media/formats/mp4/mp4.gyp:mp4_unittest', 'media/formats/mp4/mp4.gyp:mp4_unittest',
'media/formats/webm/webm.gyp:webm_unittest', 'media/formats/webm/webm.gyp:webm_unittest',
'media/formats/webvtt/webvtt.gyp:webvtt_unittest',
'media/formats/wvm/wvm.gyp:wvm_unittest', 'media/formats/wvm/wvm.gyp:wvm_unittest',
'mpd/mpd.gyp:mpd_unittest', 'mpd/mpd.gyp:mpd_unittest',
'packager_test', 'packager_test',