Я пишу «разделитель строк» для парсера, и я хочу иметь возможность использовать как char, так и wchar_t. У меня есть следующий метод:
static void tokenize(const basic_string<T> &, vector<CToken> &);
И я хотел бы дать ему широкую строку для разбора:
vector<CToken> tTokens;
CTokenizer<wstring>::tokenize(L"if(i == 0) { print i + 2; } else { return; }", tTokens);
Я также попробовал:
vector<CToken> tTokens;
const wstring sCode = L"if(i == 0) { print i + 2; } else { return; }";
CTokenizer<wstring>::tokenize(sCode, tTokens);
Поэтому я предполагаю, что есть что-то, чего я не понимаю в шаблонах. Что я могу сделать, пожалуйста?
Спасибо за вашу помощь !
РЕДАКТИРОВАТЬ: Вот мой журнал сборки:
1>------ Build started: Project: c_parser, Configuration: Debug Win32 ------
1> Parsercpp.cpp
1>c:\users\virus\documents\visual studio 2012\projects\c_parser\c_parser\parsercpp.cpp(44): error C2958: the left parenthesis '(' found at 'c:\users\virus\documents\visual studio 2012\projects\c_parser\c_parser\parsercpp.cpp(38)' was not matched correctly
1>c:\program files (x86)\microsoft visual studio 11.0\vc\include\xstring(529): error C2621: member 'std::_String_val<_Val_types>::_Bxty::_Buf' of union 'std::_String_val<_Val_types>::_Bxty' has copy constructor
1> with
1> [
1> _Val_types=std::_Simple_types<std::basic_string<wchar_t,std::char_traits<wchar_t>,std::allocator<wchar_t>>>
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xstring(532) : see reference to class template instantiation 'std::_String_val<_Val_types>::_Bxty' being compiled
1> with
1> [
1> _Val_types=std::_Simple_types<std::basic_string<wchar_t,std::char_traits<wchar_t>,std::allocator<wchar_t>>>
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xstring(627) : see reference to class template instantiation 'std::_String_val<_Val_types>' being compiled
1> with
1> [
1> _Val_types=std::_Simple_types<std::basic_string<wchar_t,std::char_traits<wchar_t>,std::allocator<wchar_t>>>
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xstring(700) : see reference to class template instantiation 'std::_String_alloc<_Al_has_storage,_Alloc_types>' being compiled
1> with
1> [
1> _Al_has_storage=false,
1> _Alloc_types=std::_String_base_types<std::wstring,std::allocator<std::wstring>>
1> ]
1> c:\users\virus\documents\visual studio 2012\projects\c_parser\c_parser\parsercpp.cpp(104) : see reference to class template instantiation 'std::basic_string<_Elem>' being compiled
1> with
1> [
1> _Elem=std::wstring
1> ]
1>c:\users\virus\documents\visual studio 2012\projects\c_parser\c_parser\parsercpp.cpp(104): error C2664: 'nsParser::CTokenizer<T>::tokenize' : cannot convert parameter 1 from 'const std::wstring' to 'const std::basic_string<_Elem> &'
1> with
1> [
1> T=std::wstring
1> ]
1> and
1> [
1> _Elem=std::wstring
1> ]
1> Reason: cannot convert from 'const std::wstring' to 'const std::basic_string<_Elem>'
1> with
1> [
1> _Elem=std::wstring
1> ]
1> No user-defined-conversion operator available that can perform this conversion, or the operator cannot be called
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
РЕДАКТИРОВАТЬ :
template<class T>
class CTokenizer
{
public:
static vector<T> s_tKeywords;
public:
static void tokenize(const basic_string<T> &, vector<CToken> &);
};
Код из parser.cpp приведен выше:
vector<CToken> tTokens;
const wstring sCode = L"if(i == 0) { print i + 2; } else { return; }";
CTokenizer<wstring>::tokenize(sCode, tTokens);
Вы должны быть экземпляром CTokenizer<wchar_t>
не CTokenizer<std::wstring>
, То, как вы это делаете, подпись tokenize()
становится
static void tokenize(const basic_string<wstring> &, vector<CToken> &);
Либо изменить tokenize
декларация
static void tokenize(const T &, vector<CToken> &);
или призыв к
CTokenizer<wchar_t>::tokenize(L"if(i == 0) { print i + 2; } else { return; }", tTokens);
редактировать после вашего комментария: Затем используйте часть «или» (в отличие от «либо») …
И с тех пор T
тогда это «тип символа» (не тип строки), я предлагаю вам переименовать его во что-то значимое.
Взяв код вашего второго EDIT, после этих изменений класс выглядит так:
template<class CharT>
class CTokenizer
{
public:
static vector< basic_string<CharT> > s_tKeywords;
public:
static void tokenize(const basic_string<CharT> &, vector<CToken> &);
};
тогда вы звоните tokenize
как я писал выше (с wchar_t
не wstring
, как параметр типа шаблона). (wstring
это просто псевдоним типа для basic_string<wchar_t>
.)