webm_parser: Convert style to match the rest of libwebm

Remove webm_parser/clang-format-style.
Run clang-format -style=file -i for each source file.

Change-Id: Ieaf44bd323375cbcfec67014e94b7742d6bda14a
This commit is contained in:
Tom Finegan 2016-07-22 15:18:02 -07:00
parent 24be76dcb2
commit 25d26028c1
53 changed files with 741 additions and 803 deletions

View File

@ -1,91 +0,0 @@
---
Language: Cpp
# BasedOnStyle: Google
AccessModifierOffset: -1
AlignAfterOpenBracket: Align
AlignConsecutiveAssignments: false
AlignConsecutiveDeclarations: false
AlignEscapedNewlinesLeft: true
AlignOperands: true
AlignTrailingComments: true
AllowAllParametersOfDeclarationOnNextLine: true
AllowShortBlocksOnASingleLine: false
AllowShortCaseLabelsOnASingleLine: false
AllowShortFunctionsOnASingleLine: All
AllowShortIfStatementsOnASingleLine: true
AllowShortLoopsOnASingleLine: true
AlwaysBreakAfterDefinitionReturnType: None
AlwaysBreakAfterReturnType: None
AlwaysBreakBeforeMultilineStrings: true
AlwaysBreakTemplateDeclarations: false
BinPackArguments: true
BinPackParameters: true
BraceWrapping:
AfterClass: false
AfterControlStatement: false
AfterEnum: false
AfterFunction: false
AfterNamespace: false
AfterObjCDeclaration: false
AfterStruct: false
AfterUnion: false
BeforeCatch: false
BeforeElse: false
IndentBraces: false
BreakBeforeBinaryOperators: None
BreakBeforeBraces: Attach
BreakBeforeTernaryOperators: true
BreakConstructorInitializersBeforeComma: false
BreakAfterJavaFieldAnnotations: false
BreakStringLiterals: true
ColumnLimit: 80
ConstructorInitializerAllOnOneLineOrOnePerLine: true
ConstructorInitializerIndentWidth: 4
ContinuationIndentWidth: 4
Cpp11BracedListStyle: true
DerivePointerAlignment: true
DisableFormat: false
ExperimentalAutoDetectBinPacking: false
ForEachMacros: [ foreach, Q_FOREACH, BOOST_FOREACH ]
IncludeCategories:
- Regex: '^<.*\.h>'
Priority: 1
- Regex: '^<.*'
Priority: 2
- Regex: '.*'
Priority: 3
IndentCaseLabels: true
IndentWidth: 2
IndentWrappedFunctionNames: false
KeepEmptyLinesAtTheStartOfBlocks: false
MacroBlockBegin: ''
MacroBlockEnd: ''
MaxEmptyLinesToKeep: 1
NamespaceIndentation: None
ObjCBlockIndentWidth: 2
ObjCSpaceAfterProperty: false
ObjCSpaceBeforeProtocolList: false
PenaltyBreakBeforeFirstCallParameter: 1
PenaltyBreakComment: 300
PenaltyBreakFirstLessLess: 120
PenaltyBreakString: 1000
PenaltyExcessCharacter: 1000000
PenaltyReturnTypeOnItsOwnLine: 200
PointerAlignment: Left
ReflowComments: true
SortIncludes: true
SpaceAfterCStyleCast: false
SpaceBeforeAssignmentOperators: true
SpaceBeforeParens: ControlStatements
SpaceInEmptyParentheses: false
SpacesBeforeTrailingComments: 2
SpacesInAngles: false
SpacesInContainerLiterals: true
SpacesInCStyleCastParentheses: false
SpacesInParentheses: false
SpacesInSquareBrackets: false
Standard: Auto
TabWidth: 8
UseTab: Never
...

View File

