/* * RICHEDIT.H * * Purpose: * RICHEDIT v2.0-v6.0 public definitions * * Copyright (c) Microsoft Corporation. All rights reserved. */ #ifndef _RICHEDIT_ #define _RICHEDIT_ #pragma once #include <wtypes.h> #include <objbase.h> #ifdef _WIN32 #include <pshpack4.h> #elif !defined(RC_INVOKED) #pragma pack(4) #endif #ifdef __cplusplus extern "C" { #endif // __cplusplus // To mimic older RichEdit behavior, set _RICHEDIT_VER to appropriate value // Version 1.0 0x0100 // Version 2.0 0x0200 // Version 2.1 0x0210 #ifndef _RICHEDIT_VER #define _RICHEDIT_VER 0x0800 #endif #define cchTextLimitDefault 32767 #define MSFTEDIT_CLASS L"RICHEDIT50W" // NOTE: MSFTEDIT.DLL only registers MSFTEDIT_CLASS. If an application wants // to use the following RichEdit classes, it needs to load riched20.dll. // Otherwise, CreateWindow with RICHEDIT_CLASS will fail. // This also applies to any dialog that uses RICHEDIT_CLASS // RichEdit 2.0 Window Class // On Windows CE, avoid possible conflicts on Win95 #define CERICHEDIT_CLASSA "RichEditCEA" #define CERICHEDIT_CLASSW L"RichEditCEW" #define RICHEDIT_CLASSA "RichEdit20A" #define RICHEDIT_CLASS10A "RICHEDIT" // Richedit 1.0 #ifndef MACPORT #define RICHEDIT_CLASSW L"RichEdit20W" #else //----------------------MACPORT #define RICHEDIT_CLASSW TEXT("RichEdit20W") // MACPORT change #endif // MACPORT #if (_RICHEDIT_VER >= 0x0200 ) #ifdef UNICODE #define RICHEDIT_CLASS RICHEDIT_CLASSW #else #define RICHEDIT_CLASS RICHEDIT_CLASSA #endif // UNICODE #else #define RICHEDIT_CLASS RICHEDIT_CLASS10A #endif // _RICHEDIT_VER >= 0x0200 // RichEdit messages #ifndef WM_CONTEXTMENU #define WM_CONTEXTMENU 0x007B #endif #ifndef WM_UNICHAR #define WM_UNICHAR 0x0109 #endif #ifndef WM_PRINTCLIENT #define WM_PRINTCLIENT 0x0318 #endif #ifndef EM_GETLIMITTEXT #define EM_GETLIMITTEXT (WM_USER + 37) #endif #ifndef EM_POSFROMCHAR #define EM_POSFROMCHAR (WM_USER + 38) #define EM_CHARFROMPOS (WM_USER + 39) #endif #ifndef EM_SCROLLCARET #define EM_SCROLLCARET (WM_USER + 49) #endif #define EM_CANPASTE (WM_USER + 50) #define EM_DISPLAYBAND (WM_USER + 51) #define EM_EXGETSEL (WM_USER + 52) #define EM_EXLIMITTEXT (WM_USER + 53) #define EM_EXLINEFROMCHAR (WM_USER + 54) #define EM_EXSETSEL (WM_USER + 55) #define EM_FINDTEXT (WM_USER + 56) #define EM_FORMATRANGE (WM_USER + 57) #define EM_GETCHARFORMAT (WM_USER + 58) #define EM_GETEVENTMASK (WM_USER + 59) #define EM_GETOLEINTERFACE (WM_USER + 60) #define EM_GETPARAFORMAT (WM_USER + 61) #define EM_GETSELTEXT (WM_USER + 62) #define EM_HIDESELECTION (WM_USER + 63) #define EM_PASTESPECIAL (WM_USER + 64) #define EM_REQUESTRESIZE (WM_USER + 65) #define EM_SELECTIONTYPE (WM_USER + 66) #define EM_SETBKGNDCOLOR (WM_USER + 67) #define EM_SETCHARFORMAT (WM_USER + 68) #define EM_SETEVENTMASK (WM_USER + 69) #define EM_SETOLECALLBACK (WM_USER + 70) #define EM_SETPARAFORMAT (WM_USER + 71) #define EM_SETTARGETDEVICE (WM_USER + 72) #define EM_STREAMIN (WM_USER + 73) #define EM_STREAMOUT (WM_USER + 74) #define EM_GETTEXTRANGE (WM_USER + 75) #define EM_FINDWORDBREAK (WM_USER + 76) #define EM_SETOPTIONS (WM_USER + 77) #define EM_GETOPTIONS (WM_USER + 78) #define EM_FINDTEXTEX (WM_USER + 79) #ifdef _WIN32 #define EM_GETWORDBREAKPROCEX (WM_USER + 80) #define EM_SETWORDBREAKPROCEX (WM_USER + 81) #endif // RichEdit 2.0 messages #define EM_SETUNDOLIMIT (WM_USER + 82) #define EM_REDO (WM_USER + 84) #define EM_CANREDO (WM_USER + 85) #define EM_GETUNDONAME (WM_USER + 86) #define EM_GETREDONAME (WM_USER + 87) #define EM_STOPGROUPTYPING (WM_USER + 88) #define EM_SETTEXTMODE (WM_USER + 89) #define EM_GETTEXTMODE (WM_USER + 90) // enum for use with EM_GET/SETTEXTMODE typedef enum tagTextMode { TM_PLAINTEXT = 1, TM_RICHTEXT = 2, // Default behavior TM_SINGLELEVELUNDO = 4, TM_MULTILEVELUNDO = 8, // Default behavior TM_SINGLECODEPAGE = 16, TM_MULTICODEPAGE = 32 // Default behavior } TEXTMODE; #define EM_AUTOURLDETECT (WM_USER + 91) #if (_RICHEDIT_VER >= 0x0800) #define AURL_ENABLEURL 1 #define AURL_ENABLEEMAILADDR 2 #define AURL_ENABLETELNO 4 #define AURL_ENABLEEAURLS 8 #define AURL_ENABLEDRIVELETTERS 16 #define AURL_DISABLEMIXEDLGC 32 // Disable mixed Latin Greek Cyrillic IDNs #endif #define EM_GETAUTOURLDETECT (WM_USER + 92) #define EM_SETPALETTE (WM_USER + 93) #define EM_GETTEXTEX (WM_USER + 94) #define EM_GETTEXTLENGTHEX (WM_USER + 95) #define EM_SHOWSCROLLBAR (WM_USER + 96) #define EM_SETTEXTEX (WM_USER + 97) // East Asia specific messages #define EM_SETPUNCTUATION (WM_USER + 100) #define EM_GETPUNCTUATION (WM_USER + 101) #define EM_SETWORDWRAPMODE (WM_USER + 102) #define EM_GETWORDWRAPMODE (WM_USER + 103) #define EM_SETIMECOLOR (WM_USER + 104) #define EM_GETIMECOLOR (WM_USER + 105) #define EM_SETIMEOPTIONS (WM_USER + 106) #define EM_GETIMEOPTIONS (WM_USER + 107) #define EM_CONVPOSITION (WM_USER + 108) #define EM_SETLANGOPTIONS (WM_USER + 120) #define EM_GETLANGOPTIONS (WM_USER + 121) #define EM_GETIMECOMPMODE (WM_USER + 122) #define EM_FINDTEXTW (WM_USER + 123) #define EM_FINDTEXTEXW (WM_USER + 124) // RE3.0 FE messages #define EM_RECONVERSION (WM_USER + 125) #define EM_SETIMEMODEBIAS (WM_USER + 126) #define EM_GETIMEMODEBIAS (WM_USER + 127) // BiDi specific messages #define EM_SETBIDIOPTIONS (WM_USER + 200) #define EM_GETBIDIOPTIONS (WM_USER + 201) #define EM_SETTYPOGRAPHYOPTIONS (WM_USER + 202) #define EM_GETTYPOGRAPHYOPTIONS (WM_USER + 203) // Extended edit style specific messages #define EM_SETEDITSTYLE (WM_USER + 204) #define EM_GETEDITSTYLE (WM_USER + 205) // Extended edit style masks #define SES_EMULATESYSEDIT 1 #define SES_BEEPONMAXTEXT 2 #define SES_EXTENDBACKCOLOR 4 #define SES_MAPCPS 8 // Obsolete (never used) #if (_RICHEDIT_VER >= 0x0500) #define SES_HYPERLINKTOOLTIPS 8 #endif #define SES_EMULATE10 16 // Obsolete (never used) #if (_RICHEDIT_VER >= 0x0700) #define SES_DEFAULTLATINLIGA 16 #endif #define SES_USECRLF 32 // Obsolete (never used) #define SES_USEAIMM 64 #define SES_NOIME 128 #define SES_ALLOWBEEPS 256 #define SES_UPPERCASE 512 #define SES_LOWERCASE 1024 #define SES_NOINPUTSEQUENCECHK 2048 #define SES_BIDI 4096 #define SES_SCROLLONKILLFOCUS 8192 #define SES_XLTCRCRLFTOCR 16384 #define SES_DRAFTMODE 32768 #define SES_USECTF 0x00010000 #define SES_HIDEGRIDLINES 0x00020000 #define SES_USEATFONT 0x00040000 #define SES_CUSTOMLOOK 0x00080000 #define SES_LBSCROLLNOTIFY 0x00100000 #define SES_CTFALLOWEMBED 0x00200000 #define SES_CTFALLOWSMARTTAG 0x00400000 #define SES_CTFALLOWPROOFING 0x00800000 #if (_RICHEDIT_VER >= 0x0500) #define SES_LOGICALCARET 0x01000000 #define SES_WORDDRAGDROP 0x02000000 #define SES_SMARTDRAGDROP 0x04000000 #define SES_MULTISELECT 0x08000000 #define SES_CTFNOLOCK 0x10000000 #define SES_NOEALINEHEIGHTADJUST 0x20000000 #define SES_MAX 0x20000000 #endif // Options for EM_SETLANGOPTIONS and EM_GETLANGOPTIONS #define IMF_AUTOKEYBOARD 0x0001 #define IMF_AUTOFONT 0x0002 #define IMF_IMECANCELCOMPLETE 0x0004 // High completes comp string when aborting, low cancels #define IMF_IMEALWAYSSENDNOTIFY 0x0008 #define IMF_AUTOFONTSIZEADJUST 0x0010 #define IMF_UIFONTS 0x0020 #if (_RICHEDIT_VER >= 0x0800) #define IMF_NOIMPLICITLANG 0x0040 #endif #define IMF_DUALFONT 0x0080 #if (_RICHEDIT_VER >= 0x0800) #define IMF_NOKBDLIDFIXUP 0x0200 #endif #define IMF_NORTFFONTSUBSTITUTE 0x0400 #if (_RICHEDIT_VER >= 0x0800) #define IMF_SPELLCHECKING 0x0800 #define IMF_TKBPREDICTION 0x1000 #endif // Values for EM_GETIMECOMPMODE #define ICM_NOTOPEN 0x0000 #define ICM_LEVEL3 0x0001 #define ICM_LEVEL2 0x0002 #define ICM_LEVEL2_5 0x0003 #define ICM_LEVEL2_SUI 0x0004 #define ICM_CTF 0x0005 // Options for EM_SETTYPOGRAPHYOPTIONS #define TO_ADVANCEDTYPOGRAPHY 0x0001 #define TO_SIMPLELINEBREAK 0x0002 #define TO_DISABLECUSTOMTEXTOUT 0x0004 #define TO_ADVANCEDLAYOUT 0x0008 // Pegasus outline mode messages (RE 3.0) // Outline mode message #define EM_OUTLINE (WM_USER + 220) // Message for getting and restoring scroll pos #define EM_GETSCROLLPOS (WM_USER + 221) #define EM_SETSCROLLPOS (WM_USER + 222) // Change fontsize in current selection by wParam #define EM_SETFONTSIZE (WM_USER + 223) #define EM_GETZOOM (WM_USER + 224) #define EM_SETZOOM (WM_USER + 225) #define EM_GETVIEWKIND (WM_USER + 226) #define EM_SETVIEWKIND (WM_USER + 227) // RichEdit 4.0 messages #define EM_GETPAGE (WM_USER + 228) #define EM_SETPAGE (WM_USER + 229) #define EM_GETHYPHENATEINFO (WM_USER + 230) #define EM_SETHYPHENATEINFO (WM_USER + 231) #define EM_GETPAGEROTATE (WM_USER + 235) #define EM_SETPAGEROTATE (WM_USER + 236) #define EM_GETCTFMODEBIAS (WM_USER + 237) #define EM_SETCTFMODEBIAS (WM_USER + 238) #define EM_GETCTFOPENSTATUS (WM_USER + 240) #define EM_SETCTFOPENSTATUS (WM_USER + 241) #define EM_GETIMECOMPTEXT (WM_USER + 242) #define EM_ISIME (WM_USER + 243) #define EM_GETIMEPROPERTY (WM_USER + 244) // These messages control what rich edit does when it comes accross // OLE objects during RTF stream in. Normally rich edit queries the client // application only after OleLoad has been called. With these messages it is possible to // set the rich edit control to a mode where it will query the client application before // OleLoad is called #define EM_GETQUERYRTFOBJ (WM_USER + 269) #define EM_SETQUERYRTFOBJ (WM_USER + 270) // EM_SETPAGEROTATE wparam values #define EPR_0 0 // Text flows left to right and top to bottom #define EPR_270 1 // Text flows top to bottom and right to left #define EPR_180 2 // Text flows right to left and bottom to top #define EPR_90 3 // Text flows bottom to top and left to right #if (_RICHEDIT_VER >= 0x0800) #define EPR_SE 5 // Text flows top to bottom and left to right (Mongolian text layout) #endif // EM_SETCTFMODEBIAS wparam values #define CTFMODEBIAS_DEFAULT 0x0000 #define CTFMODEBIAS_FILENAME 0x0001 #define CTFMODEBIAS_NAME 0x0002 #define CTFMODEBIAS_READING 0x0003 #define CTFMODEBIAS_DATETIME 0x0004 #define CTFMODEBIAS_CONVERSATION 0x0005 #define CTFMODEBIAS_NUMERIC 0x0006 #define CTFMODEBIAS_HIRAGANA 0x0007 #define CTFMODEBIAS_KATAKANA 0x0008 #define CTFMODEBIAS_HANGUL 0x0009 #define CTFMODEBIAS_HALFWIDTHKATAKANA 0x000A #define CTFMODEBIAS_FULLWIDTHALPHANUMERIC 0x000B #define CTFMODEBIAS_HALFWIDTHALPHANUMERIC 0x000C // EM_SETIMEMODEBIAS lparam values #define IMF_SMODE_PLAURALCLAUSE 0x0001 #define IMF_SMODE_NONE 0x0002 // EM_GETIMECOMPTEXT wparam structure typedef struct _imecomptext { LONG cb; // count of bytes in the output buffer. DWORD flags; // value specifying the composition string type. // Currently only support ICT_RESULTREADSTR } IMECOMPTEXT; #define ICT_RESULTREADSTR 1 // Outline mode wparam values #define EMO_EXIT 0 // Enter normal mode, lparam ignored #define EMO_ENTER 1 // Enter outline mode, lparam ignored #define EMO_PROMOTE 2 // LOWORD(lparam) == 0 ==> // promote to body-text // LOWORD(lparam) != 0 ==> // promote/demote current selection // by indicated number of levels #define EMO_EXPAND 3 // HIWORD(lparam) = EMO_EXPANDSELECTION // -> expands selection to level // indicated in LOWORD(lparam) // LOWORD(lparam) = -1/+1 corresponds // to collapse/expand button presses // in winword (other values are // equivalent to having pressed these // buttons more than once) // HIWORD(lparam) = EMO_EXPANDDOCUMENT // -> expands whole document to // indicated level #define EMO_MOVESELECTION 4 // LOWORD(lparam) != 0 -> move current // selection up/down by indicated amount #define EMO_GETVIEWMODE 5 // Returns VM_NORMAL or VM_OUTLINE // EMO_EXPAND options #define EMO_EXPANDSELECTION 0 #define EMO_EXPANDDOCUMENT 1 #define VM_NORMAL 4 // Agrees with RTF \viewkindN #define VM_OUTLINE 2 #define VM_PAGE 9 // Screen page view (not print layout) /// New messages as of Win8 #if (_RICHEDIT_VER >= 0x0800) #define EM_INSERTTABLE (WM_USER + 232) #pragma warning(push) #pragma warning(disable:4214) // Microsoft extension -- Bitfield not int // Data type defining table rows for EM_INSERTTABLE typedef struct _tableRowParms { // EM_INSERTTABLE wparam is a (TABLEROWPARMS *) BYTE cbRow; // Count of bytes in this structure BYTE cbCell; // Count of bytes in TABLECELLPARMS BYTE cCell; // Count of cells BYTE cRow; // Count of rows LONG dxCellMargin; // Cell left/right margin (\trgaph) LONG dxIndent; // Row left (right if fRTL indent (similar to \trleft) LONG dyHeight; // Row height (\trrh) DWORD nAlignment:3; // Row alignment (like PARAFORMAT::bAlignment, \trql, trqr, \trqc) DWORD fRTL:1; // Display cells in RTL order (\rtlrow) DWORD fKeep:1; // Keep row together (\trkeep} DWORD fKeepFollow:1; // Keep row on same page as following row (\trkeepfollow) DWORD fWrap:1; // Wrap text to right/left (depending on bAlignment) // (see \tdfrmtxtLeftN, \tdfrmtxtRightN) DWORD fIdentCells:1; // lparam points at single struct valid for all cells LONG cpStartRow; // cp where to insert table (-1 for selection cp) // (can be used for either TRD by EM_GETTABLEPARMS) BYTE bTableLevel; // Table nesting level (EM_GETTABLEPARMS only) BYTE iCell; // Index of cell to insert/delete (EM_SETTABLEPARMS only) } TABLEROWPARMS; // Data type defining table cells for EM_INSERTTABLE typedef struct _tableCellParms { // EM_INSERTTABLE lparam is a (TABLECELLPARMS *) LONG dxWidth; // Cell width (\cellx) WORD nVertAlign:2; // Vertical alignment (0/1/2 = top/center/bottom // \clvertalt (def), \clvertalc, \clvertalb) WORD fMergeTop:1; // Top cell for vertical merge (\clvmgf) WORD fMergePrev:1; // Merge with cell above (\clvmrg) WORD fVertical:1; // Display text top to bottom, right to left (\cltxtbrlv) WORD fMergeStart:1; // Start set of horizontally merged cells (\clmgf) WORD fMergeCont:1; // Merge with previous cell (\clmrg) WORD wShading; // Shading in .01% (\clshdng) e.g., 10000 flips fore/back SHORT dxBrdrLeft; // Left border width (\clbrdrl\brdrwN) (in twips) SHORT dyBrdrTop; // Top border width (\clbrdrt\brdrwN) SHORT dxBrdrRight; // Right border width (\clbrdrr\brdrwN) SHORT dyBrdrBottom; // Bottom border width (\clbrdrb\brdrwN) COLORREF crBrdrLeft; // Left border color (\clbrdrl\brdrcf) COLORREF crBrdrTop; // Top border color (\clbrdrt\brdrcf) COLORREF crBrdrRight; // Right border color (\clbrdrr\brdrcf) COLORREF crBrdrBottom; // Bottom border color (\clbrdrb\brdrcf) COLORREF crBackPat; // Background color (\clcbpat) COLORREF crForePat; // Foreground color (\clcfpat) } TABLECELLPARMS; #pragma warning(pop) #define EM_GETAUTOCORRECTPROC (WM_USER + 233) #define EM_SETAUTOCORRECTPROC (WM_USER + 234) #define EM_CALLAUTOCORRECTPROC (WM_USER + 255) // AutoCorrect callback typedef int (WINAPI *AutoCorrectProc)(LANGID langid, const wchar_t *pszBefore, wchar_t *pszAfter, LONG cchAfter, LONG *pcchReplaced); #define ATP_NOCHANGE 0 #define ATP_CHANGE 1 #define ATP_NODELIMITER 2 #define ATP_REPLACEALLTEXT 4 #define EM_GETTABLEPARMS (WM_USER + 265) #define EM_SETEDITSTYLEEX (WM_USER + 275) #define EM_GETEDITSTYLEEX (WM_USER + 276) // wparam values for EM_SETEDITSTYLEEX/EM_GETEDITSTYLEEX // All unused bits are reserved. #define SES_EX_NOTABLE 0x00000004 #define SES_EX_HANDLEFRIENDLYURL 0x00000100 #define SES_EX_NOTHEMING 0x00080000 #define SES_EX_NOACETATESELECTION 0x00100000 #define SES_EX_USESINGLELINE 0x00200000 #define SES_EX_MULTITOUCH 0x08000000 // Only works under Win8+ #define SES_EX_HIDETEMPFORMAT 0x10000000 #define SES_EX_USEMOUSEWPARAM 0x20000000 // Use wParam when handling WM_MOUSEMOVE message and do not call GetAsyncKeyState #define EM_GETSTORYTYPE (WM_USER + 290) #define EM_SETSTORYTYPE (WM_USER + 291) #define EM_GETELLIPSISMODE (WM_USER + 305) #define EM_SETELLIPSISMODE (WM_USER + 306) // DWORD: *lparam for EM_GETELLIPSISMODE, lparam for EM_SETELLIPSISMODE #define ELLIPSIS_MASK 0x00000003 // all meaningful bits #define ELLIPSIS_NONE 0x00000000 // ellipsis disabled #define ELLIPSIS_END 0x00000001 // ellipsis at the end (forced break) #define ELLIPSIS_WORD 0x00000003 // ellipsis at the end (word break) #define EM_SETTABLEPARMS (WM_USER + 307) #define EM_GETTOUCHOPTIONS (WM_USER + 310) #define EM_SETTOUCHOPTIONS (WM_USER + 311) #define EM_INSERTIMAGE (WM_USER + 314) #define EM_SETUIANAME (WM_USER + 320) #define EM_GETELLIPSISSTATE (WM_USER + 322) // Values for EM_SETTOUCHOPTIONS/EM_GETTOUCHOPTIONS #define RTO_SHOWHANDLES 1 #define RTO_DISABLEHANDLES 2 #define RTO_READINGMODE 3 // lparam for EM_INSERTIMAGE typedef struct tagRICHEDIT_IMAGE_PARAMETERS { LONG xWidth; // Units are HIMETRIC LONG yHeight; // Units are HIMETRIC LONG Ascent; // Units are HIMETRIC LONG Type; // Valid values are TA_TOP, TA_BOTTOM and TA_BASELINE LPCWSTR pwszAlternateText; IStream * pIStream; } RICHEDIT_IMAGE_PARAMETERS; #endif // New notifications #define EN_MSGFILTER 0x0700 #define EN_REQUESTRESIZE 0x0701 #define EN_SELCHANGE 0x0702 #define EN_DROPFILES 0x0703 #define EN_PROTECTED 0x0704 #define EN_CORRECTTEXT 0x0705 // PenWin specific #define EN_STOPNOUNDO 0x0706 #define EN_IMECHANGE 0x0707 // East Asia specific #define EN_SAVECLIPBOARD 0x0708 #define EN_OLEOPFAILED 0x0709 #define EN_OBJECTPOSITIONS 0x070a #define EN_LINK 0x070b #define EN_DRAGDROPDONE 0x070c #define EN_PARAGRAPHEXPANDED 0x070d #define EN_PAGECHANGE 0x070e #define EN_LOWFIRTF 0x070f #define EN_ALIGNLTR 0x0710 // BiDi specific notification #define EN_ALIGNRTL 0x0711 // BiDi specific notification #if (_RICHEDIT_VER >= 0x0800) #define EN_CLIPFORMAT 0x0712 #define EN_STARTCOMPOSITION 0x0713 #define EN_ENDCOMPOSITION 0x0714 // Notification structure for EN_ENDCOMPOSITION typedef struct _endcomposition { NMHDR nmhdr; DWORD dwCode; } ENDCOMPOSITIONNOTIFY; // Constants for ENDCOMPOSITIONNOTIFY dwCode #define ECN_ENDCOMPOSITION 0x0001 #define ECN_NEWTEXT 0x0002 #endif // Event notification masks #define ENM_NONE 0x00000000 #define ENM_CHANGE 0x00000001 #define ENM_UPDATE 0x00000002 #define ENM_SCROLL 0x00000004 #define ENM_SCROLLEVENTS 0x00000008 #define ENM_DRAGDROPDONE 0x00000010 #define ENM_PARAGRAPHEXPANDED 0x00000020 #define ENM_PAGECHANGE 0x00000040 #if (_RICHEDIT_VER >= 0x0800) #define ENM_CLIPFORMAT 0x00000080 #endif #define ENM_KEYEVENTS 0x00010000 #define ENM_MOUSEEVENTS 0x00020000 #define ENM_REQUESTRESIZE 0x00040000 #define ENM_SELCHANGE 0x00080000 #define ENM_DROPFILES 0x00100000 #define ENM_PROTECTED 0x00200000 #define ENM_CORRECTTEXT 0x00400000 // PenWin specific #define ENM_IMECHANGE 0x00800000 // Used by RE1.0 compatibility #define ENM_LANGCHANGE 0x01000000 #define ENM_OBJECTPOSITIONS 0x02000000 #define ENM_LINK 0x04000000 #define ENM_LOWFIRTF 0x08000000 #if (_RICHEDIT_VER >= 0x0800) #define ENM_STARTCOMPOSITION 0x10000000 #define ENM_ENDCOMPOSITION 0x20000000 #define ENM_GROUPTYPINGCHANGE 0x40000000 #define ENM_HIDELINKTOOLTIP 0x80000000 #endif // New edit control styles #define ES_SAVESEL 0x00008000 #define ES_SUNKEN 0x00004000 #define ES_DISABLENOSCROLL 0x00002000 // Same as WS_MAXIMIZE, but that doesn't make sense so we re-use the value #define ES_SELECTIONBAR 0x01000000 // Same as ES_UPPERCASE, but re-used to completely disable OLE drag'n'drop #define ES_NOOLEDRAGDROP 0x00000008 // Obsolete Edit Style #define ES_EX_NOCALLOLEINIT 0x00000000 // Not supported in RE 2.0/3.0 // These flags are used in FE Windows #define ES_VERTICAL 0x00400000 // Not supported in RE 2.0/3.0 #define ES_NOIME 0x00080000 #define ES_SELFIME 0x00040000 // Edit control options #define ECO_AUTOWORDSELECTION 0x00000001 #define ECO_AUTOVSCROLL 0x00000040 #define ECO_AUTOHSCROLL 0x00000080 #define ECO_NOHIDESEL 0x00000100 #define ECO_READONLY 0x00000800 #define ECO_WANTRETURN 0x00001000 #define ECO_SAVESEL 0x00008000 #define ECO_SELECTIONBAR 0x01000000 #define ECO_VERTICAL 0x00400000 // FE specific // ECO operations #define ECOOP_SET 0x0001 #define ECOOP_OR 0x0002 #define ECOOP_AND 0x0003 #define ECOOP_XOR 0x0004 // New word break function actions #define WB_CLASSIFY 3 #define WB_MOVEWORDLEFT 4 #define WB_MOVEWORDRIGHT 5 #define WB_LEFTBREAK 6 #define WB_RIGHTBREAK 7 // East Asia specific flags #define WB_MOVEWORDPREV 4 #define WB_MOVEWORDNEXT 5 #define WB_PREVBREAK 6 #define WB_NEXTBREAK 7 #define PC_FOLLOWING 1 #define PC_LEADING 2 #define PC_OVERFLOW 3 #define PC_DELIMITER 4 #define WBF_WORDWRAP 0x010 #define WBF_WORDBREAK 0x020 #define WBF_OVERFLOW 0x040 #define WBF_LEVEL1 0x080 #define WBF_LEVEL2 0x100 #define WBF_CUSTOM 0x200 // East Asia specific flags #define IMF_FORCENONE 0x0001 #define IMF_FORCEENABLE 0x0002 #define IMF_FORCEDISABLE 0x0004 #define IMF_CLOSESTATUSWINDOW 0x0008 #define IMF_VERTICAL 0x0020 #define IMF_FORCEACTIVE 0x0040 #define IMF_FORCEINACTIVE 0x0080 #define IMF_FORCEREMEMBER 0x0100 #define IMF_MULTIPLEEDIT 0x0400 // Word break flags (used with WB_CLASSIFY) #define WBF_CLASS ((BYTE) 0x0F) #define WBF_ISWHITE ((BYTE) 0x10) #define WBF_BREAKLINE ((BYTE) 0x20) #define WBF_BREAKAFTER ((BYTE) 0x40) // Data types #ifdef _WIN32 // Extended edit word break proc (character set aware) typedef LONG (*EDITWORDBREAKPROCEX)(char *pchText, LONG cchText, BYTE bCharSet, INT action); #endif // All character format measurements are in twips typedef struct _charformat { UINT cbSize; DWORD dwMask; DWORD dwEffects; LONG yHeight; LONG yOffset; COLORREF crTextColor; BYTE bCharSet; BYTE bPitchAndFamily; char szFaceName[LF_FACESIZE]; } CHARFORMATA; typedef struct _charformatw { UINT cbSize; DWORD dwMask; DWORD dwEffects; LONG yHeight; LONG yOffset; COLORREF crTextColor; BYTE bCharSet; BYTE bPitchAndFamily; wchar_t szFaceName[LF_FACESIZE]; } CHARFORMATW; #if (_RICHEDIT_VER >= 0x0200) #ifdef UNICODE #define CHARFORMAT CHARFORMATW #else #define CHARFORMAT CHARFORMATA #endif // UNICODE #else #define CHARFORMAT CHARFORMATA #endif // _RICHEDIT_VER >= 0x0200 // CHARFORMAT2 structure #if defined(__cplusplus) struct CHARFORMAT2W : _charformatw { WORD wWeight; // Font weight (LOGFONT value) SHORT sSpacing; // Amount to space between letters COLORREF crBackColor; // Background color LCID lcid; // Locale ID #if (_RICHEDIT_VER >= 0x0500) union { DWORD dwReserved; // Name up to 5.0 DWORD dwCookie; // Client cookie opaque to RichEdit }; #else DWORD dwReserved; // Name up to 5.0 #endif SHORT sStyle; // Style handle WORD wKerning; // Twip size above which to kern char pair BYTE bUnderlineType; // Underline type BYTE bAnimation; // Animated text like marching ants BYTE bRevAuthor; // Revision author index #if (_RICHEDIT_VER >= 0x0800) BYTE bUnderlineColor; // Underline color #endif }; struct CHARFORMAT2A : _charformat { WORD wWeight; // Font weight (LOGFONT value) SHORT sSpacing; // Amount to space between letters COLORREF crBackColor; // Background color LCID lcid; // Locale ID #if (_RICHEDIT_VER >= 0x0500) union { DWORD dwReserved; // Name up to 5.0 DWORD dwCookie; // Client cookie opaque to RichEdit }; #else DWORD dwReserved; // Name up to 5.0 #endif SHORT sStyle; // Style handle WORD wKerning; // Twip size above which to kern char pair BYTE bUnderlineType; // Underline type BYTE bAnimation; // Animated text like marching ants BYTE bRevAuthor; // Revision author index #if (_RICHEDIT_VER >= 0x0800) BYTE bUnderlineColor; // Underline color #endif }; #else // regular C-style typedef struct _charformat2w { UINT cbSize; DWORD dwMask; DWORD dwEffects; LONG yHeight; LONG yOffset; // > 0 for superscript, < 0 for subscript COLORREF crTextColor; BYTE bCharSet; BYTE bPitchAndFamily; wchar_t szFaceName[LF_FACESIZE]; WORD wWeight; // Font weight (LOGFONT value) SHORT sSpacing; // Amount to space between letters COLORREF crBackColor; // Background color LCID lcid; // Locale ID #if (_RICHEDIT_VER >= 0x0500) union { DWORD dwReserved; // Name up to 5.0 DWORD dwCookie; // Client cookie opaque to RichEdit }; #else DWORD dwReserved; // Name up to 5.0 #endif SHORT sStyle; // Style handle WORD wKerning; // Twip size above which to kern char pair BYTE bUnderlineType; // Underline type BYTE bAnimation; // Animated text like marching ants BYTE bRevAuthor; // Revision author index #if (_RICHEDIT_VER >= 0x0800) BYTE bUnderlineColor; // Underline color #endif } CHARFORMAT2W; typedef struct _charformat2a { UINT cbSize; DWORD dwMask; DWORD dwEffects; LONG yHeight; LONG yOffset; // > 0 for superscript, < 0 for subscript COLORREF crTextColor; BYTE bCharSet; BYTE bPitchAndFamily; char szFaceName[LF_FACESIZE]; WORD wWeight; // Font weight (LOGFONT value) SHORT sSpacing; // Amount to space between letters COLORREF crBackColor; // Background color LCID lcid; // Locale ID #if (_RICHEDIT_VER >= 0x0500) union { DWORD dwReserved; // Name up to 5.0 DWORD dwCookie; // Client cookie opaque to RichEdit }; #else DWORD dwReserved; // Name up to 5.0 #endif SHORT sStyle; // Style handle WORD wKerning; // Twip size above which to kern char pair BYTE bUnderlineType; // Underline type BYTE bAnimation; // Animated text like marching ants BYTE bRevAuthor; // Revision author index #if (_RICHEDIT_VER >= 0x0800) BYTE bUnderlineColor; // Underline color #endif } CHARFORMAT2A; #endif // C++ #ifdef UNICODE #define CHARFORMAT2 CHARFORMAT2W #else #define CHARFORMAT2 CHARFORMAT2A #endif #define CHARFORMATDELTA (sizeof(CHARFORMAT2) - sizeof(CHARFORMAT)) // CFM_COLOR mirrors CFE_AUTOCOLOR, a little hack to easily deal with autocolor // CHARFORMAT masks #define CFM_BOLD 0x00000001 #define CFM_ITALIC 0x00000002 #define CFM_UNDERLINE 0x00000004 #define CFM_STRIKEOUT 0x00000008 #define CFM_PROTECTED 0x00000010 #define CFM_LINK 0x00000020 // Exchange hyperlink extension #define CFM_SIZE 0x80000000 #define CFM_COLOR 0x40000000 #define CFM_FACE 0x20000000 #define CFM_OFFSET 0x10000000 #define CFM_CHARSET 0x08000000 // CHARFORMAT effects #define CFE_BOLD 0x00000001 #define CFE_ITALIC 0x00000002 #define CFE_UNDERLINE 0x00000004 #define CFE_STRIKEOUT 0x00000008 #define CFE_PROTECTED 0x00000010 #define CFE_LINK 0x00000020 #define CFE_AUTOCOLOR 0x40000000 // NOTE: this corresponds to // CFM_COLOR, which controls it // Masks and effects defined for CHARFORMAT2 -- an (*) indicates // that the data is stored by RichEdit 2.0/3.0, but not displayed #define CFM_SMALLCAPS 0x00000040 // (*) #define CFM_ALLCAPS 0x00000080 // Displayed by 3.0 #define CFM_HIDDEN 0x00000100 // Hidden by 3.0 #define CFM_OUTLINE 0x00000200 // (*) #define CFM_SHADOW 0x00000400 // (*) #define CFM_EMBOSS 0x00000800 // (*) #define CFM_IMPRINT 0x00001000 // (*) #define CFM_DISABLED 0x00002000 #define CFM_REVISED 0x00004000 #define CFM_REVAUTHOR 0x00008000 #define CFE_SUBSCRIPT 0x00010000 // Superscript and subscript are #define CFE_SUPERSCRIPT 0x00020000 // mutually exclusive #define CFM_ANIMATION 0x00040000 // (*) #define CFM_STYLE 0x00080000 // (*) #define CFM_KERNING 0x00100000 #define CFM_SPACING 0x00200000 // Displayed by 3.0 #define CFM_WEIGHT 0x00400000 #define CFM_UNDERLINETYPE 0x00800000 // Many displayed by 3.0 #if (_RICHEDIT_VER >= 0x0600) #define CFM_COOKIE 0x01000000 // RE 6.0 #endif #define CFM_LCID 0x02000000 #define CFM_BACKCOLOR 0x04000000 // Higher mask bits defined above #define CFM_SUBSCRIPT (CFE_SUBSCRIPT | CFE_SUPERSCRIPT) #define CFM_SUPERSCRIPT CFM_SUBSCRIPT // CHARFORMAT "ALL" masks #define CFM_EFFECTS (CFM_BOLD | CFM_ITALIC | CFM_UNDERLINE | CFM_COLOR | \ CFM_STRIKEOUT | CFE_PROTECTED | CFM_LINK) #define CFM_ALL (CFM_EFFECTS | CFM_SIZE | CFM_FACE | CFM_OFFSET | CFM_CHARSET) #define CFM_EFFECTS2 (CFM_EFFECTS | CFM_DISABLED | CFM_SMALLCAPS | CFM_ALLCAPS \ | CFM_HIDDEN | CFM_OUTLINE | CFM_SHADOW | CFM_EMBOSS \ | CFM_IMPRINT | CFM_REVISED \ | CFM_SUBSCRIPT | CFM_SUPERSCRIPT | CFM_BACKCOLOR) #if (_RICHEDIT_VER >= 0x0600) #define CFM_ALL2 (CFM_ALL | CFM_EFFECTS2 | CFM_BACKCOLOR | CFM_LCID \ | CFM_UNDERLINETYPE | CFM_WEIGHT | CFM_REVAUTHOR \ | CFM_SPACING | CFM_KERNING | CFM_STYLE | CFM_ANIMATION \ | CFM_COOKIE) #else #define CFM_ALL2 (CFM_ALL | CFM_EFFECTS2 | CFM_BACKCOLOR | CFM_LCID \ | CFM_UNDERLINETYPE | CFM_WEIGHT | CFM_REVAUTHOR \ | CFM_SPACING | CFM_KERNING | CFM_STYLE | CFM_ANIMATION) #endif #define CFE_SMALLCAPS CFM_SMALLCAPS #define CFE_ALLCAPS CFM_ALLCAPS #define CFE_HIDDEN CFM_HIDDEN #define CFE_OUTLINE CFM_OUTLINE #define CFE_SHADOW CFM_SHADOW #define CFE_EMBOSS CFM_EMBOSS #define CFE_IMPRINT CFM_IMPRINT #define CFE_DISABLED CFM_DISABLED #define CFE_REVISED CFM_REVISED // CFE_AUTOCOLOR and CFE_AUTOBACKCOLOR correspond to CFM_COLOR and // CFM_BACKCOLOR, respectively, which control them #define CFE_AUTOBACKCOLOR CFM_BACKCOLOR #define CFM_FONTBOUND 0x00100000 #define CFM_LINKPROTECTED 0x00800000 // Word hyperlink field #define CFM_EXTENDED 0x02000000 #define CFM_MATHNOBUILDUP 0x08000000 #define CFM_MATH 0x10000000 #define CFM_MATHORDINARY 0x20000000 #define CFM_ALLEFFECTS (CFM_EFFECTS2 | CFM_FONTBOUND | CFM_EXTENDED | CFM_MATHNOBUILDUP | CFM_MATH | CFM_MATHORDINARY) #define CFE_FONTBOUND 0x00100000 // Font chosen by binder, not user #define CFE_LINKPROTECTED 0x00800000 #define CFE_EXTENDED 0x02000000 #define CFE_MATHNOBUILDUP 0x08000000 #define CFE_MATH 0x10000000 #define CFE_MATHORDINARY 0x20000000 // Underline types. RE 1.0 displays only CFU_UNDERLINE #define CFU_CF1UNDERLINE 0xFF // Map charformat's bit underline to CF2 #define CFU_INVERT 0xFE // For IME composition fake a selection #define CFU_UNDERLINETHICKLONGDASH 18 // (*) display as dash #define CFU_UNDERLINETHICKDOTTED 17 // (*) display as dot #define CFU_UNDERLINETHICKDASHDOTDOT 16 // (*) display as dash dot dot #define CFU_UNDERLINETHICKDASHDOT 15 // (*) display as dash dot #define CFU_UNDERLINETHICKDASH 14 // (*) display as dash #define CFU_UNDERLINELONGDASH 13 // (*) display as dash #define CFU_UNDERLINEHEAVYWAVE 12 // (*) display as wave #define CFU_UNDERLINEDOUBLEWAVE 11 // (*) display as wave #define CFU_UNDERLINEHAIRLINE 10 // (*) display as single #define CFU_UNDERLINETHICK 9 #define CFU_UNDERLINEWAVE 8 #define CFU_UNDERLINEDASHDOTDOT 7 #define CFU_UNDERLINEDASHDOT 6 #define CFU_UNDERLINEDASH 5 #define CFU_UNDERLINEDOTTED 4 #define CFU_UNDERLINEDOUBLE 3 // (*) display as single #define CFU_UNDERLINEWORD 2 // (*) display as single #define CFU_UNDERLINE 1 #define CFU_UNDERLINENONE 0 #define yHeightCharPtsMost 1638 // EM_SETCHARFORMAT wParam masks #define SCF_SELECTION 0x0001 #define SCF_WORD 0x0002 #define SCF_DEFAULT 0x0000 // Set default charformat or paraformat #define SCF_ALL 0x0004 // Not valid with SCF_SELECTION or SCF_WORD #define SCF_USEUIRULES 0x0008 // Modifier for SCF_SELECTION; says that // format came from a toolbar, etc., and // hence UI formatting rules should be // used instead of literal formatting #define SCF_ASSOCIATEFONT 0x0010 // Associate fontname with bCharSet (one // possible for each of Western, ME, FE, // Thai) #define SCF_NOKBUPDATE 0x0020 // Do not update KB layout for this change // even if autokeyboard is on #define SCF_ASSOCIATEFONT2 0x0040 // Associate plane-2 (surrogate) font #if (_RICHEDIT_VER >= 0x0500) #define SCF_SMARTFONT 0x0080 // Apply font only if it can handle script (5.0) #define SCF_CHARREPFROMLCID 0x0100 // Get character repertoire from lcid (5.0) #define SPF_DONTSETDEFAULT 0x0002 // Suppress setting default on empty control #define SPF_SETDEFAULT 0x0004 // Set the default paraformat #endif typedef struct _charrange { LONG cpMin; LONG cpMax; } CHARRANGE; typedef struct _textrange { CHARRANGE chrg; LPSTR lpstrText; // Allocated by caller, zero terminated by RichEdit } TEXTRANGEA; typedef struct _textrangew { CHARRANGE chrg; LPWSTR lpstrText; // Allocated by caller, zero terminated by RichEdit } TEXTRANGEW; #if (_RICHEDIT_VER >= 0x0200) #ifdef UNICODE #define TEXTRANGE TEXTRANGEW #else #define TEXTRANGE TEXTRANGEA #endif // UNICODE #else #define TEXTRANGE TEXTRANGEA #endif // _RICHEDIT_VER >= 0x0200 typedef DWORD (CALLBACK *EDITSTREAMCALLBACK)(DWORD_PTR dwCookie, LPBYTE pbBuff, LONG cb, LONG *pcb); typedef struct _editstream { DWORD_PTR dwCookie; // User value passed to callback as first parameter DWORD dwError; // Last error EDITSTREAMCALLBACK pfnCallback; } EDITSTREAM; // Stream formats. Flags are all in low word, since high word // gives possible codepage choice. #define SF_TEXT 0x0001 #define SF_RTF 0x0002 #define SF_RTFNOOBJS 0x0003 // Write only #define SF_TEXTIZED 0x0004 // Write only #define SF_UNICODE 0x0010 // Unicode file (UCS2 little endian) #define SF_USECODEPAGE 0x0020 // CodePage given by high word #define SF_NCRFORNONASCII 0x40 // Output \uN for nonASCII #define SFF_WRITEXTRAPAR 0x80 // Output \par at end // Flag telling stream operations to operate on selection only // EM_STREAMIN replaces current selection // EM_STREAMOUT streams out current selection #define SFF_SELECTION 0x8000 // Flag telling stream operations to ignore some FE control words // having to do with FE word breaking and horiz vs vertical text. // Not used in RichEdit 2.0 and later #define SFF_PLAINRTF 0x4000 // Flag telling file stream output (SFF_SELECTION flag not set) to persist // \viewscaleN control word. #define SFF_PERSISTVIEWSCALE 0x2000 // Flag telling file stream input with SFF_SELECTION flag not set not to // close the document #define SFF_KEEPDOCINFO 0x1000 // Flag telling stream operations to output in Pocket Word format #define SFF_PWD 0x0800 // 3-bit field specifying the value of N - 1 to use for \rtfN or \pwdN #define SF_RTFVAL 0x0700 typedef struct _findtext { CHARRANGE chrg; LPCSTR lpstrText; } FINDTEXTA; typedef struct _findtextw { CHARRANGE chrg; LPCWSTR lpstrText; } FINDTEXTW; #if (_RICHEDIT_VER >= 0x0200) #ifdef UNICODE #define FINDTEXT FINDTEXTW #else #define FINDTEXT FINDTEXTA #endif // UNICODE #else #define FINDTEXT FINDTEXTA #endif // _RICHEDIT_VER >= 0x0200 typedef struct _findtextexa { CHARRANGE chrg; LPCSTR lpstrText; CHARRANGE chrgText; } FINDTEXTEXA; typedef struct _findtextexw { CHARRANGE chrg; LPCWSTR lpstrText; CHARRANGE chrgText; } FINDTEXTEXW; #if (_RICHEDIT_VER >= 0x0200) #ifdef UNICODE #define FINDTEXTEX FINDTEXTEXW #else #define FINDTEXTEX FINDTEXTEXA #endif // UNICODE #else #define FINDTEXTEX FINDTEXTEXA #endif // _RICHEDIT_VER >= 0x0200 typedef struct _formatrange { HDC hdc; HDC hdcTarget; RECT rc; RECT rcPage; CHARRANGE chrg; } FORMATRANGE; // All paragraph measurements are in twips #define MAX_TAB_STOPS 32 #define lDefaultTab 720 #define MAX_TABLE_CELLS 63 typedef struct _paraformat { UINT cbSize; DWORD dwMask; WORD wNumbering; union { WORD wReserved; WORD wEffects; }; LONG dxStartIndent; LONG dxRightIndent; LONG dxOffset; WORD wAlignment; SHORT cTabCount; LONG rgxTabs[MAX_TAB_STOPS]; } PARAFORMAT; #ifdef __cplusplus struct PARAFORMAT2 : _paraformat { LONG dySpaceBefore; // Vertical spacing before para LONG dySpaceAfter; // Vertical spacing after para LONG dyLineSpacing; // Line spacing depending on Rule SHORT sStyle; // Style handle BYTE bLineSpacingRule; // Rule for line spacing (see tom.doc) BYTE bOutlineLevel; // Outline level WORD wShadingWeight; // Shading in hundredths of a per cent WORD wShadingStyle; // Nibble 0: style, 1: cfpat, 2: cbpat WORD wNumberingStart; // Starting value for numbering WORD wNumberingStyle; // Alignment, roman/arabic, (), ), ., etc. WORD wNumberingTab; // Space bet FirstIndent & 1st-line text WORD wBorderSpace; // Border-text spaces (nbl/bdr in pts) WORD wBorderWidth; // Pen widths (nbl/bdr in half pts) WORD wBorders; // Border styles (nibble/border) }; #else // Regular C-style typedef struct _paraformat2 { UINT cbSize; DWORD dwMask; WORD wNumbering; union { WORD wReserved; WORD wEffects; }; LONG dxStartIndent; LONG dxRightIndent; LONG dxOffset; WORD wAlignment; SHORT cTabCount; LONG rgxTabs[MAX_TAB_STOPS]; LONG dySpaceBefore; // Vertical spacing before para LONG dySpaceAfter; // Vertical spacing after para LONG dyLineSpacing; // Line spacing depending on Rule SHORT sStyle; // Style handle BYTE bLineSpacingRule; // Rule for line spacing (see tom.doc) BYTE bOutlineLevel; // Outline Level WORD wShadingWeight; // Shading in hundredths of a per cent WORD wShadingStyle; // Byte 0: style, nib 2: cfpat, 3: cbpat WORD wNumberingStart; // Starting value for numbering WORD wNumberingStyle; // Alignment, Roman/Arabic, (), ), ., etc. WORD wNumberingTab; // Space bet 1st indent and 1st-line text WORD wBorderSpace; // Border-text spaces (nbl/bdr in pts) WORD wBorderWidth; // Pen widths (nbl/bdr in half twips) WORD wBorders; // Border styles (nibble/border) } PARAFORMAT2; #endif // C++ // PARAFORMAT mask values #define PFM_STARTINDENT 0x00000001 #define PFM_RIGHTINDENT 0x00000002 #define PFM_OFFSET 0x00000004 #define PFM_ALIGNMENT 0x00000008 #define PFM_TABSTOPS 0x00000010 #define PFM_NUMBERING 0x00000020 #define PFM_OFFSETINDENT 0x80000000 // PARAFORMAT 2.0 masks and effects #define PFM_SPACEBEFORE 0x00000040 #define PFM_SPACEAFTER 0x00000080 #define PFM_LINESPACING 0x00000100 #define PFM_STYLE 0x00000400 #define PFM_BORDER 0x00000800 // (*) #define PFM_SHADING 0x00001000 // (*) #define PFM_NUMBERINGSTYLE 0x00002000 // RE 3.0 #define PFM_NUMBERINGTAB 0x00004000 // RE 3.0 #define PFM_NUMBERINGSTART 0x00008000 // RE 3.0 #define PFM_RTLPARA 0x00010000 #define PFM_KEEP 0x00020000 // (*) #define PFM_KEEPNEXT 0x00040000 // (*) #define PFM_PAGEBREAKBEFORE 0x00080000 // (*) #define PFM_NOLINENUMBER 0x00100000 // (*) #define PFM_NOWIDOWCONTROL 0x00200000 // (*) #define PFM_DONOTHYPHEN 0x00400000 // (*) #define PFM_SIDEBYSIDE 0x00800000 // (*) // The following three properties are read only #define PFM_COLLAPSED 0x01000000 // RE 3.0 #define PFM_OUTLINELEVEL 0x02000000 // RE 3.0 #define PFM_BOX 0x04000000 // RE 3.0 #define PFM_RESERVED2 0x08000000 // RE 4.0 #define PFM_TABLEROWDELIMITER 0x10000000 // RE 4.0 #define PFM_TEXTWRAPPINGBREAK 0x20000000 // RE 3.0 #define PFM_TABLE 0x40000000 // RE 3.0 // PARAFORMAT "ALL" masks #define PFM_ALL (PFM_STARTINDENT | PFM_RIGHTINDENT | PFM_OFFSET | \ PFM_ALIGNMENT | PFM_TABSTOPS | PFM_NUMBERING | \ PFM_OFFSETINDENT| PFM_RTLPARA) // Note: PARAFORMAT has no effects (BiDi RichEdit 1.0 does have PFE_RTLPARA) #define PFM_EFFECTS (PFM_RTLPARA | PFM_KEEP | PFM_KEEPNEXT | PFM_TABLE \ | PFM_PAGEBREAKBEFORE | PFM_NOLINENUMBER \ | PFM_NOWIDOWCONTROL | PFM_DONOTHYPHEN | PFM_SIDEBYSIDE \ | PFM_TABLE | PFM_TABLEROWDELIMITER) #define PFM_ALL2 (PFM_ALL | PFM_EFFECTS | PFM_SPACEBEFORE | PFM_SPACEAFTER \ | PFM_LINESPACING | PFM_STYLE | PFM_SHADING | PFM_BORDER \ | PFM_NUMBERINGTAB | PFM_NUMBERINGSTART | PFM_NUMBERINGSTYLE) #define PFE_RTLPARA (PFM_RTLPARA >> 16) #define PFE_KEEP (PFM_KEEP >> 16) // (*) #define PFE_KEEPNEXT (PFM_KEEPNEXT >> 16) // (*) #define PFE_PAGEBREAKBEFORE (PFM_PAGEBREAKBEFORE >> 16) // (*) #define PFE_NOLINENUMBER (PFM_NOLINENUMBER >> 16) // (*) #define PFE_NOWIDOWCONTROL (PFM_NOWIDOWCONTROL >> 16) // (*) #define PFE_DONOTHYPHEN (PFM_DONOTHYPHEN >> 16) // (*) #define PFE_SIDEBYSIDE (PFM_SIDEBYSIDE >> 16) // (*) #define PFE_TEXTWRAPPINGBREAK (PFM_TEXTWRAPPINGBREAK>>16) // (*) // The following four effects are read only #define PFE_COLLAPSED (PFM_COLLAPSED >> 16) // (+) #define PFE_BOX (PFM_BOX >> 16) // (+) #define PFE_TABLE (PFM_TABLE >> 16) // Inside table row. RE 3.0 #define PFE_TABLEROWDELIMITER (PFM_TABLEROWDELIMITER>>16) // Table row start. RE 4.0 // PARAFORMAT numbering options #define PFN_BULLET 1 // tomListBullet // PARAFORMAT2 wNumbering options #define PFN_ARABIC 2 // tomListNumberAsArabic: 0, 1, 2, ... #define PFN_LCLETTER 3 // tomListNumberAsLCLetter: a, b, c, ... #define PFN_UCLETTER 4 // tomListNumberAsUCLetter: A, B, C, ... #define PFN_LCROMAN 5 // tomListNumberAsLCRoman: i, ii, iii, ... #define PFN_UCROMAN 6 // tomListNumberAsUCRoman: I, II, III, ... // PARAFORMAT2 wNumberingStyle options #define PFNS_PAREN 0x000 // default, e.g., 1) #define PFNS_PARENS 0x100 // tomListParentheses/256, e.g., (1) #define PFNS_PERIOD 0x200 // tomListPeriod/256, e.g., 1. #define PFNS_PLAIN 0x300 // tomListPlain/256, e.g., 1 #define PFNS_NONUMBER 0x400 // Used for continuation w/o number #define PFNS_NEWNUMBER 0x8000 // Start new number with wNumberingStart // (can be combined with other PFNS_xxx) // PARAFORMAT alignment options #define PFA_LEFT 1 #define PFA_RIGHT 2 #define PFA_CENTER 3 // PARAFORMAT2 alignment options #define PFA_JUSTIFY 4 // New paragraph-alignment option 2.0 (*) #define PFA_FULL_INTERWORD 4 // These are supported in 3.0 with advanced // Notification structures #ifndef WM_NOTIFY #define WM_NOTIFY 0x004E typedef struct _nmhdr { HWND hwndFrom; UINT idFrom; UINT code; } NMHDR; #endif // !WM_NOTIFY typedef struct _msgfilter { NMHDR nmhdr; UINT msg; WPARAM wParam; LPARAM lParam; } MSGFILTER; typedef struct _reqresize { NMHDR nmhdr; RECT rc; } REQRESIZE; typedef struct _selchange { NMHDR nmhdr; CHARRANGE chrg; WORD seltyp; } SELCHANGE; #if (_RICHEDIT_VER >= 0x0800) typedef struct _grouptypingchange { NMHDR nmhdr; BOOL fGroupTyping; } GROUPTYPINGCHANGE; #endif typedef struct _clipboardformat { NMHDR nmhdr; CLIPFORMAT cf; } CLIPBOARDFORMAT; #define SEL_EMPTY 0x0000 #define SEL_TEXT 0x0001 #define SEL_OBJECT 0x0002 #define SEL_MULTICHAR 0x0004 #define SEL_MULTIOBJECT 0x0008 // Used with IRichEditOleCallback::GetContextMenu, this flag will be // passed as a "selection type". It indicates that a context menu for // a right-mouse drag drop should be generated. The IOleObject parameter // will really be the IDataObject for the drop #define GCM_RIGHTMOUSEDROP 0x8000 #if (_RICHEDIT_VER >= 0x0800) typedef struct _getcontextmenuex { CHARRANGE chrg; DWORD dwFlags; POINT pt; void* pvReserved; } GETCONTEXTMENUEX; // bits for GETCONTEXTMENUEX::dwFlags #define GCMF_GRIPPER 0x00000001 #define GCMF_SPELLING 0x00000002 // pSpellingSuggestions is valid // and points to the list of spelling suggestions #define GCMF_TOUCHMENU 0x00004000 #define GCMF_MOUSEMENU 0x00002000 #endif typedef struct _endropfiles { NMHDR nmhdr; HANDLE hDrop; LONG cp; BOOL fProtected; } ENDROPFILES; typedef struct _enprotected { NMHDR nmhdr; UINT msg; WPARAM wParam; LPARAM lParam; CHARRANGE chrg; } ENPROTECTED; typedef struct _ensaveclipboard { NMHDR nmhdr; LONG cObjectCount; LONG cch; } ENSAVECLIPBOARD; #ifndef MACPORT typedef struct _enoleopfailed { NMHDR nmhdr; LONG iob; LONG lOper; HRESULT hr; } ENOLEOPFAILED; #endif #define OLEOP_DOVERB 1 typedef struct _objectpositions { NMHDR nmhdr; LONG cObjectCount; LONG *pcpPositions; } OBJECTPOSITIONS; typedef struct _enlink { NMHDR nmhdr; UINT msg; WPARAM wParam; LPARAM lParam; CHARRANGE chrg; } ENLINK; typedef struct _enlowfirtf { NMHDR nmhdr; char *szControl; } ENLOWFIRTF; // PenWin specific typedef struct _encorrecttext { NMHDR nmhdr; CHARRANGE chrg; WORD seltyp; } ENCORRECTTEXT; // East Asia specific typedef struct _punctuation { UINT iSize; LPSTR szPunctuation; } PUNCTUATION; // East Asia specific typedef struct _compcolor { COLORREF crText; COLORREF crBackground; DWORD dwEffects; }COMPCOLOR; // Clipboard formats - use as parameter to RegisterClipboardFormat() #define CF_RTF TEXT("Rich Text Format") #define CF_RTFNOOBJS TEXT("Rich Text Format Without Objects") #define CF_RETEXTOBJ TEXT("RichEdit Text and Objects") // Paste Special typedef struct _repastespecial { DWORD dwAspect; DWORD_PTR dwParam; } REPASTESPECIAL; // UndoName info typedef enum _undonameid { UID_UNKNOWN = 0, UID_TYPING = 1, UID_DELETE = 2, UID_DRAGDROP = 3, UID_CUT = 4, UID_PASTE = 5, UID_AUTOTABLE = 6 } UNDONAMEID; // Flags for the SETEXTEX data structure #define ST_DEFAULT 0 #define ST_KEEPUNDO 1 #define ST_SELECTION 2 #define ST_NEWCHARS 4 #if (_RICHEDIT_VER >= 0x0500) #define ST_UNICODE 8 #endif // EM_SETTEXTEX info; this struct is passed in the wparam of the message typedef struct _settextex { DWORD flags; // Flags (see the ST_XXX defines) UINT codepage; // Code page for translation (CP_ACP for sys default, // 1200 for Unicode, -1 for control default) } SETTEXTEX; // Flags for the GETEXTEX data structure #define GT_DEFAULT 0 #define GT_USECRLF 1 #define GT_SELECTION 2 #define GT_RAWTEXT 4 #define GT_NOHIDDENTEXT 8 // EM_GETTEXTEX info; this struct is passed in the wparam of the message typedef struct _gettextex { DWORD cb; // Count of bytes in the string DWORD flags; // Flags (see the GT_XXX defines UINT codepage; // Code page for translation (CP_ACP for sys default, // 1200 for Unicode, -1 for control default) LPCSTR lpDefaultChar; // Replacement for unmappable chars LPBOOL lpUsedDefChar; // Pointer to flag set when def char used } GETTEXTEX; // Flags for the GETTEXTLENGTHEX data structure #define GTL_DEFAULT 0 // Do default (return # of chars) #define GTL_USECRLF 1 // Compute answer using CRLFs for paragraphs #define GTL_PRECISE 2 // Compute a precise answer #define GTL_CLOSE 4 // Fast computation of a "close" answer #define GTL_NUMCHARS 8 // Return number of characters #define GTL_NUMBYTES 16 // Return number of _bytes_ // EM_GETTEXTLENGTHEX info; this struct is passed in the wparam of the msg typedef struct _gettextlengthex { DWORD flags; // Flags (see GTL_XXX defines) UINT codepage; // Code page for translation (CP_ACP for default, // 1200 for Unicode) } GETTEXTLENGTHEX; // BiDi specific features typedef struct _bidioptions { UINT cbSize; WORD wMask; WORD wEffects; } BIDIOPTIONS; // BIDIOPTIONS masks #if (_RICHEDIT_VER == 0x0100) #define BOM_DEFPARADIR 0x0001 // Default paragraph direction (implies alignment) (obsolete) #define BOM_PLAINTEXT 0x0002 // Use plain text layout (obsolete) #endif // _RICHEDIT_VER == 0x0100 #define BOM_NEUTRALOVERRIDE 0x0004 // Override neutral layout (obsolete) #define BOM_CONTEXTREADING 0x0008 // Context reading order #define BOM_CONTEXTALIGNMENT 0x0010 // Context alignment #define BOM_LEGACYBIDICLASS 0x0040 // Legacy Bidi classification (obsolete) #if (_RICHEDIT_VER >= 0x0600) #define BOM_UNICODEBIDI 0x0080 // Use Unicode BiDi algorithm #endif // BIDIOPTIONS effects #if (_RICHEDIT_VER == 0x0100) #define BOE_RTLDIR 0x0001 // Default paragraph direction (implies alignment) (obsolete) #define BOE_PLAINTEXT 0x0002 // Use plain text layout (obsolete) #endif // _RICHEDIT_VER == 0x0100 #define BOE_NEUTRALOVERRIDE 0x0004 // Override neutral layout (obsolete) #define BOE_CONTEXTREADING 0x0008 // Context reading order #define BOE_CONTEXTALIGNMENT 0x0010 // Context alignment #if (_RICHEDIT_VER >= 0x0800) #define BOE_FORCERECALC 0x0020 // Force recalc and redraw #endif #define BOE_LEGACYBIDICLASS 0x0040 // Legacy Bidi classification (obsolete) #if (_RICHEDIT_VER >= 0x0600) #define BOE_UNICODEBIDI 0x0080 // Use Unicode BiDi algorithm #endif // Additional EM_FINDTEXT[EX] flags #define FR_MATCHDIAC 0x20000000 #define FR_MATCHKASHIDA 0x40000000 #define FR_MATCHALEFHAMZA 0x80000000 // UNICODE embedding character #ifndef WCH_EMBEDDING #define WCH_EMBEDDING (wchar_t)0xFFFC #endif // WCH_EMBEDDING // khyph - Kind of hyphenation typedef enum tagKHYPH { khyphNil, // No Hyphenation khyphNormal, // Normal Hyphenation khyphAddBefore, // Add letter before hyphen khyphChangeBefore, // Change letter before hyphen khyphDeleteBefore, // Delete letter before hyphen khyphChangeAfter, // Change letter after hyphen khyphDelAndChange // Delete letter before hyphen and change // letter preceding hyphen } KHYPH; typedef struct hyphresult { KHYPH khyph; // Kind of hyphenation long ichHyph; // Character which was hyphenated wchar_t chHyph; // Depending on hyphenation type, character added, changed, etc. } HYPHRESULT; void WINAPI HyphenateProc(_In_ wchar_t *pszWord, LANGID langid, long ichExceed, HYPHRESULT *phyphresult); typedef struct tagHyphenateInfo { SHORT cbSize; // Size of HYPHENATEINFO structure SHORT dxHyphenateZone; // If a space character is closer to the margin // than this value, don't hyphenate (in TWIPs) void (WINAPI* pfnHyphenate)(wchar_t*, LANGID, long, HYPHRESULT*); } HYPHENATEINFO; #ifdef _WIN32 #include <poppack.h> #elif !defined(RC_INVOKED) #pragma pack() #endif // Additional class for Richedit 6.0 #if (_RICHEDIT_VER >= 0x0600 ) #ifndef RICHEDIT60_CLASS #define RICHEDIT60_CLASS L"RICHEDIT60W" #endif #endif // The following identifiers are deprecated // They were in previous versions of richedit.h #define PFA_FULL_NEWSPAPER 5 // Not implemented #define PFA_FULL_INTERLETTER 6 // Not implemented #define PFA_FULL_SCALED 7 // Not implemented #define PFA_FULL_GLYPHS 8 // Not implemented #define AURL_ENABLEEA 1 // Deprecated: use AURL_ENABLEEAURLS #define GCM_TOUCHMENU 0x4000 // Deprecated: Use GCMF_TOUCHMENU #define GCM_MOUSEMENU 0x2000 // Deprecated: Use GCMF_MOUSEMENU #ifdef __cplusplus } #endif // __cplusplus #endif // !_RICHEDIT_