static bool handleCandidates(HWND hwnd) { /* Obtain IME context */ HIMC imc = ImmGetContext(hwnd); if (!imc) return false; /* Make sure there is at least one candidate list */ DWORD count = 0; DWORD len = ImmGetCandidateListCountW(imc, &count); if (!count) { ImmReleaseContext(hwnd, imc); return false; } candidateIMEWindow=hwnd; /* Read first candidate list */ CANDIDATELIST* list = (CANDIDATELIST*)malloc(len); ImmGetCandidateList(imc, 0, list, len); ImmReleaseContext(hwnd, imc); /* Determine candidates currently being shown */ DWORD pageEnd = list->dwPageStart + list->dwPageSize; DWORD selection=list->dwSelection-list->dwPageStart; if (list->dwPageSize == 0) { pageEnd = list->dwCount; } else if (pageEnd > list->dwCount) { pageEnd = list->dwCount; } /* Concatenate currently shown candidates into a string */ WCHAR* cand_str = (WCHAR*)malloc(len); WCHAR* ptr = cand_str; for (DWORD n = list->dwPageStart, count = 0; n < pageEnd; ++n) { DWORD offset = list->dwOffset[n]; WCHAR* cand = (WCHAR*)(((char*)list) + offset); size_t clen = wcslen(cand); if (!clen) continue; CopyMemory(ptr, cand, (clen + 1) * sizeof(WCHAR)); if ((n + 1) < pageEnd) ptr[clen] = '\n'; ptr += (clen + 1); ++count; } HKL kbd_layout = GetKeyboardLayout(0); WCHAR filename[MAX_PATH + 1]={0}; ImmGetIMEFileNameW(kbd_layout, filename, MAX_PATH); if(cand_str&&wcslen(cand_str)>0) { nvdaControllerInternal_inputCandidateListUpdate(cand_str,selection,filename); } /* Clean up */ free(cand_str); free(list); return (count > 0); }
inline void handleCandidatesClosed(HWND hwnd) { if(!hwnd||hwnd!=candidateIMEWindow) return; /* Obtain IME context */ HIMC imc = ImmGetContext(hwnd); if (!imc) { candidateIMEWindow=0; nvdaControllerInternal_inputCandidateListUpdate(L"",-1,L""); return; } DWORD count = 0; DWORD len = ImmGetCandidateListCountW(imc, &count); ImmReleaseContext(hwnd, imc); if (!count) { candidateIMEWindow=0; nvdaControllerInternal_inputCandidateListUpdate(L"",-1,L""); } }