亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? regularopt.cpp

?? 我的簡易編譯器終于在花了近20個工作日后完成了。按照設計是做成一個FormulaEx.dll
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
{
	int sl = strlen(szDateStr);
 
	CString sTmp2("");
	bool bDot = false;
	for( int j=0; j< sl; j++){
		if (szDateStr[j] >= '0' && szDateStr[j] <= '9'){
			if (bDot){
				sTmp2 = sTmp2 + '-';
				bDot = false;
			}
			sTmp2 = sTmp2 + szDateStr[j];
		}else if(sTmp2!="")
			bDot = true;
	}
	return sTmp2;
}

bool CRegularOpt::IsDate(LPCTSTR szTime ,CTime & t_time)
{
	int sl = strlen(szTime);
	int sp=0;
	int s=0;
	char c[5];
	int y,m,d;
	while(sp<sl && (szTime[sp]==' ' ||  szTime[sp]== 9)) sp++;
	while(sp<sl ){
		if(szTime[sp]>='0' &&  szTime[sp]<= '9'){
			if(s<4) c[s] = szTime[sp];
			sp++;s++;
			continue;
		}
		//if(szTime[sp] == '-') 
			sp++; 
		break;
	}//check year
	c[4]=0;
	y = atoi(c);
	if(y < 1970 || y>2038) return false;
	s=0;
	while(sp<sl ){
		if(szTime[sp]>='0' &&  szTime[sp]<= '9'){
			if(s<2) c[s] = szTime[sp];
			sp++;s++;
			continue;
		}
		//if(szTime[sp] == '-') 
		sp++; 
		break;
	}//check month
	if(s > 2) return false;
	c[s]=0;
	m = atoi(c);
	if(m<1 || m >12) return false;
	s=0;
	while(sp<sl ){
		if(szTime[sp]>='0' &&  szTime[sp]<= '9'){
			if(s<2) c[s] = szTime[sp];
			sp++;s++;
			continue;
		}
		break;
	}//check day
	if(s > 2) return false;
	c[s]=0;
	d = atoi(c);
	if(d<1 || d >31) return false;
	t_time = CTime(y,m,d,0,0,0,-1);	
	return true;
}


bool CRegularOpt::IsTime(LPCTSTR szTime ,CTime & t_time)
{
	int sl = strlen(szTime);
	int sp=0;
	int s;
	char c[5];
	int h,min,sec;
	while(sp<sl && (szTime[sp]==' ' ||  szTime[sp]== 9)) sp++;

	s=0;
	while(sp<sl ){
		if(szTime[sp]>='0' &&  szTime[sp]<= '9'){
			if(s<2) c[s] = szTime[sp];
			sp++;s++;
			continue;
		}
		//if(szTime[sp] == ':') 
			sp++; 
		break;
	}//check hour
	if(s > 2) return false;
	c[s]=0;
	h = atoi(c);
	if(h<0 || h >24) return false;
	s=0;
	while(sp<sl ){
		if(szTime[sp]>='0' &&  szTime[sp]<= '9'){
			if(s<2) c[s] = szTime[sp];
			sp++;s++;
			continue;
		}
		//if(szTime[sp] == ':') 
			sp++; 
		break;
	}//check minute
	if(s > 2) return false;
	c[s]=0;
	min = atoi(c);
	if(min<0 || min >60) return false;
	s=0;
	while(sp<sl ){
		if(szTime[sp]>='0' &&  szTime[sp]<= '9'){
			if(s<2) c[s] = szTime[sp];
			sp++;s++;
			continue;
		}
		break;
	}//check second
	if(s > 2) return false;
	c[s]=0;
	sec = atoi(c);
	if(sec<0 || sec >60) return false;
	t_time = CTime(2002,7,24,h,min,sec,-1);	
	return true;
}

int	 CRegularOpt::SplitFloatList(LPCTSTR szStr , CArray<float,float> & arfData, char splitChar)
{
	int nSL = strlen(szStr);
	if (nSL<1) return 0;
	int nRes = 0;

	CString sWord;
	int nPos = 0;
	if(splitChar == ' '){
		while(nPos < nSL){
			while((nPos < nSL) && ((szStr[nPos]==' ') || (szStr[nPos]==9) || (szStr[nPos]==13) || (szStr[nPos]==10) )) nPos++;
			sWord="";
			while((nPos < nSL) && (szStr[nPos]!=' ') && (szStr[nPos]!=9) && (szStr[nPos]!=13) && (szStr[nPos]!=10) ) {
				sWord += szStr[nPos];
				nPos ++;
			}
			if(sWord != ""){
				nRes ++;
				arfData.Add(float(atof(sWord)));
			}
		}
	}else{
		while(nPos < nSL){
			sWord="";
			while((nPos < nSL) && (szStr[nPos]!=splitChar)) {
				if((szStr[nPos]!=' ') && (szStr[nPos]!=9) && (szStr[nPos]!=13) && (szStr[nPos]!=10) )
					sWord += szStr[nPos];
				nPos ++;
			}
			if(sWord != ""){
				nRes ++;
				arfData.Add(float(atof(sWord)));
			}
			nPos++;
		}
	}
	return nRes;
}

