usp10: Update ScriptStringAnalyse and tests for ScriptString functions.

This commit is contained in:
Jeff Latimer 2006-06-06 20:21:07 +10:00 committed by Alexandre Julliard
parent 422ca43d14
commit 51ac1039db
2 changed files with 54 additions and 15 deletions

View File

@ -488,8 +488,9 @@ void test_ScriptTextOut(void)
static void test_ScriptString(void) static void test_ScriptString(void)
{ {
HRESULT hr; HRESULT hr;
HWND hwnd;
HDC hdc = 0; HDC hdc = 0;
WCHAR teststr[6] = {'T', 'e', 's', 't', '1', '\0'}; WCHAR teststr[6] = {'T', 'e', 's', 't', 'a', '\0'};
void *pString = (WCHAR *) &teststr; void *pString = (WCHAR *) &teststr;
int cString = 5; int cString = 5;
int cGlyphs = cString * 2 + 16; int cGlyphs = cString * 2 + 16;
@ -501,7 +502,7 @@ static void test_ScriptString(void)
const int piDx[5] = {10, 10, 10, 10, 10}; const int piDx[5] = {10, 10, 10, 10, 10};
SCRIPT_TABDEF pTabdef; SCRIPT_TABDEF pTabdef;
const BYTE pbInClass = 0; const BYTE pbInClass = 0;
SCRIPT_STRING_ANALYSIS pssa; SCRIPT_STRING_ANALYSIS pssa = NULL;
int iX = 10; int iX = 10;
int iY = 100; int iY = 100;
@ -510,14 +511,52 @@ static void test_ScriptString(void)
int iMinSel = 0; int iMinSel = 0;
int iMaxSel = 0; int iMaxSel = 0;
BOOL fDisabled = FALSE; BOOL fDisabled = FALSE;
LOGFONTW lf;
HFONT zfont;
/* We need a valid HDC to drive a lot of Script functions which requires the following *
* to set up for the tests. */
hwnd = CreateWindowExA(0, "static", "", WS_POPUP, 0,0,100,100,
0, 0, 0, NULL);
assert(hwnd != 0);
hdc = GetDC(hwnd); /* We now have a hdc */
ok( hdc != NULL, "HDC failed to be created %p\n", hdc);
lstrcpyW(lf.lfFaceName, (WCHAR *) "Courier");
lf.lfHeight = 10;
lf.lfItalic = 0;
lf.lfEscapement = 0;
lf.lfOrientation = 0;
lf.lfUnderline = 0;
lf.lfStrikeOut = 0;
lf.lfWeight = 3;
lf.lfWidth = 10;
zfont = (HFONT) SelectObject(hdc, CreateFontIndirectW(&lf));
/* Test without hdc to get E_INVALIDARG */
hr = ScriptStringAnalyse( NULL, pString, cString, cGlyphs, iCharset, dwFlags,
iReqWidth, &psControl, &psState, piDx, &pTabdef,
&pbInClass, &pssa);
ok(hr == E_PENDING, "ScriptStringAnalyse Stub should return E_PENDING not %08x\n", (unsigned int) hr);
/* test with hdc, this should be a valid test */
hr = ScriptStringAnalyse( hdc, pString, cString, cGlyphs, iCharset, dwFlags, hr = ScriptStringAnalyse( hdc, pString, cString, cGlyphs, iCharset, dwFlags,
iReqWidth, &psControl, &psState, piDx, &pTabdef, iReqWidth, &psControl, &psState, piDx, &pTabdef,
&pbInClass, &pssa); &pbInClass, &pssa);
ok(hr == E_INVALIDARG, "ScriptStringAnalyse Stub should return E_INVALIDARG not %08x\n", (unsigned int) hr); ok(hr == E_NOTIMPL, "ScriptStringAnalyse Stub should return E_NOTIMPL not %08x\n", (unsigned int) hr);
/* Commented code it pending new code in ScriptStringAnalysis */
/* ok(hr == S_OK, "ScriptStringAnalyse Stub should return S_OK not %08x\n", (unsigned int) hr);*/
/* ok(pssa != NULL, "ScriptStringAnalyse pssa should not be NULL\n");*/
if (hr == 0)
{
hr = ScriptStringOut(pssa, iX, iY, uOptions, &prc, iMinSel, iMaxSel,fDisabled); hr = ScriptStringOut(pssa, iX, iY, uOptions, &prc, iMinSel, iMaxSel,fDisabled);
ok(hr == E_NOTIMPL, "ScriptStringOut Stub should return E_NOTIMPL not %08x\n", (unsigned int) hr); ok(hr == E_NOTIMPL, "ScriptStringOut Stub should return E_NOTIMPL not %08x\n", (unsigned int) hr);
hr = ScriptStringFree(&pssa); hr = ScriptStringFree(&pssa);
ok(hr == S_OK, "ScriptStringFree Stub should return S_OK not %08x\n", (unsigned int) hr); ok(hr == S_OK, "ScriptStringFree Stub should return S_OK not %08x\n", (unsigned int) hr);
}
} }
START_TEST(usp10) START_TEST(usp10)

View File

@ -288,7 +288,7 @@ HRESULT WINAPI ScriptStringAnalyse(HDC hdc,
return E_INVALIDARG; return E_INVALIDARG;
} }
if ((dwFlags & SSA_GLYPHS) && NULL == hdc) { if ((dwFlags & SSA_GLYPHS) && NULL == hdc) {
return E_INVALIDARG; return E_PENDING;
} }
return E_NOTIMPL; return E_NOTIMPL;