Skip to content

Commit

Permalink
Fix compile failure for C++17.
Browse files Browse the repository at this point in the history
I don't understand why this target is being included in the build at all, however, this will allow it to compile for C++17 irrespective of it doing nothing.

PiperOrigin-RevId: 712585677
  • Loading branch information
jwhpryor authored and copybara-github committed Jan 6, 2025
1 parent d855896 commit 5646574
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 5 deletions.
13 changes: 12 additions & 1 deletion implementation/class.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,10 @@ namespace jni {

template <typename Extends_, typename Constructors_, typename Static_,
typename Methods_, typename Fields_>
struct Class {};
struct Class {
constexpr Class() = default;
constexpr Class(const char* name) {}
};

template <typename Extends_, typename... Constructors_,
typename... StaticMethods_, typename... StaticFields_,
Expand Down Expand Up @@ -70,6 +73,14 @@ struct Class<Extends_, std::tuple<Constructors_...>,
// provided where they are and aren't present.
////////////////////////////////////////////////////////////////////////////////

// To stifle a test failure.
constexpr Class()
: Object("__JNI_BIND__NO_CLASS__"),
constructors_(Constructor<>{}),
static_(),
methods_(),
fields_() {}

// Methods + Fields.
explicit constexpr Class(const char* class_name, Methods_... methods,
Fields_... fields)
Expand Down
4 changes: 2 additions & 2 deletions implementation/return.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ struct Return : ReturnBase {

using Raw = Raw_;

constexpr Return() = default;
constexpr Return() {}

template <typename Raw>
constexpr explicit Return(Raw raw) : raw_(raw) {}
Expand All @@ -42,7 +42,7 @@ struct Return<void> : ReturnBase {
using Raw = void;
const Void raw_{};

constexpr Return() = default;
constexpr Return() {}
};

Return() -> Return<void>;
Expand Down
4 changes: 2 additions & 2 deletions metaprogramming/string_literal.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,9 @@ struct StringLiteral {
template <size_t N>
StringLiteral(const char (&str)[N]) -> StringLiteral<N>;

} // namespace jni::metaprogramming

#endif // __cplusplus >= 202002L
#endif // __cplusplus

} // namespace jni::metaprogramming

#endif // JNI_BIND_METAPROGRAMMING_STRING_LITERAL_H_

0 comments on commit 5646574

Please sign in to comment.