int	 CRegularOpt::SplitString(LPCTSTR szStr , CStringList & ssRes,char splitChar)
{
	int nSL = strlen(szStr);
	if (nSL<1) return 0;
	int nRes = 0;

	CString sWord;
	int nPos = 0;
	if(splitChar == ' '){
		while(nPos < nSL){
			while((nPos < nSL) && ((szStr[nPos]==' ') || (szStr[nPos]==9))) nPos++;
			sWord="";
			while((nPos < nSL) && (szStr[nPos]!=' ') && (szStr[nPos]!=9)) {
				sWord += szStr[nPos];
				nPos ++;
			}
			if(sWord != ""){
				nRes ++;
				ssRes.AddTail(sWord);
			}
		}
	}else{
		while(nPos < nSL){
			sWord="";
			while((nPos < nSL) && (szStr[nPos]!=splitChar)) {
				sWord += szStr[nPos];
				nPos ++;
			}
			if(sWord != ""){
				nRes ++;
				ssRes.AddTail(sWord);
			}
			nPos++;
		}
	}
	return nRes;
}

CString	CRegularOpt::SplitNum(LPCTSTR szNum ,char splittertype)
{
	CString resNum(szNum),tempstr(szNum);
	tempstr.TrimLeft();
	int sl = tempstr.GetLength();
	if(sl<3) return resNum;
	int dp = tempstr.Find('.');
	if( dp == -1) dp = sl;
	int sp,step=0;
	switch (splittertype){
	case '3':step=3;	break;
	case '4':step=4;  break;
	}
	if(step !=0 ){
		if(dp>0){
			if(tempstr[0]=='-'){
				sp = (dp-1)%step;
				if(dp>1 && sp==0) sp=step;
				sp++;
				resNum = tempstr.Mid(0,sp);
			}else{
				sp = dp%step;
				if(sp==0) sp=step;
				resNum = tempstr.Mid(0,sp);
			}
			for(;sp<dp;sp+=step){
				resNum += ","+tempstr.Mid(sp,step);
			}
			sp++;
		}else{
			sp = 1;
		}
		if(sp<sl)
			resNum += '.';
		for(;sp<sl;sp+=3){
			resNum += tempstr.Mid(sp,step);
			if(sp+3 < sl) resNum += ',';
		}
	}
	return resNum;
}
//大寫 負 零壹貳叁肆伍陸柒捌玖
const	CString CNum[]={"零","壹","貳","叁","肆","伍","陸","柒","捌","玖"};
const	CString CNum2[]={"〇","一","二","三","四","五","六","七","八","九"};
const	CString CBit[]={"","拾","佰","仟"};
      //拾佰仟萬拾佰仟億拾佰仟萬
