From 2046aec032f743023a5e353735255d951e2e54d6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Poulhi=C3=A8s?= Date: Sat, 17 Dec 2022 16:23:05 +0100 Subject: gccrs: fix some clang warnings MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This fixes some extra warnings reported by clang. gcc/rust/ChangeLog: PR rust/108111 * ast/rust-ast-full-decls.h (StructPatternElements): Declare as a class. * ast/rust-item.h (EnumItem): Mark several method as being overrides. * ast/rust-pattern.h (StructPattern::get_locus): Add override. * lex/rust-lex.h (BufferInputSource): Use reference_wrapper instead of bare reference. (TokenSource::get): Add method to implement the reference_wrapper interface. * typecheck/rust-tyty.h (TypeBoundPredicate): Add empty dtor. * util/rust-buffered-queue.h (peek): Source token stream is now using a reference_wrapper, use .get() Signed-off-by: Marc Poulhiès --- gcc/rust/ast/rust-ast-full-decls.h | 2 +- gcc/rust/ast/rust-item.h | 10 +++++----- gcc/rust/ast/rust-pattern.h | 2 +- gcc/rust/lex/rust-lex.h | 5 ++++- gcc/rust/typecheck/rust-tyty.h | 2 ++ gcc/rust/util/rust-buffered-queue.h | 2 +- 6 files changed, 14 insertions(+), 9 deletions(-) (limited to 'gcc') diff --git a/gcc/rust/ast/rust-ast-full-decls.h b/gcc/rust/ast/rust-ast-full-decls.h index 5a85646..2275b49 100644 --- a/gcc/rust/ast/rust-ast-full-decls.h +++ b/gcc/rust/ast/rust-ast-full-decls.h @@ -240,7 +240,7 @@ class StructPatternField; class StructPatternFieldTuplePat; class StructPatternFieldIdentPat; class StructPatternFieldIdent; -struct StructPatternElements; +class StructPatternElements; class StructPattern; class TupleStructItems; class TupleStructItemsNoRange; diff --git a/gcc/rust/ast/rust-item.h b/gcc/rust/ast/rust-item.h index 60944d7..a094cc4 100644 --- a/gcc/rust/ast/rust-item.h +++ b/gcc/rust/ast/rust-item.h @@ -2210,18 +2210,18 @@ public: return std::unique_ptr (clone_item_impl ()); } - virtual std::string as_string () const; + virtual std::string as_string () const override; // not pure virtual as not abstract - virtual void accept_vis (ASTVisitor &vis); + virtual void accept_vis (ASTVisitor &vis) override; - Location get_locus () const { return locus; } + Location get_locus () const override { return locus; } Identifier get_identifier () const { return variant_name; } // Based on idea that name is never empty. - void mark_for_strip () { variant_name = ""; } - bool is_marked_for_strip () const { return variant_name.empty (); } + void mark_for_strip () override { variant_name = ""; } + bool is_marked_for_strip () const override { return variant_name.empty (); } protected: EnumItem *clone_item_impl () const override { return new EnumItem (*this); } diff --git a/gcc/rust/ast/rust-pattern.h b/gcc/rust/ast/rust-pattern.h index fbff0e4..d77dae2 100644 --- a/gcc/rust/ast/rust-pattern.h +++ b/gcc/rust/ast/rust-pattern.h @@ -919,7 +919,7 @@ public: * is empty). */ bool has_struct_pattern_elems () const { return !elems.is_empty (); } - Location get_locus () const { return path.get_locus (); } + Location get_locus () const override { return path.get_locus (); } void accept_vis (ASTVisitor &vis) override; diff --git a/gcc/rust/lex/rust-lex.h b/gcc/rust/lex/rust-lex.h index 8655788..a24c980 100644 --- a/gcc/rust/lex/rust-lex.h +++ b/gcc/rust/lex/rust-lex.h @@ -277,7 +277,7 @@ private: // InputSource input_source; // Input file queue. std::unique_ptr raw_input_source; - buffered_queue input_queue; + buffered_queue> input_queue; // Token source wrapper thing. struct TokenSource @@ -288,6 +288,9 @@ private: // Create a new TokenSource with given lexer. TokenSource (Lexer *parLexer) : lexer (parLexer) {} + // Used to mimic std::reference_wrapper that is used for InputSource. + TokenSource &get () { return *this; } + // Overload operator () to build token in lexer. TokenPtr next () { return lexer->build_token (); } }; diff --git a/gcc/rust/typecheck/rust-tyty.h b/gcc/rust/typecheck/rust-tyty.h index c7d5db3..b39c8a1 100644 --- a/gcc/rust/typecheck/rust-tyty.h +++ b/gcc/rust/typecheck/rust-tyty.h @@ -387,6 +387,8 @@ public: TypeBoundPredicate (const TypeBoundPredicate &other); + virtual ~TypeBoundPredicate (){}; + TypeBoundPredicate &operator= (const TypeBoundPredicate &other); static TypeBoundPredicate error (); diff --git a/gcc/rust/util/rust-buffered-queue.h b/gcc/rust/util/rust-buffered-queue.h index b864b32..fc40811 100644 --- a/gcc/rust/util/rust-buffered-queue.h +++ b/gcc/rust/util/rust-buffered-queue.h @@ -102,7 +102,7 @@ public: /* iterate through buffer and invoke operator () on source on values * past original end */ for (int i = 0; i < num_items_to_read; i++) - buffer[end + i] = source.next (); + buffer[end + i] = source.get ().next (); // move end based on additional items added end += num_items_to_read; -- cgit v1.1