当前位置: 首页>>代码示例>>C++>>正文


C++ Tstring::find方法代码示例

本文整理汇总了C++中Tstring::find方法的典型用法代码示例。如果您正苦于以下问题:C++ Tstring::find方法的具体用法?C++ Tstring::find怎么用?C++ Tstring::find使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Tstring的用法示例。


在下文中一共展示了Tstring::find方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: StringReplace

static inline Tstring StringReplace( Tstring str, const Tstring2 & oldStr_, const Tstring3 & newStr_ ) {
	std::size_t pos = 0;
	const Tstring oldStr = oldStr_;
	const Tstring newStr = newStr_;
	while ( ( pos = str.find( oldStr, pos ) ) != Tstring::npos ) {
		str.replace( pos, oldStr.length(), newStr );
		pos += newStr.length();
	}
	return str;
}
开发者ID:Sappharad,项目名称:modizer,代码行数:10,代码来源:in_openmpt.cpp

示例2: isKnownFailure

		bool isKnownFailure(Tstring const & pStmt) const { for (size_t i = 0; i < mNumKnownFailures; i++) { if (Tstring::npos != pStmt.find(sKnownFailures[i])) return true; } return false; }
开发者ID:affinitydb,项目名称:tests_kernel,代码行数:1,代码来源:testmeansql.cpp

示例3: AdvancedMach

//2,高级过滤  L=20|01=0C|02=0B|20=CC|IP=211.1.1.1|P=9900 条件必须都要满足
BOOL CGPacket::AdvancedMach(Tstring& str)
{
	std::map<Tstring, Tstring> matchmap;
	int splitpos = 0, pos = 0;
	while (TRUE)
	{
		splitpos = str.find(_T('|'), pos);

		Tstring strSub;
		if (Tstring::npos != splitpos)
		{
			strSub = str.substr(pos, splitpos - pos);
		}
		else {
			strSub = str.substr(pos);
		}

		int assignpos;
		assignpos = strSub.find(_T('='));
		if (Tstring::npos != assignpos) {
			Tstring key, value;
			key = strSub.substr(0, assignpos);
			value = strSub.substr(assignpos+1);
			matchmap[key] = value;
		}
		if (splitpos == Tstring::npos)
			break;
		pos = splitpos + 1;
	}
		
	//2,高级过滤  L=20|01=0C|02=0B|20=CC|IP=211.1.1.1|P=9900 条件必须都要满足
	std::map<Tstring, Tstring>::iterator i;
	for (i = matchmap.begin(); i != matchmap.end(); i++)
	{
		Tstring Key, Value;
		Key = (*i).first;
		Value = (*i).second;
		if (Key == Tstring(_T("L"))) {
			if (m_dwSize != _ttoi(Value.c_str())) 
			{
				return FALSE;
			}

		}
		else if (Key == Tstring(_T("IP"))) {
			if (m_property.strIpAddr != Value)
			{
				return FALSE;
			}
		}
		else if (Key == Tstring(_T("P"))) {
			if (m_property.strPort != Value)
			{
				return FALSE;
			}

		}
		else {
			if (m_pBuf[_ttoi(Key.c_str())] != _ttoi(Value.c_str()))
			{
				return FALSE;
			}
		}
	}
	return TRUE;
}
开发者ID:danieljiang0415,项目名称:gh,代码行数:67,代码来源:GPacket.cpp

示例4: PreProcessPackeTstring

Tstring CSendPage::PreProcessPackeTstring(Tstring& tstrStr )
{
	Tstring tstrTemp, tstrRet;
	Tstring::size_type posLeftBracket = 0, posRightBracket = -1;
	posLeftBracket = tstrStr.find(_T("["));

	if (posLeftBracket == Tstring::npos)
	{
		return tstrStr;
	}
	
	tstrRet = tstrStr.substr( 0, posLeftBracket);

ParseRightBracket:

	DWORD dwBracketDataSize;
	posRightBracket = tstrStr.find(_T("]"), posLeftBracket);
	if (posRightBracket == Tstring::npos)
	{
		return _T("");
	}
	dwBracketDataSize = posRightBracket - posLeftBracket -1 ;
	tstrTemp = tstrStr.substr(posLeftBracket + 1, dwBracketDataSize);

	TCHAR tszTemp[1024];
	INT   iInc;

	TCHAR tszBracket[32], tszNum[32];
	TCHAR ch, *ptStr, sign;
	int i, j, flag;

	i=0, j=0, flag=0;
	ptStr = (TCHAR*)tstrTemp.c_str();

	do{
		ch = *ptStr++;
		if(ch == _T('+') || ch == _T('-'))
		{
			sign = ch;
			flag = !flag;
		}
		else if(!flag)
		{
			tszBracket[i++] = ch;
		}else
		{
			tszNum[j++] = ch;
		}
	}while(ch != _T('\0'));
	tszBracket[i] = _T('\0');
	tszNum[j] = _T('\0');

	//todo inc or dec the string
	tstrRet += Tstring(tszBracket);

	BYTE *pHexBuf = new BYTE[i];
	DWORD dwSelHexSize = Utility::StringLib::Tstring2Hex(tszBracket, pHexBuf);
	
	switch (dwSelHexSize)
	{
	case 1:
		*pHexBuf += (sign == _T('+') ? _ttoi(tszNum) : 0 - _ttoi(tszNum));
		break;
	case 2:
		*(WORD*)pHexBuf = htons(htons(*(WORD*)pHexBuf) + (sign == _T('+') ? _ttoi(tszNum) : 0 - _ttoi(tszNum)));
		break;
	case 4:
		*(DWORD*)pHexBuf =  htonl(htonl(*(DWORD*)pHexBuf) + (sign == _T('+') ? _ttoi(tszNum) : 0 - _ttoi(tszNum)));
		break;
	default:
		delete[]pHexBuf;
		return _T("");
	}

	tstrTemp = Utility::StringLib::Hex2Tstring(pHexBuf, dwSelHexSize);

	delete[]pHexBuf;

	tstrTemp = Tstring(_T("[")) + tstrTemp + (sign == _T('+') ?Tstring(_T("+")):Tstring(_T("-"))) + Tstring(tszNum) + Tstring(_T("]"));

	tstrStr.replace(posLeftBracket, dwBracketDataSize + 2, tstrTemp);

	posLeftBracket = tstrStr.find(_T("["), posRightBracket);

	if (posLeftBracket != Tstring::npos){
		tstrRet += tstrStr.substr( posRightBracket+1, posLeftBracket - posRightBracket - 1 );
		goto ParseRightBracket;
	}else
	{
		tstrRet += tstrStr.substr( posRightBracket+1 );
	}

	return tstrRet;
	
}
开发者ID:danieljiang0415,项目名称:gh,代码行数:95,代码来源:sendpage.cpp


注:本文中的Tstring::find方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。