@ -956,8 +956,10 @@ class DemoCallback : public Callback {
PrintValue("timecode", simple_block.timecode); PrintValue("timecode", simple_block.timecode);
PrintValue("lacing", simple_block.lacing); PrintValue("lacing", simple_block.lacing);
std::string flags = (simple_block.is_visible) ? "visible" : "invisible"; std::string flags = (simple_block.is_visible) ? "visible" : "invisible";
if (simple_block.is_key_frame) flags += ", key frame"; if (simple_block.is_key_frame)
if (simple_block.is_discardable) flags += ", discardable"; flags += ", key frame";
if (simple_block.is_discardable)
flags += ", discardable";
PrintValue("flags", flags); PrintValue("flags", flags);
*action = Action::kRead; *action = Action::kRead;
return Status(Status::kOkCompleted); return Status(Status::kOkCompleted);
@ -1096,16 +1098,15 @@ class DemoCallback : public Callback {
int main(int argc, char* argv[]) { int main(int argc, char* argv[]) {
if ((argc != 1 && argc != 2) || if ((argc != 1 && argc != 2) ||
(argc == 2 && argv[1] == std::string("--help"))) { (argc == 2 && argv[1] == std::string("--help"))) {
std::cerr << "Usage:\n" std::cerr << "Usage:\n" << argv[0] << " [path-to-webm-file]\n\n"
<< argv[0] << " [path-to-webm-file]\n\n"
<< "Prints info for the WebM file specified in the command line. " << "Prints info for the WebM file specified in the command line. "
"If no file is\n" "If no file is\n"
<< "specified, stdin is used as input.\n"; << "specified, stdin is used as input.\n";
return EXIT_FAILURE; return EXIT_FAILURE;
} }
FILE* file = (argc == 2) ? std::fopen(argv[1], "rb") FILE* file = (argc == 2) ? std::fopen(argv[1], "rb") :
: std::freopen(nullptr, "rb", stdin); std::freopen(nullptr, "rb", stdin);
if (!file) { if (!file) {
std::cerr << "File cannot be opened\n"; std::cerr << "File cannot be opened\n";
return EXIT_FAILURE; return EXIT_FAILURE;

View File

@ -63,8 +63,8 @@ extern "C" int LLVMFuzzerTestOneInput(const std::uint8_t* data,
#if __AFL_COMPILER #if __AFL_COMPILER
int main(int argc, char* argv[]) { int main(int argc, char* argv[]) {
FILE* file = (argc == 2) ? std::fopen(argv[1], "rb") FILE* file = (argc == 2) ? std::fopen(argv[1], "rb") :
: std::freopen(nullptr, "rb", stdin); std::freopen(nullptr, "rb", stdin);
if (!file) { if (!file) {
std::cerr << "File cannot be opened\n"; std::cerr << "File cannot be opened\n";
return EXIT_FAILURE; return EXIT_FAILURE;

View File

@ -36,7 +36,8 @@ namespace webm {
Otherwise it will return false since the element was ommitted or skipped when Otherwise it will return false since the element was ommitted or skipped when
parsing. parsing.
*/ */
template <typename T> class Element { template <typename T>
class Element {
public: public:
/** /**
Value-initializes the element's value and makes `is_present()` false. Value-initializes the element's value and makes `is_present()` false.

View File

@ -72,7 +72,8 @@ class FileReader : public Reader {
private: private:
struct FileCloseFunctor { struct FileCloseFunctor {
void operator()(FILE* file) const { void operator()(FILE* file) const {
if (file) std::fclose(file); if (file)
std::fclose(file);
} }
}; };

View File

@ -45,7 +45,8 @@ class IstreamReader : public Reader {
reference derived from `std::istream`. reference derived from `std::istream`.
*/ */
template <typename T> template <typename T>
explicit IstreamReader(T&& istream) : istream_(new T(std::move(istream))) {} explicit IstreamReader(T&& istream)
: istream_(new T(std::move(istream))) {}
/** /**
Constructs a new reader by moving the provided reader into the new reader. Constructs a new reader by moving the provided reader into the new reader.

View File

@ -60,7 +60,7 @@ class Ancestory {
// Constructs an Ancestory using the first count elements of ancestory. // Constructs an Ancestory using the first count elements of ancestory.
// ancestory must have static storage duration. // ancestory must have static storage duration.
template <std::size_t N> template <std::size_t N>
Ancestory(const Id (&ancestory)[N], std::size_t count) Ancestory(const Id(&ancestory)[N], std::size_t count)
: begin_(ancestory), end_(ancestory + count) { : begin_(ancestory), end_(ancestory + count) {
assert(count <= N); assert(count <= N);
} }

View File

@ -13,7 +13,8 @@ namespace webm {
std::uint8_t CountLeadingZeros(std::uint8_t value) { std::uint8_t CountLeadingZeros(std::uint8_t value) {
// Special case for 0 since we can't shift by sizeof(T) * 8 bytes. // Special case for 0 since we can't shift by sizeof(T) * 8 bytes.
if (value == 0) return 8; if (value == 0)
return 8;
std::uint8_t count = 0; std::uint8_t count = 0;
while (!(value & (0x80 >> count))) { while (!(value & (0x80 >> count))) {

View File

@ -50,11 +50,13 @@ class BlockHeaderParser : public Parser {
int timecode_bytes_remaining_ = 2; int timecode_bytes_remaining_ = 2;
enum class State { enum class State {
/* clang-format off */
// State Transitions to state When // State Transitions to state When
kReadingTrackNumber, // kReadingTimecode track parsed kReadingTrackNumber, // kReadingTimecode track parsed
kReadingTimecode, // kReadingFlags timecode parsed kReadingTimecode, // kReadingFlags timecode parsed
kReadingFlags, // kDone flags parsed kReadingFlags, // kDone flags parsed
kDone, // No transitions from here (must call Init) kDone, // No transitions from here (must call Init)
/* clang-format on */
} state_ = State::kReadingTrackNumber; } state_ = State::kReadingTrackNumber;
}; };

View File

@ -274,7 +274,8 @@ Status BasicBlockParser<T>::Feed(Callback* callback, Reader* reader,
} }
} }
template <typename T> bool BasicBlockParser<T>::WasSkipped() const { template <typename T>
bool BasicBlockParser<T>::WasSkipped() const {
return state_ == State::kSkipping; return state_ == State::kSkipping;
} }

View File

@ -33,7 +33,8 @@ namespace webm {
// http://www.webmproject.org/docs/container/#Block // http://www.webmproject.org/docs/container/#Block
// http://matroska.org/technical/specs/index.html#block_structure // http://matroska.org/technical/specs/index.html#block_structure
// http://matroska.org/technical/specs/index.html#simpleblock_structure // http://matroska.org/technical/specs/index.html#simpleblock_structure
template <typename T> class BasicBlockParser : public ElementParser { template <typename T>
class BasicBlockParser : public ElementParser {
static_assert(std::is_same<T, Block>::value || static_assert(std::is_same<T, Block>::value ||
std::is_same<T, SimpleBlock>::value, std::is_same<T, SimpleBlock>::value,
"T must be Block or SimpleBlock"); "T must be Block or SimpleBlock");
@ -89,6 +90,7 @@ template <typename T> class BasicBlockParser : public ElementParser {
// Parsing states for the finite-state machine. // Parsing states for the finite-state machine.
enum class State { enum class State {
/* clang-format off */
// State Transitions to state When // State Transitions to state When
kReadingHeader, // kGettingAction no lacing kReadingHeader, // kGettingAction no lacing
// kReadingLaceCount yes lacing // kReadingLaceCount yes lacing
@ -106,6 +108,7 @@ template <typename T> class BasicBlockParser : public ElementParser {
kSkipping, // No transitions from here (must call Init) kSkipping, // No transitions from here (must call Init)
kReadingFrames, // kDone all frames read kReadingFrames, // kDone all frames read
kDone, // No transitions from here (must call Init) kDone, // No transitions from here (must call Init)
/* clang-format on */
}; };
// The current state of the parser. // The current state of the parser.

View File

@ -26,7 +26,8 @@ namespace webm {
// Spec reference for string/binary elements: // Spec reference for string/binary elements:
// http://matroska.org/technical/specs/index.html#EBML_ex // http://matroska.org/technical/specs/index.html#EBML_ex
// https://github.com/Matroska-Org/ebml-specification/blob/master/specification.markdown#ebml-element-types // https://github.com/Matroska-Org/ebml-specification/blob/master/specification.markdown#ebml-element-types
template <typename T> class ByteParser : public ElementParser { template <typename T>
class ByteParser : public ElementParser {
public: public:
static_assert(std::is_same<T, std::vector<std::uint8_t>>::value || static_assert(std::is_same<T, std::vector<std::uint8_t>>::value ||
std::is_same<T, std::string>::value, std::is_same<T, std::string>::value,

View File

@ -135,7 +135,8 @@ Status Callback::Skip(Reader* reader, std::uint64_t* bytes_remaining) {
assert(reader != nullptr); assert(reader != nullptr);
assert(bytes_remaining != nullptr); assert(bytes_remaining != nullptr);
if (*bytes_remaining == 0) return Status(Status::kOkCompleted); if (*bytes_remaining == 0)
return Status(Status::kOkCompleted);
Status status; Status status;
do { do {

View File

@ -27,7 +27,8 @@ namespace webm {
// http://matroska.org/technical/specs/index.html#EBML_ex // http://matroska.org/technical/specs/index.html#EBML_ex
// https://github.com/Matroska-Org/ebml-specification/blob/master/specification.markdown#element-data-size // https://github.com/Matroska-Org/ebml-specification/blob/master/specification.markdown#element-data-size
// https://github.com/Matroska-Org/ebml-specification/blob/master/specification.markdown#ebml-element-types // https://github.com/Matroska-Org/ebml-specification/blob/master/specification.markdown#ebml-element-types
template <typename T> class IntParser : public ElementParser { template <typename T>
class IntParser : public ElementParser {
public: public:
static_assert( static_assert(
std::is_same<T, std::int64_t>::value || std::is_same<T, std::int64_t>::value ||

View File

@ -55,7 +55,8 @@ class MasterParser : public ElementParser {
// //
// Initializer lists don't support move-only types (i.e. std::unique_ptr), so // Initializer lists don't support move-only types (i.e. std::unique_ptr), so
// instead a variadic template is used. // instead a variadic template is used.
template <typename... T> explicit MasterParser(T&&... parser_pairs) { template <typename... T>
explicit MasterParser(T&&... parser_pairs) {
// Prefer an odd reserve size. This makes libc++ use a prime number for the // Prefer an odd reserve size. This makes libc++ use a prime number for the
// bucket count. Otherwise, if it happens to be a power of 2, then libc++ // bucket count. Otherwise, if it happens to be a power of 2, then libc++
// will use a power-of-2 bucket count (and since Matroska EBML IDs have low // will use a power-of-2 bucket count (and since Matroska EBML IDs have low
@ -127,6 +128,7 @@ class MasterParser : public ElementParser {
private: private:
// Parsing states for the finite-state machine. // Parsing states for the finite-state machine.
enum class State { enum class State {
/* clang-format off */
// State Transitions to state When // State Transitions to state When
kFirstReadOfChildId, // kFinishingReadingChildId size(id) > 1 kFirstReadOfChildId, // kFinishingReadingChildId size(id) > 1
// kReadingChildSize size(id) == 1 // kReadingChildSize size(id) == 1
@ -142,6 +144,7 @@ class MasterParser : public ElementParser {
// kFirstReadOfChildId read < my_size_ // kFirstReadOfChildId read < my_size_
// kEndReached read == my_size_ // kEndReached read == my_size_
kEndReached, // No transitions from here (must call Init) kEndReached, // No transitions from here (must call Init)
/* clang-format on */
}; };
using StdHashId = std::hash<std::underlying_type<Id>::type>; using StdHashId = std::hash<std::underlying_type<Id>::type>;
@ -204,7 +207,8 @@ class MasterParser : public ElementParser {
// Inserts the parser into the parsers_ map and asserts it is the only parser // Inserts the parser into the parsers_ map and asserts it is the only parser
// registers to parse the corresponding Id. // registers to parse the corresponding Id.
template <typename T> void InsertParser(T&& parser) { template <typename T>
void InsertParser(T&& parser) {
bool inserted = parsers_.insert(std::forward<T>(parser)).second; bool inserted = parsers_.insert(std::forward<T>(parser)).second;
(void)inserted; // Silence unused variable warning. (void)inserted; // Silence unused variable warning.
assert(inserted); // Make sure there aren't duplicates. assert(inserted); // Make sure there aren't duplicates.

View File

@ -58,7 +58,8 @@ namespace webm {
// : MasterValueParser(MakeChild<BoolParser>(Id::kBar, &Foo::bar), // : MasterValueParser(MakeChild<BoolParser>(Id::kBar, &Foo::bar),
// MakeChild<BoolParser>(Id::kBaz, &Foo::baz)) {} // MakeChild<BoolParser>(Id::kBaz, &Foo::baz)) {}
// }; // };
template <typename T> class MasterValueParser : public ElementParser { template <typename T>
class MasterValueParser : public ElementParser {
public: public:
Status Init(const ElementMetadata& metadata, Status Init(const ElementMetadata& metadata,
std::uint64_t max_size) override { std::uint64_t max_size) override {
@ -340,10 +341,12 @@ template <typename T> class MasterValueParser : public ElementParser {
// Helper struct that will be std::true_type if Tag is in Tags, or // Helper struct that will be std::true_type if Tag is in Tags, or
// std::false_type otherwise. // std::false_type otherwise.
template <typename Tag, typename... Tags> struct HasTag; template <typename Tag, typename... Tags>
struct HasTag;
// Base condition: Tags is empty, so it trivially does not contain Tag. // Base condition: Tags is empty, so it trivially does not contain Tag.
template <typename Tag> struct HasTag<Tag> : std::false_type {}; template <typename Tag>
struct HasTag<Tag> : std::false_type {};
// If the head of the Tags list is a different tag, skip it and check the // If the head of the Tags list is a different tag, skip it and check the
// remaining tags. // remaining tags.
@ -409,7 +412,8 @@ template <typename T> class MasterValueParser : public ElementParser {
return Status(Status::kOkCompleted); return Status(Status::kOkCompleted);
} }
template <typename Tag> constexpr static bool has_tag() { template <typename Tag>
constexpr static bool has_tag() {
return HasTag<Tag, Tags...>::value; return HasTag<Tag, Tags...>::value;
} }
}; };

View File

@ -24,7 +24,8 @@ namespace webm {
// parsing operations. The parser is allocated when Init is called. This class // parsing operations. The parser is allocated when Init is called. This class
// is intended to be used with recursive elements, where a parser needs to // is intended to be used with recursive elements, where a parser needs to
// recursively instantiate parsers of the same type. // recursively instantiate parsers of the same type.
template <typename T> class RecursiveParser : public ElementParser { template <typename T>
class RecursiveParser : public ElementParser {
public: public:
RecursiveParser() = default; RecursiveParser() = default;

View File

@ -55,10 +55,12 @@ class VirtualBlockParser : public ElementParser {
BlockHeaderParser parser_; BlockHeaderParser parser_;
enum class State { enum class State {
/* clang-format off */
// State Transitions to state When // State Transitions to state When
kReadingHeader, // kValidatingSize header parsed kReadingHeader, // kValidatingSize header parsed
kValidatingSize, // kDone no errors kValidatingSize, // kDone no errors
kDone, // No transitions from here (must call Init) kDone, // No transitions from here (must call Init)
/* clang-format on */
} state_ = State::kReadingHeader; } state_ = State::kReadingHeader;
}; };

View File

@ -184,6 +184,7 @@ class WebmParser::DocumentParser {
private: private:
// Parsing states for the finite-state machine. // Parsing states for the finite-state machine.
enum class State { enum class State {
/* clang-format off */
// State Transitions to state When // State Transitions to state When
kBegin, // kReadingChildId done kBegin, // kReadingChildId done
kReadingChildId, // kReadingChildSize done kReadingChildId, // kReadingChildSize done
@ -195,6 +196,7 @@ class WebmParser::DocumentParser {
kReadingChildBody, // kValidatingChildSize cached metadata kReadingChildBody, // kValidatingChildSize cached metadata
// kReadingChildId otherwise // kReadingChildId otherwise
kEndReached, // No transitions from here kEndReached, // No transitions from here
/* clang-format on */
}; };
// The parser for parsing child element Ids. // The parser for parsing child element Ids.

View File

@ -24,7 +24,8 @@ namespace webm {
// Base class for unit tests that test an instance of the Parser inteface. The // Base class for unit tests that test an instance of the Parser inteface. The
// template parameter T is the parser class being tested. // template parameter T is the parser class being tested.
template <typename T> class ParserTest : public testing::Test { template <typename T>
class ParserTest : public testing::Test {
public: public:
// Sets the reader's internal buffer to the given buffer. // Sets the reader's internal buffer to the given buffer.
virtual void SetReaderData(std::vector<std::uint8_t> data) { virtual void SetReaderData(std::vector<std::uint8_t> data) {
@ -34,7 +35,8 @@ template <typename T> class ParserTest : public testing::Test {
// Destroys and recreates the parser, forwarding the arguments to the // Destroys and recreates the parser, forwarding the arguments to the
// constructor. This is primarily useful for tests that require the parser to // constructor. This is primarily useful for tests that require the parser to
// have different constructor parameters. // have different constructor parameters.
template <typename... Args> void ResetParser(Args&&... args) { template <typename... Args>
void ResetParser(Args&&... args) {
parser_.~T(); parser_.~T();
new (&parser_) T(std::forward<Args>(args)...); new (&parser_) T(std::forward<Args>(args)...);
} }

View File

@ -23,7 +23,7 @@ namespace {
// Creates a std::array from a string literal (and omits the trailing // Creates a std::array from a string literal (and omits the trailing
// NUL-character). // NUL-character).
template <std::size_t N> template <std::size_t N>
std::array<std::uint8_t, N - 1> ArrayFromString(const char (&string)[N]) { std::array<std::uint8_t, N - 1> ArrayFromString(const char(&string)[N]) {
std::array<std::uint8_t, N - 1> array; std::array<std::uint8_t, N - 1> array;
std::copy_n(string, N - 1, array.begin()); std::copy_n(string, N - 1, array.begin());
return array; return array;