строка — C ++ L & quot; безотносительно & quot; — & GT; wstring — & gt; basic_string & л; Т & GT;

Я пишу «разделитель строк» ​​для парсера, и я хочу иметь возможность использовать как 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);

1

Решение

Вы должны быть экземпляром CTokenizer<wchar_t>не CTokenizer<std::wstring>, То, как вы это делаете, подпись tokenize() становится

static void tokenize(const basic_string<wstring> &, vector<CToken> &);
1

Другие решения

Либо изменить 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>.)

0

По вопросам рекламы [email protected]