本文整理汇总了C++中CNativeW类的典型用法代码示例。如果您正苦于以下问题:C++ CNativeW类的具体用法?C++ CNativeW怎么用?C++ CNativeW使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了CNativeW类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: UnicodeToEUC
EConvertResult CEuc::UnicodeToEUC(const CNativeW& cSrc, CMemory* pDstMem)
{
// エラー状態
bool bError = false;
const wchar_t* pSrc = cSrc.GetStringPtr();
int nSrcLen = cSrc.GetStringLength();
// 必要なバッファサイズを調べてメモリを確保
char* pDst;
try{
pDst = new char[nSrcLen * 2];
}catch( ... ){
pDst = NULL;
}
if( pDst == NULL ){
return RESULT_FAILURE;
}
// 変換
int nDstLen = UniToEucjp( pSrc, nSrcLen, pDst, &bError );
// pDstMem を更新
pDstMem->SetRawDataHoldBuffer( pDst, nDstLen );
// 後始末
delete [] pDst;
if( bError == false ){
return RESULT_COMPLETE;
}else{
return RESULT_LOSESOME;
}
}
示例2: Command_GREP_REPLACE_DLG
/*! GREP置換ダイアログの表示
*/
void CViewCommander::Command_GREP_REPLACE_DLG( void )
{
CNativeW cmemCurText;
CDlgGrepReplace& cDlgGrepRep = GetEditWindow()->m_cDlgGrepReplace;
// 複数Grepウィンドウを使い分けている場合などに影響しないように、未設定のときだけHistoryを見る
bool bGetHistory = cDlgGrepRep.m_bSetText == false;
m_pCommanderView->GetCurrentTextForSearchDlg( cmemCurText, bGetHistory );
if( 0 < cmemCurText.GetStringLength() ){
cDlgGrepRep.m_strText = cmemCurText.GetStringPtr();
cDlgGrepRep.m_bSetText = true;
}
if( 0 < GetDllShareData().m_sSearchKeywords.m_aReplaceKeys.size() ){
if( cDlgGrepRep.m_nReplaceKeySequence < GetDllShareData().m_Common.m_sSearch.m_nReplaceKeySequence ){
cDlgGrepRep.m_strText2 = GetDllShareData().m_sSearchKeywords.m_aReplaceKeys[0];
}
}
int nRet = cDlgGrepRep.DoModal( G_AppInstance(), m_pCommanderView->GetHwnd(), GetDocument()->m_cDocFile.GetFilePath(), (LPARAM)m_pCommanderView );
if( !nRet ){
return;
}
HandleCommand(F_GREP_REPLACE, TRUE, 0, 0, 0, 0); // GREPコマンドの発行
}
示例3: Replace
void CNativeW::Replace( const wchar_t* pszFrom, int nFromLen, const wchar_t* pszTo, int nToLen )
{
CNativeW cmemWork;
int nBgnOld = 0;
int nBgn = 0;
while( nBgn <= GetStringLength() - nFromLen ){
if( 0 == wmemcmp( &GetStringPtr()[nBgn], pszFrom, nFromLen ) ){
if( nBgnOld == 0 && nFromLen <= nToLen ){
cmemWork.AllocStringBuffer( GetStringLength() );
}
if( 0 < nBgn - nBgnOld ){
cmemWork.AppendString( &GetStringPtr()[nBgnOld], nBgn - nBgnOld );
}
cmemWork.AppendString( pszTo, nToLen );
nBgn = nBgn + nFromLen;
nBgnOld = nBgn;
}else{
nBgn++;
}
}
if( nBgnOld != 0 ){
if( 0 < GetStringLength() - nBgnOld ){
cmemWork.AppendString( &GetStringPtr()[nBgnOld], GetStringLength() - nBgnOld );
}
SetNativeData( cmemWork );
}else{
if( this->GetStringPtr() == NULL ){
this->SetString(L"");
}
}
}
示例4: _ttempnam
/*! 外部ファイルを指定でのファイルを表示
*/
BOOL CEditView::MakeDiffTmpFile2( TCHAR* tmpName, const TCHAR* orgName, ECodeType code, ECodeType saveCode )
{
//一時
TCHAR* pszTmpName = _ttempnam( NULL, SAKURA_DIFF_TEMP_PREFIX );
if( NULL == pszTmpName ){
WarningMessage( NULL, LS(STR_DIFF_FAILED) );
return FALSE;
}
_tcscpy( tmpName, pszTmpName );
free( pszTmpName );
bool bBom = false;
const STypeConfigMini* typeMini;
CDocTypeManager().GetTypeConfigMini( CDocTypeManager().GetDocumentTypeOfPath( orgName ), &typeMini );
CFileLoad cfl( typeMini->m_encoding );
CTextOutputStream out(tmpName, saveCode, true, false);
if(!out){
WarningMessage( NULL, LS(STR_DIFF_FAILED_TEMP) );
return FALSE;
}
try{
bool bBigFile;
#ifdef _WIN64
bBigFile = true;
#else
bBigFile = false;
#endif
cfl.FileOpen( orgName, bBigFile, code, GetDllShareData().m_Common.m_sFile.GetAutoMIMEdecode(), &bBom );
CNativeW cLine;
CEol cEol;
while( RESULT_FAILURE != cfl.ReadLine( &cLine, &cEol ) ) {
const wchar_t* pLineData;
CLogicInt nLineLen;
pLineData= cLine.GetStringPtr(&nLineLen);
if( 0 == nLineLen || NULL == pLineData ) break;
if( bBom ){
CNativeW cLine2(L"\ufeff");
cLine2.AppendString(pLineData, nLineLen);
out.WriteString(cLine2.GetStringPtr(), cLine2.GetStringLength());
bBom = false;
}else{
out.WriteString(pLineData,nLineLen);
}
}
if( bBom ){
out.WriteString(L"\ufeff", 1);
}
}
catch(...){
out.Close();
_tunlink( tmpName ); //関数の実行に失敗したとき、一時ファイルの削除は関数内で行う。
WarningMessage( NULL, LS(STR_DIFF_FAILED_TEMP) );
return FALSE;
}
return TRUE;
}
示例5: ReadProfileRes
/*! Profileをリソースから読み出す
@param pName [in] リソース名
@param pType [in] リソースタイプ
@retval true 成功
@retval false 失敗
@date 2010/5/19 MainMenu用に作成
1行300文字までに制限
*/
bool CProfile::ReadProfileRes( const TCHAR* pName, const TCHAR* pType, std::vector<std::wstring>* pData )
{
static const BYTE UTF8_BOM[]={0xEF,0xBB,0xBF};
HRSRC hRsrc;
HGLOBAL hGlobal;
size_t nSize;
char* psMMres;
char* p;
char sLine[300+1];
char* pn;
size_t lnsz;
wstring line;
CMemory cmLine;
CNativeW cmLineW;
m_strProfileName = _T("-Res-");
if (( hRsrc = ::FindResource( 0, pName, pType )) != NULL
&& ( hGlobal = ::LoadResource( 0, hRsrc )) != NULL
&& ( psMMres = (char *)::LockResource(hGlobal)) != NULL
&& ( nSize = (size_t)::SizeofResource( 0, hRsrc )) != 0) {
p = psMMres;
if (nSize >= sizeof(UTF8_BOM) && memcmp( p, UTF8_BOM, sizeof(UTF8_BOM) )==0) {
// Skip BOM
p += sizeof(UTF8_BOM);
}
for (; p < psMMres + nSize ; p = pn) {
// 1行切り取り(長すぎた場合切捨て)
pn = strpbrk(p, "\n");
if (pn == NULL) {
// 最終行
pn = psMMres + nSize;
}
else {
pn++;
}
lnsz = (pn-p)<=300 ? (pn-p) : 300;
memcpy(sLine, p, lnsz);
sLine[lnsz] = '\0';
if (sLine[lnsz-1] == '\n') sLine[--lnsz] = '\0';
if (sLine[lnsz-1] == '\r') sLine[--lnsz] = '\0';
// UTF-8 -> UNICODE
cmLine.SetRawDataHoldBuffer( sLine, lnsz );
CUtf8::UTF8ToUnicode( cmLine, &cmLineW );
line = cmLineW.GetStringPtr();
if( pData ){
pData->push_back(line);
}else{
//解析
ReadOneline(line);
}
}
}
return true;
}
示例6: ErrorBeep
/* 外部ヘルプ1
@date 2012.09.26 Moca HTMLHELP対応
*/
void CViewCommander::Command_EXTHELP1( void )
{
retry:;
if( CHelpManager().ExtWinHelpIsSet( &(GetDocument()->m_cDocType.GetDocumentAttribute()) ) == false){
// if( 0 == wcslen( GetDllShareData().m_Common.m_szExtHelp1 ) ){
ErrorBeep();
//From Here Sept. 15, 2000 JEPRO
// [Esc]キーと[x]ボタンでも中止できるように変更
if( IDYES == ::MYMESSAGEBOX( NULL, MB_YESNOCANCEL | MB_ICONEXCLAMATION | MB_APPLMODAL | MB_TOPMOST, GSTR_APPNAME,
//To Here Sept. 15, 2000
LS(STR_ERR_CEDITVIEW_CMD01)
) ){
/* 共通設定 プロパティシート */
if( !CEditApp::getInstance()->OpenPropertySheet( ID_PROPCOM_PAGENUM_HELPER ) ){
return;
}
goto retry;
}
// Jun. 15, 2000 genta
else{
return;
}
}
CNativeW cmemCurText;
const TCHAR* helpfile = CHelpManager().GetExtWinHelp( &(GetDocument()->m_cDocType.GetDocumentAttribute()) );
/* 現在カーソル位置単語または選択範囲より検索等のキーを取得 */
m_pCommanderView->GetCurrentTextForSearch( cmemCurText, false );
TCHAR path[_MAX_PATH];
if( _IS_REL_PATH( helpfile ) ){
// 2003.06.23 Moca 相対パスは実行ファイルからのパス
// 2007.05.21 ryoji 相対パスは設定ファイルからのパスを優先
GetInidirOrExedir( path, helpfile );
}else{
auto_strcpy( path, helpfile );
}
// 2012.09.26 Moca HTMLHELP対応
TCHAR szExt[_MAX_EXT];
_tsplitpath( path, NULL, NULL, NULL, szExt );
if( 0 == _tcsicmp(szExt, _T(".chi")) || 0 == _tcsicmp(szExt, _T(".chm")) || 0 == _tcsicmp(szExt, _T(".col")) ){
std::wstring pathw = to_wchar(path);
Command_EXTHTMLHELP( pathw.c_str(), cmemCurText.GetStringPtr() );
}else{
::WinHelp( m_pCommanderView->m_hwndParent, path, HELP_KEY, (ULONG_PTR)cmemCurText.GetStringPtr() );
}
return;
}
示例7: ErrorBeep
/* uudecodeして保存 */
void CViewCommander::Command_UUDECODE( void )
{
/* テキストが選択されているか */
if( !m_pCommanderView->GetSelectionInfo().IsTextSelected() ){
ErrorBeep();
return;
}
// 選択範囲のデータを取得 -> cmemBuf
// 正常時はTRUE,範囲未選択の場合はFALSEを返す
CNativeW ctextBuf;
if( !m_pCommanderView->GetSelectedDataSimple(ctextBuf) ){
ErrorBeep();
return;
}
// uudecode(デコード) ctextBuf -> cmemBin, szPath
CMemory cmemBin;
TCHAR szPath[_MAX_PATH]=_T("");
CDecode_UuDecode decoder;
if( !decoder.CallDecode(ctextBuf, &cmemBin) ){
return;
}
decoder.CopyFilename( szPath );
ctextBuf.Clear();
/* 保存ダイアログ モーダルダイアログの表示 */
if( !GetDocument()->m_cDocFileOperation.SaveFileDialog( szPath ) ){
return;
}
//データ
int nDataLen;
const void* pData = cmemBin.GetRawPtr(&nDataLen);
//カキコ
CBinaryOutputStream out(szPath);
if( !out )goto err;
if( nDataLen != out.Write(pData,nDataLen) )goto err;
//完了
return;
err:
ErrorBeep();
ErrorMessage( m_pCommanderView->GetHwnd(), LS(STR_ERR_CEDITVIEW_CMD16), szPath );
}
示例8: IsEqual
/* 等しい内容か */
bool CNativeW::IsEqual( const CNativeW& cmem1, const CNativeW& cmem2 )
{
if(&cmem1==&cmem2)return true;
const wchar_t* psz1;
const wchar_t* psz2;
int nLen1;
int nLen2;
psz1 = cmem1.GetStringPtr( &nLen1 );
psz2 = cmem2.GetStringPtr( &nLen2 );
if( nLen1 == nLen2 ){
if( 0 == wmemcmp( psz1, psz2, nLen1 ) ){
return true;
}
}
return false;
}
示例9: UnicodeToHex
// 文字コード表示用 UNICODE → Hex 変換 2008/6/9 Uchi
EConvertResult CEuc::UnicodeToHex(const wchar_t* cSrc, const int iSLen, TCHAR* pDst, const CommonSetting_Statusbar* psStatusbar)
{
CNativeW cCharBuffer;
EConvertResult res;
int i;
TCHAR* pd;
unsigned char* ps;
bool bbinary=false;
// 2008/6/21 Uchi
if (psStatusbar->m_bDispUniInEuc) {
// Unicodeで表示
return CCodeBase::UnicodeToHex(cSrc, iSLen, pDst, psStatusbar);
}
// 1文字データバッファ
cCharBuffer.SetString(cSrc, 1);
if( IsBinaryOnSurrogate(cSrc[0]) ){
bbinary = true;
}
// EUC-JP 変換
res = UnicodeToEUC(cCharBuffer, cCharBuffer._GetMemory());
if (res != RESULT_COMPLETE) {
return res;
}
// Hex変換
ps = reinterpret_cast<unsigned char*>( cCharBuffer._GetMemory()->GetRawPtr() );
pd = pDst;
if( bbinary == false ){
for (i = cCharBuffer._GetMemory()->GetRawLength(); i >0; i--, ps ++, pd += 2) {
auto_sprintf( pd, _T("%02X"), *ps);
}
}else{
auto_sprintf( pd, _T("?%02X"), *ps );
}
return RESULT_COMPLETE;
}
示例10: UnicodeToHex
// 文字コード表示用 UNICODE → Hex 変換 2008/6/21 Uchi
EConvertResult CUtf8::_UnicodeToHex(const wchar_t* cSrc, const int iSLen, TCHAR* pDst, const CommonSetting_Statusbar* psStatusbar, const bool bCESUMode)
{
CNativeW cBuff;
EConvertResult res;
int i;
TCHAR* pd;
unsigned char* ps;
bool bbinary=false;
if (psStatusbar->m_bDispUtf8Codepoint) {
// Unicodeで表示
return CCodeBase::UnicodeToHex(cSrc, iSLen, pDst, psStatusbar);
}
cBuff.AllocStringBuffer(4);
// 1文字データバッファ
if (IsUTF16High(cSrc[0]) && iSLen >= 2 && IsUTF16Low(cSrc[1])) {
cBuff._GetMemory()->SetRawDataHoldBuffer(cSrc, 4);
}
else {
cBuff._GetMemory()->SetRawDataHoldBuffer(cSrc, 2);
if( IsBinaryOnSurrogate(cSrc[0]) ){
bbinary = true;
}
}
// UTF-8/CESU-8 変換
if (bCESUMode != true) {
res = UnicodeToUTF8(cBuff, cBuff._GetMemory());
}
else {
res = UnicodeToCESU8(cBuff, cBuff._GetMemory());
}
if (res != RESULT_COMPLETE) {
return res;
}
// Hex変換
ps = reinterpret_cast<unsigned char*>( cBuff._GetMemory()->GetRawPtr() );
pd = pDst;
if( bbinary == false ){
for (i = cBuff._GetMemory()->GetRawLength(); i >0; i--, ps ++, pd += 2) {
auto_sprintf( pd, _T("%02X"), *ps);
}
}else{
auto_sprintf( pd, _T("?%02X"), *ps );
}
return RESULT_COMPLETE;
}
示例11: Command_GREP_DIALOG
/*! GREPダイアログの表示
@date 2005.01.10 genta CEditView_Commandより移動
@author Yazaki
*/
void CViewCommander::Command_GREP_DIALOG( void )
{
CNativeW cmemCurText;
// 2014.07.01 複数Grepウィンドウを使い分けている場合などに影響しないように、未設定のときだけHistoryを見る
bool bGetHistory = GetEditWindow()->m_cDlgGrep.m_bSetText == false;
/* 現在カーソル位置単語または選択範囲より検索等のキーを取得 */
bool bSet = m_pCommanderView->GetCurrentTextForSearchDlg( cmemCurText, bGetHistory ); // 2006.08.23 ryoji ダイアログ専用関数に変更
if( bSet ){
GetEditWindow()->m_cDlgGrep.m_strText = cmemCurText.GetStringPtr();
GetEditWindow()->m_cDlgGrep.m_bSetText = true;
}
/* Grepダイアログの表示 */
int nRet = GetEditWindow()->m_cDlgGrep.DoModal( G_AppInstance(), m_pCommanderView->GetHwnd(), GetDocument()->m_cDocFile.GetFilePath() );
// MYTRACE( _T("nRet=%d\n"), nRet );
if( !nRet ){
return;
}
HandleCommand(F_GREP, true, 0, 0, 0, 0); // GREPコマンドの発行
}
示例12: in
/*! キーボードマクロの読み込み(ファイルから)
エラーメッセージは出しません。呼び出し側でよきにはからってください。
*/
BOOL CPPAMacroMgr::LoadKeyMacro( HINSTANCE hInstance, const TCHAR* pszPath )
{
CTextInputStream in( pszPath );
if(!in) {
m_nReady = false;
return FALSE;
}
CNativeW cmemWork;
// バッファ(cmemWork)にファイル内容を読み込み、m_cPPAに渡す。
while( in ) {
wstring szLine = in.ReadLineW();
szLine += L"\n";
cmemWork.AppendString(szLine.c_str());
}
in.Close();
m_cBuffer.SetNativeData( cmemWork ); // m_cBufferにコピー
m_nReady = true;
return TRUE;
}
示例13: GetCaret
/*!
カーソル行をクリップボードにコピーする
@date 2007.10.08 ryoji 新規(Command_COPY()から処理抜き出し)
*/
void CEditView::CopyCurLine(
bool bAddCRLFWhenCopy, //!< [in] 折り返し位置に改行コードを挿入するか?
EEolType neweol, //!< [in] コピーするときのEOL。
bool bEnableLineModePaste //!< [in] ラインモード貼り付けを可能にする
)
{
if( GetSelectionInfo().IsTextSelected() ){
return;
}
const CLayout* pcLayout = m_pcEditDoc->m_cLayoutMgr.SearchLineByLayoutY( GetCaret().GetCaretLayoutPos().y );
if( NULL == pcLayout ){
return;
}
/* クリップボードに入れるべきテキストデータを、cmemBufに格納する */
CNativeW cmemBuf;
cmemBuf.SetString( pcLayout->GetPtr(), pcLayout->GetLengthWithoutEOL() );
if( pcLayout->GetLayoutEol().GetLen() != 0 ){
cmemBuf.AppendString(
( neweol == EOL_UNKNOWN ) ?
pcLayout->GetLayoutEol().GetValue2() : CEol(neweol).GetValue2()
);
}else if( bAddCRLFWhenCopy ){ // 2007.10.08 ryoji bAddCRLFWhenCopy対応処理追加
cmemBuf.AppendString(
( neweol == EOL_UNKNOWN ) ?
WCODE::CRLF : CEol(neweol).GetValue2()
);
}
/* クリップボードにデータcmemBufの内容を設定 */
BOOL bSetResult = MySetClipboardData(
cmemBuf.GetStringPtr(),
cmemBuf.GetStringLength(),
false,
bEnableLineModePaste
);
if( !bSetResult ){
ErrorBeep();
}
}
示例14: pcCodeBase
/*! バッファ内容をファイルに書き出す (テスト用)
@note Windows用にコーディングしてある
@date 2003.07.26 ryoji BOM引数追加
*/
EConvertResult CWriteManager::WriteFile_From_CDocLineMgr(
const CDocLineMgr& pcDocLineMgr, //!< [in]
const SSaveInfo& sSaveInfo //!< [in]
)
{
EConvertResult nRetVal = RESULT_COMPLETE;
std::auto_ptr<CCodeBase> pcCodeBase( CCodeFactory::CreateCodeBase(sSaveInfo.eCharCode,0) );
{
// 変換テスト
CNativeW buffer = L"abcde";
CMemory tmp;
EConvertResult e = pcCodeBase->UnicodeToCode( buffer, &tmp );
if(e==RESULT_FAILURE){
nRetVal=RESULT_FAILURE;
ErrorMessage(
CEditWnd::getInstance()->GetHwnd(),
LS(STR_FILESAVE_CONVERT_ERROR),
sSaveInfo.cFilePath.c_str()
);
return nRetVal;
}
}
try
{
//ファイルオープン
CBinaryOutputStream out(sSaveInfo.cFilePath,true);
//各行出力
int nLineNumber = 0;
const CDocLine* pcDocLine = pcDocLineMgr.GetDocLineTop();
// 1行目
{
++nLineNumber;
CMemory cmemOutputBuffer;
{
CNativeW cstrSrc;
CMemory cstrBomCheck;
pcCodeBase->GetBom( &cstrBomCheck );
if( sSaveInfo.bBomExist && 0 < cstrBomCheck.GetRawLength() ){
// 1行目にはBOMを付加する。エンコーダでbomがある場合のみ付加する。
CUnicode().GetBom( cstrSrc._GetMemory() );
}
if( pcDocLine ){
cstrSrc.AppendNativeData( pcDocLine->_GetDocLineDataWithEOL() );
}
EConvertResult e = pcCodeBase->UnicodeToCode( cstrSrc, &cmemOutputBuffer );
if(e==RESULT_LOSESOME){
nRetVal=RESULT_LOSESOME;
}
if(e==RESULT_FAILURE){
nRetVal=RESULT_FAILURE;
ErrorMessage(
CEditWnd::getInstance()->GetHwnd(),
LS(STR_FILESAVE_CONVERT_ERROR),
sSaveInfo.cFilePath.c_str()
);
throw CError_FileWrite();
}
}
out.Write(cmemOutputBuffer.GetRawPtr(), cmemOutputBuffer.GetRawLength());
if( pcDocLine ){
pcDocLine = pcDocLine->GetNextLine();
}
}
CMemory cmemOutputBuffer;
while( pcDocLine ){
++nLineNumber;
//経過通知
if(pcDocLineMgr.GetLineCount()>0 && nLineNumber%1024==0){
NotifyProgress(nLineNumber * 100 / pcDocLineMgr.GetLineCount());
// 処理中のユーザー操作を可能にする
if( !::BlockingHook( NULL ) ){
throw CAppExitException(); //中断検出
}
}
//1行出力 -> cmemOutputBuffer
{
// 書き込み時のコード変換 cstrSrc -> cmemOutputBuffer
EConvertResult e = pcCodeBase->UnicodeToCode(
pcDocLine->_GetDocLineDataWithEOL(),
&cmemOutputBuffer
);
if(e==RESULT_LOSESOME){
if(nRetVal==RESULT_COMPLETE)nRetVal=RESULT_LOSESOME;
}
if(e==RESULT_FAILURE){
nRetVal=RESULT_FAILURE;
ErrorMessage(
CEditWnd::getInstance()->GetHwnd(),
LS(STR_FILESAVE_CONVERT_ERROR),
//.........这里部分代码省略.........
示例15: CLogicInt
/* 指定範囲のデータを置換(削除 & データを挿入)
Fromを含む位置からToの直前を含むデータを削除する
Fromの位置へテキストを挿入する
*/
void CSearchAgent::ReplaceData( DocLineReplaceArg* pArg )
{
// MY_RUNNINGTIMER( cRunningTimer, "CDocLineMgr::ReplaceData()" );
/* 挿入によって増えた行の数 */
pArg->nInsLineNum = CLogicInt(0);
/* 削除した行の総数 */
pArg->nDeletedLineNum = CLogicInt(0);
/* 削除されたデータ */
if( pArg->pcmemDeleted ){
pArg->pcmemDeleted->clear();
}
CDocLine* pCDocLine;
CDocLine* pCDocLinePrev;
CDocLine* pCDocLineNext;
int nWorkPos;
int nWorkLen;
const wchar_t* pLine;
int nLineLen;
int i;
CLogicInt nAllLinesOld;
int nProgress;
CDocLine::MarkType markNext;
// May 15, 2000
HWND hwndCancel = NULL; // 初期化
HWND hwndProgress = NULL; // 初期化
pArg->ptNewPos = pArg->sDelRange.GetFrom();
/* 大量のデータを操作するとき */
CDlgCancel* pCDlgCancel = NULL;
class CDLgCandelCloser{
CDlgCancel*& m_pDlg;
public:
CDLgCandelCloser(CDlgCancel*& pDlg): m_pDlg(pDlg){}
~CDLgCandelCloser(){
if( NULL != m_pDlg ){
// 進捗ダイアログを表示しない場合と同じ動きになるようにダイアログは遅延破棄する
// ここで pCDlgCancel を delete すると delete から戻るまでの間に
// ダイアログ破棄 -> 編集画面へフォーカス移動 -> キャレット位置調整
// まで一気に動くので無効なレイアウト情報参照で異常終了することがある
m_pDlg->DeleteAsync(); // 自動破棄を遅延実行する // 2008.05.28 ryoji
}
}
};
CDLgCandelCloser closer(pCDlgCancel);
const CLogicInt nDelLines = pArg->sDelRange.GetTo().y - pArg->sDelRange.GetFrom().y;
const CLogicInt nEditLines = std::max<CLogicInt>(CLogicInt(1), nDelLines + CLogicInt(pArg->pInsData ? pArg->pInsData->size(): 0));
if( 3000 < nEditLines ){
/* 進捗ダイアログの表示 */
pCDlgCancel = new CDlgCancel;
if( NULL != ( hwndCancel = pCDlgCancel->DoModeless( ::GetModuleHandle( NULL ), NULL, IDD_OPERATIONRUNNING ) ) ){
hwndProgress = ::GetDlgItem( hwndCancel, IDC_PROGRESS );
Progress_SetRange( hwndProgress, 0, 101 );
Progress_SetPos( hwndProgress, 0 );
}
}
int nProgressOld = 0;
// バッファを確保
if( pArg->pcmemDeleted ){
pArg->pcmemDeleted->reserve( pArg->sDelRange.GetTo().y + CLogicInt(1) - pArg->sDelRange.GetFrom().y );
}
// 2012.01.10 行内の削除&挿入のときの操作を1つにする
bool bChangeOneLine = false; // 行内の挿入
bool bInsOneLine = false;
bool bLastEOLReplace = false; // 「最後改行」を「最後改行」で置換
if( pArg->pInsData && 0 < pArg->pInsData->size() ){
const CNativeW& cmemLine = pArg->pInsData->back().cmemLine;
int nLen = cmemLine.GetStringLength();
const wchar_t* pInsLine = cmemLine.GetStringPtr();
if( 0 < nLen && WCODE::IsLineDelimiter(pInsLine[nLen - 1], GetDllShareData().m_Common.m_sEdit.m_bEnableExtEol) ){
// 行挿入
bLastEOLReplace = true; // 仮。後で修正
}else{
if( 1 == pArg->pInsData->size() ){
bChangeOneLine = true; // 「abc\ndef」=>「123」のような置換もtrueなのに注意
}
}
}
const wchar_t* pInsData = L"";
int nInsLen = 0;
int nSetSeq = 0;
if( bChangeOneLine ){
nInsLen = pArg->pInsData->back().cmemLine.GetStringLength();
pInsData = pArg->pInsData->back().cmemLine.GetStringPtr();
nSetSeq = pArg->pInsData->back().nSeq;
}
/* 現在行の情報を得る */
pCDocLine = m_pcDocLineMgr->GetLine( pArg->sDelRange.GetTo().GetY2() );
i = pArg->sDelRange.GetTo().y;
if( 0 < pArg->sDelRange.GetTo().y && NULL == pCDocLine ){
pCDocLine = m_pcDocLineMgr->GetLine( pArg->sDelRange.GetTo().GetY2() - CLogicInt(1) );
//.........这里部分代码省略.........