本文整理汇总了C++中StrApp::Length方法的典型用法代码示例。如果您正苦于以下问题:C++ StrApp::Length方法的具体用法?C++ StrApp::Length怎么用?C++ StrApp::Length使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类StrApp
的用法示例。
在下文中一共展示了StrApp::Length方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: SetTestDir
/*------------------------------------------------------------------------------------------
Set the root directory for where things are located, which should be the directory
where this file is located.
------------------------------------------------------------------------------------------*/
void SetTestDir()
{
if (g_strTestDir.Length())
return; // Set this only once!
// Get the path to the template files.
HKEY hk;
if (::RegOpenKeyEx(HKEY_LOCAL_MACHINE, _T("Software\\SIL\\FieldWorks"), 0,
KEY_QUERY_VALUE, &hk) == ERROR_SUCCESS)
{
achar rgch[MAX_PATH];
DWORD cb = isizeof(rgch);
DWORD dwT;
if (::RegQueryValueEx(hk, _T("RootCodeDir"), NULL, &dwT, (BYTE *)rgch, &cb)
== ERROR_SUCCESS)
{
Assert(dwT == REG_SZ);
StrApp str(rgch);
int ich = str.FindStrCI(_T("\\distfiles"));
if (ich >= 0)
str.Replace(ich, str.Length(), _T(""));
ich = str.FindCh('\\', str.Length() - 1);
if (ich >= 0)
str.Replace(ich, str.Length(), _T(""));
str.Append(_T("\\Src\\Cellar\\Test\\"));
g_strTestDir.Assign(str);
}
RegCloseKey(hk);
}
if (!g_strTestDir.Length())
g_strTestDir.Assign("C:\\FW\\Src\\Cellar\\Test\\");
}
示例2: AppendToStaWithSep
DEFINE_THIS_FILE
#define gle (GetLastError())
#define lenof(a) (sizeof(a) / sizeof((a)[0]))
#define MAXNAMELEN 1024 // max name length for found symbols
#define IMGSYMLEN ( sizeof IMAGEHLP_SYMBOL )
#define TTBUFLEN 65536 // for a temp buffer
/// Add the given string to Sta. If Sta is not empty, add a semi-colon first
void AppendToStaWithSep(StrApp sta, const achar * pch)
{
if (sta.Length())
sta.Append(";");
sta.Append(pch);
}
示例3: SetDialogValues
//.........这里部分代码省略.........
AppendMeasurement(strDesc, nLeadIndent, m_nMsrSys, kstidLeadingFmt);
if (nFirstIndent != knNinch)
{
if (nFirstIndent < 0)
AppendMeasurement(strDesc, -nFirstIndent, m_nMsrSys, kstidHangingFmt);
else
AppendMeasurement(strDesc, nFirstIndent, m_nMsrSys, kstidFirstLineFmt);
}
AppendMeasurement(strDesc, nTrailIndent, m_nMsrSys, kstidTrailingFmt);
}
// line spacing
CheckHr(pttp->GetIntPropValues(ktptLineHeight, &var, &val));
StrApp strSpacing;
StrApp strFmt;
if (var == ktpvMilliPoint)
{
if (val < 0)
strFmt.Load(kstidFpLsExactFmt);
else
strFmt.Load(kstidFpLsAtLeastFmt);
StrAppBuf strb;
AfUtil::MakeMsrStr (val , knpt, &strb);
strSpacing.Format(strFmt.Chars(), strb.Chars());
}
else if (var == ktpvRelative)
{
if (val >= kdenTextPropRel * 2)
strSpacing.Load(kstidFpLsDouble);
else if (val >= kdenTextPropRel * 3 / 2)
strSpacing.Load(kstidFpLs15Lines);
else
strSpacing.Load(kstidFpLsSingle);
}
if (strSpacing.Length() != 0)
{
strFmt.Load(kstidLineSpacingFmt);
strT.Format(strFmt.Chars(), strSpacing.Chars());
AppendDescPart(strDesc, strT, fFirstPart);
}
int mpBefore = ReadValOrNinch(pttp, ktptSpaceBefore);
int mpAfter = ReadValOrNinch(pttp, ktptSpaceAfter);
if (mpBefore != knNinch || mpAfter != knNinch)
{
AppendDescPart(strDesc, kstidSpace, fFirstPart);
AppendMeasurement(strDesc, mpBefore, knpt, kstidBeforeFmt);
AppendMeasurement(strDesc, mpAfter, knpt, kstidAfterFmt);
}
int bulnum = ReadValOrNinch(pttp, ktptBulNumScheme);
AddIf(strDesc, bulnum >= kvbnBulletBase && bulnum < kvbnBulletMax,
kstidBulleted, fFirstPart);
AddIf(strDesc, bulnum >= kvbnNumberBase && bulnum < kvbnNumberMax,
kstidNumbered, fFirstPart);
int mpBTop = ReadValOrNinch(pttp, ktptBorderTop);
int mpBB = ReadValOrNinch(pttp, ktptBorderBottom);
int mpBL = ReadValOrNinch(pttp, ktptBorderLeading);
int mpBTr = ReadValOrNinch(pttp, ktptBorderTrailing);
if (mpBTop != knNinch || mpBB != knNinch || mpBL != knNinch || mpBTr != knNinch)
{
AppendDescPart(strDesc, kstidBorderColon, fFirstPart);
int clrBorder = ReadValOrNinch(pttp, ktptBorderColor);
bool fFirstBorder = true;
if (clrBorder != knNinch)
示例4: GetDialogValues
/*----------------------------------------------------------------------------------------------
Get the final values for the dialog controls, after the dialog has been closed.
----------------------------------------------------------------------------------------------*/
void FmtGenDlg::GetDialogValues(StyleInfo & styi, bool & fBasedOnChanged)
{
StrUni stuName = GetName();
StrApp strName = stuName;
achar rgcha[1024];
Vector<achar> vch;
achar * pszT;
memcpy(rgcha, strName.Chars(), strName.Length() * isizeof(achar));
if (stuName != styi.m_stuName)
{
StrApp strOldName(styi.m_stuName);
StrApp strNewName(stuName);
if (!m_pafsd->SetName(styi, stuName))
{
// Error: restore the old name.
::SetDlgItemText(m_hwnd, kctidFgEdName, strOldName.Chars());
}
// Otherwise update the comboboxes for BasedOn and Next.
// This allows the later code which reads from them to work correctly,
// so it is worth doing even here in a read routine.
// Also update the edit box to handle stripping of leading/trailing blanks.
else
{
::SetDlgItemText(m_hwnd, kctidFgEdName, strNewName.Chars());
UpdateComboboxes(strOldName, strNewName);
}
}
int iitem = ::SendMessage(m_hwndBasedOn, CB_GETCURSEL, 0,0);
// <0 means the item is blank (e.g., Normal is not based on anything).
// But if we pass -1 to CB_GETLBTEXT, we get the text of the first item.
// This can change Normal to be based on Normal, with bad consequences.
//
if (iitem < 0)
{
pszT = _T("");
}
else
{
int cch = ::SendMessage(m_hwndBasedOn, CB_GETLBTEXTLEN, (WPARAM)iitem, 0);
if (cch < 1024)
{
pszT = rgcha;
}
else
{
vch.Resize(cch + 1);
pszT = vch.Begin();
}
cch = ::SendMessage(m_hwndBasedOn, CB_GETLBTEXT, iitem, (long)pszT);
if (cch < 0)
pszT = _T("");
}
stuName = pszT;
HVO hvoBasedOn = m_pafsd->GetHvoOfStyleNamed(stuName);
if (styi.m_hvoBasedOn != hvoBasedOn)
{
m_pafsd->SetBasedOn(styi, hvoBasedOn); // Sets m_fDirty.
// Note that this is initialised to false in AfStylesDlg::UpdateTabCtrl.
fBasedOnChanged = true;
}
iitem = ::SendMessage(m_hwndNext, CB_GETCURSEL, 0,0);
if (iitem < 0)
{
pszT = _T("");
}
else
{
int cch = ::SendMessage(m_hwndNext, CB_GETLBTEXTLEN, (WPARAM)iitem, 0);
if (cch < 1024)
{
pszT = rgcha;
}
else
{
vch.Resize(cch + 1);
pszT = vch.Begin();
}
cch = ::SendMessage(m_hwndNext, CB_GETLBTEXT, iitem, (long)pszT);
if (cch < 0)
pszT = _T("");
}
stuName = pszT;
HVO hvoNext = m_pafsd->GetHvoOfStyleNamed(stuName);
if ((styi.m_hvoNext != hvoNext) && (styi.m_st != kstCharacter))
{
m_pafsd->SetNext(styi, hvoNext); // Sets m_fDirty.
}
} //:> FmtGenDlg::GetDialogValues.
示例5: ShowStackCore
void StackDumper::ShowStackCore( HANDLE hThread, CONTEXT& c )
{
// This makes this code custom for 32-bit windows. There is a technique to find out what
// machine type we are running on, but this should do us for a good while.
DWORD imageType = IMAGE_FILE_MACHINE_I386;
HANDLE hProcess = GetCurrentProcess();
int frameNum; // counts walked frames
DWORD offsetFromSymbol; // tells us how far from the symbol we were
DWORD symOptions; // symbol handler settings
IMAGEHLP_SYMBOL *pSym = (IMAGEHLP_SYMBOL *) malloc( IMGSYMLEN + MAXNAMELEN );
IMAGEHLP_MODULE Module;
IMAGEHLP_LINE Line;
StrApp strSearchPath; // path to search for symbol tables (I think...JT)
achar *tt = 0;
STACKFRAME s; // in/out stackframe
memset( &s, '\0', sizeof s );
tt = new achar[TTBUFLEN];
if (!tt)
return;
// Build symbol search path.
// Add current directory
if (::GetCurrentDirectory( TTBUFLEN, tt ) )
AppendToStaWithSep(strSearchPath, tt);
// Add directory containing executable or DLL we are running in.
if (::GetModuleFileName( 0, tt, TTBUFLEN ) )
{
StrUni stuPath = tt; // convert to Unicode if necessary, allows use of wchars
const OLECHAR * pchPath = stuPath.Chars();
const OLECHAR * pch;
for (pch = pchPath + wcslen(pchPath) - 1; pch >= pchPath; -- pch )
{
// locate the rightmost path separator
if ( *pch == L'\\' || *pch == L'/' || *pch == L':' )
break;
}
// if we found one, p is pointing at it; if not, tt only contains
// an exe name (no path), and p points before its first byte
if ( pch != pchPath ) // path sep found?
{
if ( *pch == L':' ) // we leave colons in place
++ pch;
if (strSearchPath.Length())
strSearchPath.Append(";");
strSearchPath.Append(pchPath, (pch - pchPath));
}
}
// environment variable _NT_SYMBOL_PATH
if (::GetEnvironmentVariable( _T("_NT_SYMBOL_PATH"), tt, TTBUFLEN ))
AppendToStaWithSep(strSearchPath, tt);
// environment variable _NT_ALTERNATE_SYMBOL_PATH
if (::GetEnvironmentVariable( _T("_NT_ALTERNATE_SYMBOL_PATH"), tt, TTBUFLEN ))
AppendToStaWithSep(strSearchPath, tt);
// environment variable SYSTEMROOT
if (::GetEnvironmentVariable( _T("SYSTEMROOT"), tt, TTBUFLEN ))
AppendToStaWithSep(strSearchPath, tt);
// Why oh why does SymInitialize() want a writeable string? Surely it doesn't modify it...
// The doc clearly says it is an [in] parameter.
// Also, there is not a wide character version of this function!
StrAnsi staT(strSearchPath);
if ( !::SymInitialize( hProcess, const_cast<char *>(staT.Chars()), false ) )
goto LCleanup;
// SymGetOptions()
symOptions = SymGetOptions();
symOptions |= SYMOPT_LOAD_LINES;
symOptions &= ~SYMOPT_UNDNAME;
SymSetOptions( symOptions ); // SymSetOptions()
// Enumerate modules and tell imagehlp.dll about them.
// On NT, this is not necessary, but it won't hurt.
EnumAndLoadModuleSymbols( hProcess, GetCurrentProcessId() );
// init STACKFRAME for first call
// Notes: AddrModeFlat is just an assumption. I hate VDM debugging.
// Notes: will have to be #ifdef-ed for Alphas; MIPSes are dead anyway,
// and good riddance.
s.AddrPC.Offset = c.Eip;
s.AddrPC.Mode = AddrModeFlat;
s.AddrFrame.Offset = c.Ebp;
s.AddrFrame.Mode = AddrModeFlat;
memset( pSym, '\0', IMGSYMLEN + MAXNAMELEN );
pSym->SizeOfStruct = IMGSYMLEN;
pSym->MaxNameLength = MAXNAMELEN;
memset( &Line, '\0', sizeof Line );
Line.SizeOfStruct = sizeof Line;
memset( &Module, '\0', sizeof Module );
Module.SizeOfStruct = sizeof Module;
offsetFromSymbol = 0;
if (!m_pstaDump)
//.........这里部分代码省略.........