查看以下测试代码:
#include <string>
#include <iostream>
using namespace std;
struct test {
operator string() const { return "test"; }
};
int main() {
test ts;
cout << ts << endl;
}
生成有点令人生畏的错误消息,该错误消息本质上说我没有定义运算符<<。为什么字符串运算符不足以解决重载?似乎test-> string将是有效的隐式转换...
<source>: In function 'int main()':
<source>:12:10: error: no match for 'operator<<' (operand types are 'std::ostream' {aka 'std::basic_ostream<char>'} and 'test')
cout << ts << endl;
~~~~~^~~~~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:108:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(std::basic_ostream<_CharT, _Traits>::__ostream_type& (*)(std::basic_ostream<_CharT, _Traits>::__ostream_type&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(__ostream_type& (*__pf)(__ostream_type&))
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:108:7: note: no known conversion for argument 1 from 'test' to 'std::basic_ostream<char>::__ostream_type& (*)(std::basic_ostream<char>::__ostream_type&)' {aka 'std::basic_ostream<char>& (*)(std::basic_ostream<char>&)'}
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:117:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(std::basic_ostream<_CharT, _Traits>::__ios_type& (*)(std::basic_ostream<_CharT, _Traits>::__ios_type&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>; std::basic_ostream<_CharT, _Traits>::__ios_type = std::basic_ios<char>]'
operator<<(__ios_type& (*__pf)(__ios_type&))
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:117:7: note: no known conversion for argument 1 from 'test' to 'std::basic_ostream<char>::__ios_type& (*)(std::basic_ostream<char>::__ios_type&)' {aka 'std::basic_ios<char>& (*)(std::basic_ios<char>&)'}
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:127:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(std::ios_base& (*)(std::ios_base&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(ios_base& (*__pf) (ios_base&))
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:127:7: note: no known conversion for argument 1 from 'test' to 'std::ios_base& (*)(std::ios_base&)'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:166:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(long __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:166:7: note: no known conversion for argument 1 from 'test' to 'long int'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:170:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(unsigned long __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:170:7: note: no known conversion for argument 1 from 'test' to 'long unsigned int'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:174:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(bool) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(bool __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:174:7: note: no known conversion for argument 1 from 'test' to 'bool'
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:693,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:91:5: note: candidate: 'std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(short int) [with _CharT = char; _Traits = std::char_traits<char>]'
basic_ostream<_CharT, _Traits>::
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:91:5: note: no known conversion for argument 1 from 'test' to 'short int'
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:181:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(short unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(unsigned short __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:181:7: note: no known conversion for argument 1 from 'test' to 'short unsigned int'
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:693,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:105:5: note: candidate: 'std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(int) [with _CharT = char; _Traits = std::char_traits<char>]'
basic_ostream<_CharT, _Traits>::
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:105:5: note: no known conversion for argument 1 from 'test' to 'int'
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:192:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(unsigned int __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:192:7: note: no known conversion for argument 1 from 'test' to 'unsigned int'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:201:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long long int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(long long __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:201:7: note: no known conversion for argument 1 from 'test' to 'long long int'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:205:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long long unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(unsigned long long __n)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:205:7: note: no known conversion for argument 1 from 'test' to 'long long unsigned int'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:220:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(double) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(double __f)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:220:7: note: no known conversion for argument 1 from 'test' to 'double'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:224:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(float) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(float __f)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:224:7: note: no known conversion for argument 1 from 'test' to 'float'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:232:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long double) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(long double __f)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:232:7: note: no known conversion for argument 1 from 'test' to 'long double'
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:245:7: note: candidate: 'std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(const void*) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]'
operator<<(const void* __p)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:245:7: note: no known conversion for argument 1 from 'test' to 'const void*'
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:693,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:119:5: note: candidate: 'std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(std::basic_ostream<_CharT, _Traits>::__streambuf_type*) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__streambuf_type = std::basic_streambuf<char>]'
basic_ostream<_CharT, _Traits>::
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:119:5: note: no known conversion for argument 1 from 'test' to 'std::basic_ostream<char>::__streambuf_type*' {aka 'std::basic_streambuf<char>*'}
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/string:52,
from <source>:1:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/basic_string.h:6314:5: note: candidate: 'template<class _CharT, class _Traits, class _Alloc> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::__cxx11::basic_string<_CharT, _Traits, _Alloc>&)'
operator<<(basic_ostream<_CharT, _Traits>& __os,
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/basic_string.h:6314:5: note: template argument deduction/substitution failed:
<source>:12:13: note: 'test' is not derived from 'const std::__cxx11::basic_string<_CharT, _Traits, _Alloc>'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ios_base.h:46,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ios:42,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:38,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/system_error:217:5: note: candidate: 'template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::error_code&)'
operator<<(basic_ostream<_CharT, _Traits>& __os, const error_code& __e)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/system_error:217:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'const std::error_code&'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:497:5: note: candidate: 'template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, _CharT)'
operator<<(basic_ostream<_CharT, _Traits>& __out, _CharT __c)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:497:5: note: template argument deduction/substitution failed:
<source>:12:13: note: deduced conflicting types for parameter '_CharT' ('char' and 'test')
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:502:5: note: candidate: 'template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, char)'
operator<<(basic_ostream<_CharT, _Traits>& __out, char __c)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:502:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'char'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:508:5: note: candidate: 'template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, char)'
operator<<(basic_ostream<char, _Traits>& __out, char __c)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:508:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'char'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:514:5: note: candidate: 'template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, signed char)'
operator<<(basic_ostream<char, _Traits>& __out, signed char __c)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:514:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'signed char'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:519:5: note: candidate: 'template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, unsigned char)'
operator<<(basic_ostream<char, _Traits>& __out, unsigned char __c)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:519:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'unsigned char'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:539:5: note: candidate: 'template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const _CharT*)'
operator<<(basic_ostream<_CharT, _Traits>& __out, const _CharT* __s)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:539:5: note: template argument deduction/substitution failed:
<source>:12:13: note: mismatched types 'const _CharT*' and 'test'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:693,
from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:321:5: note: candidate: 'template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const char*)'
operator<<(basic_ostream<_CharT, _Traits>& __out, const char* __s)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/bits/ostream.tcc:321:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'const char*'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:556:5: note: candidate: 'template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, const char*)'
operator<<(basic_ostream<char, _Traits>& __out, const char* __s)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:556:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'const char*'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:569:5: note: candidate: 'template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, const signed char*)'
operator<<(basic_ostream<char, _Traits>& __out, const signed char* __s)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:569:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'const signed char*'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:574:5: note: candidate: 'template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, const unsigned char*)'
operator<<(basic_ostream<char, _Traits>& __out, const unsigned char* __s)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:574:5: note: template argument deduction/substitution failed:
<source>:12:13: note: cannot convert 'ts' (type 'test') to type 'const unsigned char*'
cout << ts << endl;
^~
In file included from /opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/iostream:39,
from <source>:2:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:682:5: note: candidate: 'template<class _Ostream, class _Tp> typename std::enable_if<std::__and_<std::__not_<std::is_lvalue_reference<_Tp> >, std::__is_convertible_to_basic_ostream<_Ostream>, std::__is_insertable<typename std::__is_convertible_to_basic_ostream<_Tp>::__ostream_type, const _Tp&, void> >::value, typename std::__is_convertible_to_basic_ostream<_Tp>::__ostream_type>::type std::operator<<(_Ostream&&, const _Tp&)'
operator<<(_Ostream&& __os, const _Tp& __x)
^~~~~~~~
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:682:5: note: template argument deduction/substitution failed:
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream: In substitution of 'template<class _Ostream, class _Tp> typename std::enable_if<std::__and_<std::__not_<std::is_lvalue_reference<_Tp> >, std::__is_convertible_to_basic_ostream<_Ostream>, std::__is_insertable<typename std::__is_convertible_to_basic_ostream<_Tp>::__ostream_type, const _Tp&, void> >::value, typename std::__is_convertible_to_basic_ostream<_Tp>::__ostream_type>::type std::operator<<(_Ostream&&, const _Tp&) [with _Ostream = std::basic_ostream<char>&; _Tp = test]':
<source>:12:13: required from here
/opt/compiler-explorer/gcc-8.2.0/include/c++/8.2.0/ostream:682:5: error: no type named 'type' in 'struct std::enable_if<false, std::basic_ostream<char>&>'
Compiler returned: 1