CString	CRegularOpt::Capitalization(LPCTSTR szNum,const bool isSimple)
{
	CString resstr("");
	CString tmpstr(szNum);
	tmpstr.TrimLeft();
	int sl = tmpstr.GetLength();
	int sp=0;
	if (isSimple){
		if(sl<1) return CNum2[0];
		for(;sp<sl;sp++)
			if(tmpstr[sp]>='0' && tmpstr[sp]<='9')
				resstr += CNum2[tmpstr[sp]-'0'];
			else
				resstr += tmpstr[sp];
		return resstr;
	}
	int dotpos = tmpstr.Find('.');
	if(dotpos != -1){
		while(sl>1 && tmpstr[sl-1] == '0') sl--;
		if(tmpstr[sl-1]=='.') sl--;
		if(sl != tmpstr.GetLength()){
			tmpstr = tmpstr.Mid(0,sl);
		}
	}else dotpos = sl;
	if(sl<1) return CString("零");
	if(tmpstr[0] == '-'){
		resstr="負";
		sp = 1;
	}
	CString integerNum = tmpstr.Mid(sp,dotpos-sp);
	CString decimalNum("");
	if(dotpos+1<sl) decimalNum = tmpstr.Mid(dotpos+1);
	sl = integerNum.GetLength();
	sp=0; while(sp<sl && integerNum[sp]=='0') sp++;
	if(sp > 0) integerNum = integerNum.Mid(sp);
	int inl = integerNum.GetLength();
	if(inl>0){
		int h = (inl-1) % 4 ;
		int j = (inl-1) / 4 + 1;
		sp=0;
		bool allzero = false;
		bool preallzero = false;
		for(;j>0;j--){
			int k=h;
			h = 3;
			bool preiszero = allzero;
			allzero = true;
			for(;k>=0;k--,sp++){
				if(integerNum[sp] == '0')
					preiszero = true;
				else{
					allzero = false;
					if(preiszero)
						resstr+="零";
					preiszero = false;
					resstr+=CNum[int(integerNum[sp])-48] + CBit[k];
				}
			}// end for k
			if(j!=0 && j % 2 == 0 ){
				if(!allzero) 
					resstr+="萬";
			}
			else
			{
				if(!allzero || !preallzero){ 
					int repyi = j/2;
					for(int i=0; i<repyi; i++)
						resstr+="億";
				}
			}
			preallzero = allzero;
		}//end for j
	}else
		resstr+="零";
	
	int dnl = decimalNum.GetLength();
	if(dnl>0){
		resstr+="點";
		for(int i=0; i<dnl; i++){
			resstr+=CNum[int(decimalNum[i])-48];
		}
	}
	return resstr;
}
CString	CRegularOpt::RightMoveDot(LPCTSTR szNum,int bits)
{
	CString str(szNum);
	int sp = str.Find('.');
	int sl = str.GetLength();
	if(sp == -1){
		if(sl == 0) return CString("");
		for(int i=0;i<bits; i++)
			str +='0';
		return str;
	}
	CString tempstr("");
	if(sp>0) tempstr = str.Mid(0,sp);
	str = str.Mid(sp+1);
	sl = str.GetLength();
	if(sl > bits){
		tempstr += str.Mid(0,bits);
		tempstr += '.';
		tempstr +=  str.Mid(bits);
	}else{
		tempstr +=  str;
		for(int i=0; i<bits-sl;i++)
			tempstr+='0';
	}
	return tempstr;
}

CString	CRegularOpt::CheckNumber(LPCTSTR szNum)
{
	int sl = strlen(szNum);
	char  * c = new char[sl+1];
	int nPos=0; bool bNeedPot = true;
	for(int i=0;i<sl;i++){
		if( szNum[i]>='0' && szNum[i]<='9' )
			c[nPos++] = szNum[i];
		if( bNeedPot && szNum[i]=='.'){
			c[nPos++] = '.';
			bNeedPot = false;
		}
	}
	c[nPos] = '\0';
	for(i=0;i<nPos;i++)
		if(c[i] != '0') break;
	
	CString sRes(c+i);
	if(c[i]=='.') 
		sRes ='0'+sRes;
	if(nPos>0 && c[nPos-1]=='.')
		sRes+='0';
	if(sRes.IsEmpty()) sRes="0";

	delete [] c;
	return sRes;
}

