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 <dkm@kataplop.net>
class StructPatternFieldTuplePat;
class StructPatternFieldIdentPat;
class StructPatternFieldIdent;
-struct StructPatternElements;
+class StructPatternElements;
class StructPattern;
class TupleStructItems;
class TupleStructItemsNoRange;
return std::unique_ptr<EnumItem> (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); }
* 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;
// InputSource input_source;
// Input file queue.
std::unique_ptr<InputSource> raw_input_source;
- buffered_queue<int, InputSource &> input_queue;
+ buffered_queue<int, std::reference_wrapper<InputSource>> input_queue;
// Token source wrapper thing.
struct TokenSource
// 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 (); }
};
TypeBoundPredicate (const TypeBoundPredicate &other);
+ virtual ~TypeBoundPredicate (){};
+
TypeBoundPredicate &operator= (const TypeBoundPredicate &other);
static TypeBoundPredicate error ();
/* 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;