다음을 통해 공유


IWordBreaker::BreakText 메서드(indexsrv.h)

텍스트를 구문 분석하여 단어와 구를 식별하고 결과를 IWordSinkIPhraseSink 개체에 제공합니다.

구문

HRESULT BreakText(
  [in] TEXT_SOURCE *pTextSource,
  [in] IWordSink   *pWordSink,
  [in] IPhraseSink *pPhraseSink
);

매개 변수

[in] pTextSource

형식: TEXT_SOURCE*

유니코드 텍스트를 포함하는 TEXT_SOURCE 구조체에 대한 포인터입니다.

[in] pWordSink

형식: IWordSink*

이 메서드에서 생성된 단어를 수신하고 처리하는 IWordSink 개체에 대한 포인터입니다. NULL 은 이 메서드가 구만 식별해야 임을 나타냅니다.

[in] pPhraseSink

형식: IPhraseSink*

이 메서드에서 생성된 구를 수신하고 처리하는 IPhraseSink 개체에 대한 포인터입니다. NULL 은 이 메서드가 구가 아닌 개별 단어를 식별해야 임을 나타냅니다.

반환 값

형식: HRESULT

이 메서드는 이러한 값 중 하나를 반환할 수 있습니다.

반환 코드 설명
S_OK
작업이 성공했습니다. pTextSource 버퍼를 다시 채우기 위해 더 이상 텍스트를 사용할 수 없습니다.
E_INVALIDARG
인수가 잘못되었습니다. pTextSource 매개 변수는 NULL입니다.

설명

단어 분리기는 구문보다 단어에 대해 더 일반적으로 구문 분석되므로 pPhraseSink = 0에 최적화해야 합니다. pWordSink 또는 pPhraseSinkNULL일 수 있지만 둘 다 사용할 수는 없습니다.

IWordSink 개체는 단어 분리기에 대한 단어 및 대체 형식을 보유합니다. 다른 형식의 단어가 있는 경우 WordSink::P utAltWord 메서드를 사용하여 IWordSink 개체에 먼저 배치되고 WordSink::P utWord 메서드를 사용하여 루트 단어가 마지막으로 추가됩니다.

TEXT_SOURCE 구조체의 함수 포인터 요소인 pfnFillTextBuffer를 사용하여 원본 텍스트를 보충합니다. IWordBreaker::BreakText 메서드는 모든 pfnFillTextBuffer 반환 값을 처리해야 합니다. 오류가 발생하면 오류를 처리하기 전에 버퍼의 텍스트 처리를 완료합니다.

요구 사항

   
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 indexsrv.h
재배포 가능 파일 Windows NT 4.0 옵션 팩

참고 항목

IWordBreaker

TEXT_SOURCE