CString	CRegularOpt::PrecisionNum(LPCTSTR szNum,int precision)
{
	CString tmpstr(szNum);
	tmpstr.TrimLeft();
	int sl = tmpstr.GetLength();
	int dotpos = tmpstr.Find('.');
	int sp=0;
	int sign = 1;
	if(dotpos == -1) dotpos = sl;
	if(sl<1) return CString("0");
	if(tmpstr[0] == '-'){
		sp = 1;
		sign = -1;
	}
	CString integerNum = tmpstr.Mid(sp,dotpos-sp);
	CString decimalNum("");
	if(dotpos+1<sl) 
		decimalNum = tmpstr.Mid(dotpos+1);
	dotpos = integerNum.GetLength();
	sp=0; 
	while(sp<dotpos && integerNum[sp]=='0') 
		sp++;
	if(sp > 0) 
		integerNum = integerNum.Mid(sp);
	sl =  decimalNum.GetLength();
	int osl = sl;
	while(sl>0 && decimalNum[sl-1] == '0') sl--;
	if(sl == 0) decimalNum = "";
	else if(sl < osl) decimalNum =  decimalNum.Mid(0,sl);
	CString resstr;
	if(precision > -1){//if(precision != -1){
		if(sl <= precision){
			for(;sl<precision;sl++)
				decimalNum+='0';
		}else{
			sl = precision;
			int isIn = (decimalNum[sl]>='5')?1:0;
			if(sl>0)
				decimalNum = decimalNum.Mid(0,sl);
			else 
				decimalNum = "";
			sp = sl;
			while(isIn && sp>0) {
				if(decimalNum[sp-1] == '9') decimalNum.SetAt(sp-1,'0');
				else {
					 decimalNum.SetAt(sp-1,decimalNum[sp-1]  + 1);
					 isIn = 0;
				}
				sp--;
			}
			sp = integerNum.GetLength();
			while(isIn && sp>0){
				if(integerNum[sp-1] == '9') integerNum.SetAt(sp-1,'0');
				else {
					 integerNum.SetAt(sp-1,integerNum[sp-1]  + 1);
					 isIn = 0;
				}
				sp--;
			}
			if(isIn) integerNum = "1"+integerNum;
		}
	}
	if(integerNum.IsEmpty()) integerNum="0";
	if( sign == -1){
		if(sl > 0)
			resstr.Format("-%s.%s",integerNum,decimalNum);
		else
			resstr.Format("-%s",integerNum);
	}else{
		if(sl > 0)
			resstr.Format("%s.%s",integerNum,decimalNum);
		else
			resstr.Format("%s",integerNum);
	}
	if(resstr.IsEmpty()) return CString("0");
	return resstr;
}

CString CRegularOpt::GetAWord(LPCTSTR strSource,int & startPos ,char splitterChar)
{
	int sl = strlen(strSource);
	while((startPos < sl ) &&(strSource[startPos] == ' ' || strSource[startPos] == 9 || strSource[startPos] == 10|| strSource[startPos] == 13)) startPos++;
	int bp = startPos;
	while ( startPos < sl  && strSource[startPos] != splitterChar && strSource[startPos] != ' ' && strSource[startPos] != 9 ) startPos ++;
	int cl = startPos-bp+1 ;
	if(strSource[startPos] == splitterChar) startPos++;
	if(cl < 2) return  CString("");
	char * lpc = new char[cl];
	CopyMemory(lpc,strSource+bp,cl-1);
	lpc[cl-1]= 0;
	CString str(lpc);
	delete [] lpc;
	return str;	
}

CString CRegularOpt::GetARegularWord(LPCTSTR strSource,int & startPos,int sl,bool & bAcceptOpt)
{
	while((startPos < sl ) &&(strSource[startPos] == ' ' || strSource[startPos] == 9 || strSource[startPos] == 10|| strSource[startPos] == 13)) startPos++;
	int bp = startPos;
	if(startPos >= sl) return CString("");
//	int endex=1;
/*	if((strSource[startPos]>='0' && strSource[startPos]<='9') || strSource[startPos]== '.' 
		||( !bAcceptOpt && (strSource[startPos]== '-'||strSource[startPos]== '+' ) )){
		startPos++;
		while ( startPos < sl  && (
				( strSource[startPos]>='0' && strSource[startPos]<='9') ||
				( strSource[startPos]>='a' && strSource[startPos]<='z') ||
				( strSource[startPos]>='A' && strSource[startPos]<='Z') ||
				  strSource[startPos]=='.' )
				  ) startPos ++;
		bAcceptOpt = true;
	}else*/
	if( (strSource[startPos]>='0' && strSource[startPos]<='9') || 
		strSource[startPos]== '.' ||
		( !bAcceptOpt && (strSource[startPos]== '-' || strSource[startPos]== '+' ) ) ||
		( strSource[startPos]>='a' && strSource[startPos]<='z') ||
		( strSource[startPos]>='A' && strSource[startPos]<='Z') ||
		strSource[startPos]=='_' ||
		strSource[startPos]=='@'  ){
		startPos++;
		while ( startPos < sl  && (
				( strSource[startPos]>='0' && strSource[startPos]<='9') ||
				( strSource[startPos]>='a' && strSource[startPos]<='z') ||
				( strSource[startPos]>='A' && strSource[startPos]<='Z') ||
				  strSource[startPos]=='_' ||  strSource[startPos]=='.' ||
				  strSource[startPos]=='@' ) ) 
			startPos ++;
		bAcceptOpt = true;
	}else {
		bAcceptOpt = false;
		switch(strSource[startPos]){
		case '<':
			++startPos;
			if((startPos<sl) && ((strSource[startPos] == '=') || 
								 (strSource[startPos] == '>') ||
								 (strSource[startPos] == '<')   ) ) startPos ++;
			break;	
		case '>':
			++startPos;
			if((startPos<sl) && ((strSource[startPos] == '=') || 
								 (strSource[startPos] == '>')  ) ) startPos ++;
			break;
		case '=':
		case '!':
			++startPos;
			if((startPos<sl) && (strSource[startPos] == '=')) startPos ++;
			break;
		case '|':
			++startPos;
			if((startPos<sl) && (strSource[startPos] == '|')) startPos ++;
			break;
		case '&':
			++startPos;
			if((startPos<sl) && (strSource[startPos] == '&')) startPos ++;
			break;
		case '\"':
//			bp++;
			++startPos;
			while(startPos < sl && strSource[startPos] != '\"')startPos++;
			if(startPos < sl) startPos ++;
			bAcceptOpt = true;
			break;
		case '\'':
//			bp++;
			++startPos;
			while(startPos < sl && strSource[startPos] != '\'') startPos++;
			if(startPos < sl) startPos ++;
			bAcceptOpt = true;
			break;
		case ')':
			bAcceptOpt = true;
			startPos ++;
			break;
		default: //"+-*/"
			startPos ++;
			break;
		}
	}

	int cl = startPos-bp;
//	if(cl < 2) return  CString("");
	char * lpc = new char[cl+1];
	CopyMemory(lpc,strSource+bp,cl);
	lpc[cl]= 0;
	CString str(lpc);
	delete [] lpc;
	return str;	
//	std::auto_ptr
}

