error: #[classattr] can only have one argument (of type pyo3::Python) --> tests/ui/invalid_pymethods.rs:9:34 | 9 | fn class_attr_with_args(foo: i32) {} | ^^^ error: `#[classattr]` does not take any arguments --> tests/ui/invalid_pymethods.rs:14:5 | 14 | #[classattr(foobar)] | ^ error: static method needs #[staticmethod] attribute --> tests/ui/invalid_pymethods.rs:20:5 | 20 | fn staticmethod_without_attribute() {} | ^^ error: unexpected receiver --> tests/ui/invalid_pymethods.rs:26:35 | 26 | fn staticmethod_with_receiver(&self) {} | ^ error: expected receiver for #[getter] --> tests/ui/invalid_pymethods.rs:39:5 | 39 | fn getter_without_receiver() {} | ^^ error: expected receiver for #[setter] --> tests/ui/invalid_pymethods.rs:45:5 | 45 | fn setter_without_receiver() {} | ^^ error: `text_signature` not allowed on `__new__`; if you want to add a signature on `__new__`, put it on the struct definition instead --> tests/ui/invalid_pymethods.rs:51:12 | 51 | #[pyo3(text_signature = "()")] | ^^^^^^^^^^^^^^ error: static method needs #[staticmethod] attribute --> tests/ui/invalid_pymethods.rs:58:5 | 58 | fn text_signature_on_call() {} | ^^ error: `text_signature` not allowed with `getter` --> tests/ui/invalid_pymethods.rs:64:12 | 64 | #[pyo3(text_signature = "()")] | ^^^^^^^^^^^^^^ error: `text_signature` not allowed with `setter` --> tests/ui/invalid_pymethods.rs:71:12 | 71 | #[pyo3(text_signature = "()")] | ^^^^^^^^^^^^^^ error: `text_signature` not allowed with `classattr` --> tests/ui/invalid_pymethods.rs:78:12 | 78 | #[pyo3(text_signature = "()")] | ^^^^^^^^^^^^^^ error: `signature` not allowed with `getter` --> tests/ui/invalid_pymethods.rs:85:12 | 85 | #[pyo3(signature = ())] | ^^^^^^^^^ error: `signature` not allowed with `setter` --> tests/ui/invalid_pymethods.rs:92:12 | 92 | #[pyo3(signature = ())] | ^^^^^^^^^ error: `signature` not allowed with `classattr` --> tests/ui/invalid_pymethods.rs:99:12 | 99 | #[pyo3(signature = ())] | ^^^^^^^^^ error: cannot specify a second method type --> tests/ui/invalid_pymethods.rs:106:7 | 106 | #[staticmethod] | ^^^^^^^^^^^^ error: Python functions cannot have generic type parameters --> tests/ui/invalid_pymethods.rs:112:23 | 112 | fn generic_method(value: T) {} | ^ error: Python functions cannot have `impl Trait` arguments --> tests/ui/invalid_pymethods.rs:117:48 | 117 | fn impl_trait_method_first_arg(impl_trait: impl AsRef) {} | ^^^^ error: Python functions cannot have `impl Trait` arguments --> tests/ui/invalid_pymethods.rs:122:56 | 122 | fn impl_trait_method_second_arg(&self, impl_trait: impl AsRef) {} | ^^^^ error: `async fn` is not yet supported for Python functions. Additional crates such as `pyo3-asyncio` can be used to integrate async Rust and Python. For more information, see https://github.com/PyO3/pyo3/issues/1632 --> tests/ui/invalid_pymethods.rs:127:5 | 127 | async fn async_method(&self) {} | ^^^^^ error: `pass_module` cannot be used on Python methods --> tests/ui/invalid_pymethods.rs:132:12 | 132 | #[pyo3(pass_module)] | ^^^^^^^^^^^ error: Python objects are shared, so 'self' cannot be moved out of the Python interpreter. Try `&self`, `&mut self, `slf: PyRef<'_, Self>` or `slf: PyRefMut<'_, Self>`. --> tests/ui/invalid_pymethods.rs:138:29 | 138 | fn method_self_by_value(self) {} | ^^^^ error[E0592]: duplicate definitions with name `__pymethod___new____` --> tests/ui/invalid_pymethods.rs:143:1 | 143 | #[pymethods] | ^^^^^^^^^^^^ | | | duplicate definitions for `__pymethod___new____` | other definition for `__pymethod___new____` | = note: this error originates in the attribute macro `pymethods` (in Nightly builds, run with -Z macro-backtrace for more info) error[E0592]: duplicate definitions with name `__pymethod_func__` --> tests/ui/invalid_pymethods.rs:158:1 | 158 | #[pymethods] | ^^^^^^^^^^^^ | | | duplicate definitions for `__pymethod_func__` | other definition for `__pymethod_func__` | = note: this error originates in the attribute macro `pymethods` (in Nightly builds, run with -Z macro-backtrace for more info)