CString CRegularOpt::GetARegularWord(LPCTSTR strSource,int& startPos)
{
	bool b = false;
	return GetARegularWord(strSource, startPos,strlen(strSource),b);
}

CString  CRegularOpt::TrimString(LPCTSTR szWord)
{
	CString strWord(szWord);
	strWord.TrimLeft();
	strWord.TrimRight();
	int	sl = strWord.GetLength();
	if(sl >= 2 && (( strWord[0]=='\"' && strWord[sl-1]=='\"') || ( strWord[0]=='\'' && strWord[sl-1]=='\'')) ){
		if(sl>2)
			strWord = strWord.Mid(1,sl-2);
		else
			strWord = "";
	}
	return strWord;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品人人做人人爽人人添| 麻豆高清免费国产一区| 欧美日韩免费高清一区色橹橹 | 日日摸夜夜添夜夜添亚洲女人| 久久精品一区二区三区av| 欧美日韩你懂的| 日韩欧美一级二级| 欧美二区三区91| 欧美中文字幕久久 | 国产欧美日韩另类一区| 久久夜色精品国产欧美乱极品| 欧美性淫爽ww久久久久无| 91亚洲精品一区二区乱码| 高清不卡在线观看av| 国产精品一二一区| 成人午夜电影小说| 成人一二三区视频| 精品剧情v国产在线观看在线| 日韩精品一区在线| 五月婷婷综合在线| 午夜天堂影视香蕉久久| 国产激情一区二区三区四区 | 一级女性全黄久久生活片免费| 成人欧美一区二区三区黑人麻豆 | 欧美午夜不卡在线观看免费| 久久久久国产成人精品亚洲午夜| 欧美一区二区免费视频| 精品人伦一区二区色婷婷| 亚洲国产精品一区二区www在线| 亚洲精品乱码久久久久久日本蜜臀| 国产精品国模大尺度视频| 亚洲精品美国一| 91在线丨porny丨国产| 色欧美日韩亚洲| 欧美成人精品3d动漫h| 男女男精品视频| 色综合天天视频在线观看| 中文字幕日韩一区二区| 99视频在线观看一区三区| 欧美一区二区三区色| 亚洲一区二区三区三| 久热成人在线视频| 色综合久久中文综合久久97| 日韩一区中文字幕| 欧美日韩不卡视频| 美女mm1313爽爽久久久蜜臀| 欧美一级久久久| 亚洲成在人线免费| 99久久精品情趣| 五月综合激情网| 国产无人区一区二区三区| 一本大道久久a久久综合婷婷| 日韩av在线发布| 欧美一区二区视频在线观看2020| 福利91精品一区二区三区| 视频一区欧美精品| 国产精品免费看片| 欧美成人午夜电影| 91久久奴性调教| 亚洲成人av电影| 日本一区二区视频在线| 欧美一二三四在线| 欧美日韩综合不卡| 色综合久久中文综合久久牛| 国产精品综合二区| 亚洲v中文字幕| 一区二区三区四区在线免费观看 | 成人丝袜高跟foot| 久久精品国产精品亚洲精品| 樱桃国产成人精品视频| 18成人在线视频| 欧美国产欧美综合| 欧美日韩免费一区二区三区视频| av在线播放一区二区三区| 国产超碰在线一区| 国产一区二区三区免费看| 中文字幕视频一区二区三区久| 国产欧美日韩三级| 中文字幕视频一区| 亚洲精品福利视频网站| 亚洲美女一区二区三区| 久久免费电影网| 国产精品成人免费| 亚洲精品免费电影| 天堂久久一区二区三区| 日韩电影在线观看电影| 国产美女在线精品| 成人黄色片在线观看| 国产精品中文字幕一区二区三区| 国产尤物一区二区| 色系网站成人免费| 26uuu国产电影一区二区| 国产女人aaa级久久久级| 亚洲精品国产无套在线观| 美女精品一区二区| 91免费国产视频网站| 777色狠狠一区二区三区| 欧美色图天堂网| 国产日韩欧美在线一区| 亚洲综合丁香婷婷六月香| 国精品**一区二区三区在线蜜桃| 麻豆一区二区三| 99久久99久久久精品齐齐| 精品噜噜噜噜久久久久久久久试看| 国产精品传媒入口麻豆| 日本不卡一二三区黄网| gogo大胆日本视频一区| 日韩欧美色综合网站| 一区二区三区丝袜| 成人h动漫精品一区二区| 日韩欧美在线网站| 日本成人超碰在线观看| 91蜜桃婷婷狠狠久久综合9色| 欧美变态tickling挠脚心| 亚洲成人免费电影| 91视频免费看| 亚洲婷婷在线视频| 日韩av午夜在线观看| 欧美日韩一区二区三区四区五区 | 成人国产亚洲欧美成人综合网| 精品嫩草影院久久| 老司机一区二区| 欧美sm极限捆绑bd| 国内精品免费在线观看| 久久视频一区二区| 国产毛片一区二区| 欧美国产丝袜视频| 91婷婷韩国欧美一区二区| 亚洲乱码一区二区三区在线观看| 91视视频在线观看入口直接观看www| 亚洲女厕所小便bbb| 在线视频欧美区| 蜜臀99久久精品久久久久久软件| 日韩精品一区二区三区在线观看 | 久久伊人蜜桃av一区二区| 国产一区91精品张津瑜| 国产精品成人免费在线| 欧美日韩激情一区二区三区| 老鸭窝一区二区久久精品| 久久久久99精品国产片| caoporn国产精品| 亚洲国产精品麻豆| 国产亚洲精品aa午夜观看| 91免费观看在线| 国产一区二区在线免费观看| 一区二区三国产精华液| 日韩欧美国产电影| 91麻豆精品秘密| 国产乱淫av一区二区三区 | 日本精品视频一区二区三区| 秋霞电影网一区二区| 国产精品久久国产精麻豆99网站| 欧美色图片你懂的| 北条麻妃一区二区三区| 美女视频黄a大片欧美| 亚洲国产另类av| 亚洲乱码中文字幕综合| 亚洲国产高清不卡| 久久精品一区二区三区四区| 日韩女优电影在线观看| 欧美主播一区二区三区| 99re这里只有精品首页| 顶级嫩模精品视频在线看| 精品午夜一区二区三区在线观看| 国产精品少妇自拍| 亚洲国产精品av| 国产精品麻豆一区二区| 亚洲欧洲精品一区二区三区| 国产色爱av资源综合区| 久久美女艺术照精彩视频福利播放 | aaa国产一区| 99综合电影在线视频| 色综合久久综合网| 欧美日韩在线电影| 日韩区在线观看| 久久久久9999亚洲精品| **欧美大码日韩| 亚洲高清三级视频| 久热成人在线视频| 国产成人免费9x9x人网站视频| 成人激情综合网站| 欧美在线观看禁18| 欧美成人福利视频| 亚洲欧洲精品一区二区三区| 日韩电影在线一区二区三区| 国产高清精品网站| 欧美撒尿777hd撒尿| 久久精品夜色噜噜亚洲a∨| 亚洲欧美一区二区三区久本道91 | 国产日韩av一区| 一区二区免费看| 国产精品一区二区三区乱码| 日本精品一区二区三区四区的功能| 日韩欧美视频在线| 亚洲国产美女搞黄色| 国产a久久麻豆| 欧美一区二区在线播放| 一区二区三区在线视频播放| 国内精品第一页| 欧美一二三在线|