Format.c 35 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244
  1. /*
  2. * CDE - Common Desktop Environment
  3. *
  4. * Copyright (c) 1993-2012, The Open Group. All rights reserved.
  5. *
  6. * These libraries and programs are free software; you can
  7. * redistribute them and/or modify them under the terms of the GNU
  8. * Lesser General Public License as published by the Free Software
  9. * Foundation; either version 2 of the License, or (at your option)
  10. * any later version.
  11. *
  12. * These libraries and programs are distributed in the hope that
  13. * they will be useful, but WITHOUT ANY WARRANTY; without even the
  14. * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  15. * PURPOSE. See the GNU Lesser General Public License for more
  16. * details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with these libraries and programs; if not, write
  20. * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
  21. * Floor, Boston, MA 02110-1301 USA
  22. */
  23. /* $XConsortium: Format.c /main/18 1996/11/22 12:23:59 cde-hp $ */
  24. /************************************<+>*************************************
  25. ****************************************************************************
  26. **
  27. ** File: Format.c
  28. **
  29. ** Project: Text Graphic Display Library
  30. **
  31. ** Description: This body of formats the input into a form understood by
  32. ** a Display Area.
  33. **
  34. ** (c) Copyright 1987, 1988, 1989, 1990, 1991, 1992 Hewlett-Packard Company
  35. **
  36. ** (c) Copyright 1993, 1994 Hewlett-Packard Company
  37. ** (c) Copyright 1993, 1994 International Business Machines Corp.
  38. ** (c) Copyright 1993, 1994 Sun Microsystems, Inc.
  39. ** (c) Copyright 1993, 1994 Novell, Inc.
  40. **
  41. **
  42. ****************************************************************************
  43. ************************************<+>*************************************/
  44. /*
  45. * system includes
  46. */
  47. #include <stdio.h>
  48. #include <errno.h>
  49. #include <fcntl.h>
  50. #include <locale.h>
  51. #include <stdlib.h>
  52. #include <unistd.h>
  53. #include <X11/Xlib.h>
  54. #include <X11/Xresource.h>
  55. #include <Xm/Xm.h>
  56. #ifdef X_NOT_STDC_ENV
  57. extern int errno;
  58. #endif
  59. /*
  60. * Core Engine includes
  61. */
  62. #include "CanvasP.h"
  63. #include "CanvasSegP.h"
  64. /*
  65. * private includes
  66. */
  67. #include "bufioI.h"
  68. #include "CvtToArrayP.h"
  69. #include "DisplayAreaP.h"
  70. #include "FontAttrI.h"
  71. #include "FontI.h"
  72. #include "HelpXlate.h"
  73. #include "XInterfaceI.h"
  74. #include "Lock.h"
  75. /*
  76. * private core engine
  77. */
  78. #include "Access.h"
  79. #include "AccessP.h"
  80. #include "AccessI.h"
  81. #include "AccessCCDFI.h"
  82. #include "SDLI.h"
  83. #include "FormatUtilI.h"
  84. #include "FormatCCDFI.h"
  85. #include "FormatSDLI.h"
  86. #include "StringFuncsI.h"
  87. #include "FormatI.h"
  88. #ifdef NLS16
  89. #endif
  90. /******** Private Function Declarations ********/
  91. /******** End Public Function Declarations ********/
  92. /******************************************************************************
  93. *
  94. * Private variables and defines.
  95. *
  96. *****************************************************************************/
  97. #define BUFF_SIZE 1024
  98. static char *ScanString = "\n\t";
  99. static const _FrmtUiInfo defUiInfo = { NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 1, False };
  100. /******************************************************************************
  101. *
  102. * Private Functions
  103. *
  104. *****************************************************************************/
  105. /******************************************************************************
  106. * Function: int FormatChunksToXmString ()
  107. *
  108. * Parameters:
  109. * *ret_list may be NULL when called
  110. *
  111. * Returns: 0 if successful, -1 if errors
  112. *
  113. * errno Values:
  114. *
  115. * Purpose: Take some rich text chunks and turn it into an XmString.
  116. *
  117. ******************************************************************************/
  118. static int
  119. FormatChunksToXmString(
  120. DtHelpDispAreaStruct *pDAS,
  121. Boolean free_flag,
  122. void **title_chunks,
  123. XmString *ret_title,
  124. XmFontList *ret_list,
  125. Boolean *ret_mod )
  126. {
  127. int result = 0;
  128. int i;
  129. long j;
  130. int quarkCount;
  131. long chunkType;
  132. long myIdx;
  133. _DtCvPointer fontPtr;
  134. char *charSet;
  135. const char *strChunk;
  136. char buffer[16];
  137. _DtHelpFontHints fontSpecs;
  138. XmFontContext fontContext;
  139. XmString partTitle;
  140. XmString newTitle;
  141. XrmQuark charSetQuark;
  142. XrmName myCharSetQuarks[20];
  143. XrmName xrmName[_CEFontAttrNumber];
  144. Boolean myMore;
  145. /*
  146. * Initialize the pointers.
  147. */
  148. *ret_title = NULL;
  149. *ret_mod = False;
  150. if (title_chunks == NULL)
  151. return -1;
  152. /*
  153. * initialize the font context
  154. */
  155. _DtHelpCeCopyDefFontAttrList(&fontSpecs);
  156. if ( NULL != *ret_list )
  157. {
  158. if (XmFontListInitFontContext (&fontContext, *ret_list) == False)
  159. result = -1;
  160. else
  161. {
  162. XFontStruct *myFontStruct;
  163. /*
  164. * quarkize all the character sets found.
  165. */
  166. quarkCount = 0;
  167. do
  168. {
  169. myMore = XmFontListGetNextFont (fontContext, &charSet,
  170. &myFontStruct);
  171. if (myMore)
  172. {
  173. myCharSetQuarks[quarkCount++] =
  174. XrmStringToQuark (charSet);
  175. XtFree (charSet);
  176. }
  177. } while (myMore);
  178. XmFontListFreeFontContext (fontContext);
  179. }
  180. } /* if NULL != *ret_list */
  181. else
  182. { /* if NULL == *ret_list */
  183. quarkCount = 0;
  184. myCharSetQuarks[0] = 0;
  185. }
  186. /*
  187. * Build the XrmString based on the segments.
  188. * The format of the returned information is
  189. * 'DT_HELP_CE_CHARSET locale string'
  190. * 'DT_HELP_CE_FONT_PTR fontptr string'
  191. * 'DT_HELP_CE_SPC spc'
  192. * 'DT_HELP_CE_STRING string' - uses last specified
  193. * charset/font_ptr.
  194. *
  195. * The order and manner in which the title_chunks are processed
  196. * is known and depended upon in several locations.
  197. * Do not change this without changing the other locations.
  198. * See the _DtHelpFormatxxx() routines and the ones that
  199. * create the title_chunk arrays in FormatSDL.c and FormatCCDF.c
  200. */
  201. myIdx = __DtHelpDefaultFontIndexGet(pDAS);
  202. _DtHelpCopyDefaultList(xrmName);
  203. for (i = 0; result == 0 && title_chunks[i] != DT_HELP_CE_END; i++)
  204. {
  205. /*
  206. * create a string for the char set and a quark for it.
  207. */
  208. chunkType = (long) title_chunks[i++];
  209. /*
  210. * i now points to the first value after the type
  211. */
  212. if (chunkType & DT_HELP_CE_CHARSET)
  213. {
  214. char *charSet;
  215. char *lang = (char *) title_chunks[i];
  216. /*
  217. * test to see if the locale is in a lang.codeset form
  218. */
  219. if (_DtHelpCeStrchr(lang, ".", 1, &charSet) == 0)
  220. {
  221. *charSet = '\0';
  222. charSet++;
  223. }
  224. else
  225. {
  226. charSet = lang;
  227. lang = NULL;
  228. }
  229. /*
  230. * resolve/load the font for the default fonts
  231. */
  232. _DtHelpDAResolveFont(pDAS, lang, charSet, fontSpecs, &fontPtr);
  233. myIdx = (long) fontPtr;
  234. if (lang != NULL)
  235. {
  236. charSet--;
  237. *charSet = '.';
  238. }
  239. if (free_flag)
  240. free(title_chunks[i]);
  241. /*
  242. * move the i to point to the string.
  243. */
  244. i++;
  245. }
  246. else if (chunkType & DT_HELP_CE_FONT_PTR)
  247. {
  248. /*
  249. * get the default font for the language and code set.
  250. */
  251. (void) __DtHelpFontCharSetQuarkGet(pDAS, (long)title_chunks[i],
  252. &xrmName[_DT_HELP_FONT_CHAR_SET]);
  253. (void) __DtHelpFontLangQuarkGet(pDAS, (long)title_chunks[i],
  254. &xrmName[_DT_HELP_FONT_LANG_TER]);
  255. (void) __DtHelpFontIndexGet(pDAS, xrmName, &myIdx);
  256. /*
  257. * move the i to point to the string.
  258. */
  259. i++;
  260. }
  261. /*
  262. * the i point spc or string.
  263. */
  264. if (chunkType & DT_HELP_CE_SPC)
  265. {
  266. j = (long) title_chunks[i];
  267. strChunk = _DtHelpDAGetSpcString(pDAS->spc_chars[j].spc_idx);
  268. fontPtr = pDAS->spc_chars[j].font_ptr;
  269. /*
  270. * get the default font for the language and code set.
  271. */
  272. (void) __DtHelpFontCharSetQuarkGet(pDAS, (long)fontPtr,
  273. &xrmName[_DT_HELP_FONT_CHAR_SET]);
  274. (void) __DtHelpFontLangQuarkGet(pDAS, (long)fontPtr,
  275. &xrmName[_DT_HELP_FONT_LANG_TER]);
  276. (void) __DtHelpFontIndexGet(pDAS, xrmName, &myIdx);
  277. }
  278. else /* if (chunkType & _DT_HELP_CE_STRING) */
  279. strChunk = (char *) title_chunks[i];
  280. sprintf(buffer, "%ld", myIdx);
  281. charSetQuark = XrmStringToQuark(buffer);
  282. j = 0;
  283. while (j < quarkCount && myCharSetQuarks[j] != charSetQuark)
  284. j++;
  285. /*
  286. * If we didn't find a matching character set,
  287. * add it to the list.
  288. */
  289. if (j >= quarkCount)
  290. {
  291. /* Copy the input list so XmFontListAppendEntry can mangle it. */
  292. /* But only do it once! */
  293. if (False == *ret_mod)
  294. *ret_list = XmFontListCopy(*ret_list);
  295. if (myIdx < 0)
  296. {
  297. XFontSet fontSet = __DtHelpFontSetGet(pDAS->font_info, myIdx);
  298. XmFontListEntry fontEntry;
  299. fontEntry = XmFontListEntryCreate (buffer,
  300. XmFONT_IS_FONTSET,
  301. (XtPointer) fontSet);
  302. *ret_list = XmFontListAppendEntry (*ret_list, fontEntry);
  303. XmFontListEntryFree (&fontEntry);
  304. }
  305. else
  306. {
  307. XFontStruct *fontStruct =
  308. __DtHelpFontStructGet(pDAS->font_info, myIdx);
  309. XmFontListEntry fontEntry;
  310. fontEntry = XmFontListEntryCreate (buffer,
  311. XmFONT_IS_FONT,
  312. (XtPointer) fontStruct);
  313. *ret_list = XmFontListAppendEntry (*ret_list, fontEntry);
  314. XmFontListEntryFree (&fontEntry);
  315. }
  316. *ret_mod = True;
  317. if (*ret_list == NULL)
  318. result = -1;
  319. myCharSetQuarks[quarkCount++] = charSetQuark;
  320. }
  321. /*
  322. * add this segment to the XmString.
  323. */
  324. if (result == 0)
  325. {
  326. if (*ret_title == NULL)
  327. *ret_title = XmStringGenerate ((char *) strChunk, buffer,
  328. XmCHARSET_TEXT, NULL);
  329. else
  330. {
  331. partTitle = XmStringGenerate ((char *) strChunk, buffer,
  332. XmCHARSET_TEXT, NULL);
  333. newTitle = XmStringConcat (*ret_title, partTitle);
  334. XmStringFree (*ret_title);
  335. XmStringFree (partTitle);
  336. *ret_title = newTitle;
  337. }
  338. /*
  339. * if a newline was specified,
  340. * replace it with a blank.
  341. */
  342. if (*ret_title != NULL && (chunkType & DT_HELP_CE_NEWLINE))
  343. {
  344. partTitle = XmStringGenerate (" ", buffer, XmCHARSET_TEXT, NULL);
  345. newTitle = XmStringConcat (*ret_title, partTitle);
  346. XmStringFree (*ret_title);
  347. XmStringFree (partTitle);
  348. *ret_title = newTitle;
  349. }
  350. if (*ret_title == NULL)
  351. result = -1;
  352. }
  353. if (free_flag && (chunkType & DT_HELP_CE_STRING))
  354. free(title_chunks[i]);
  355. }
  356. /*
  357. * deallocate the memory.
  358. */
  359. if (free_flag) free(title_chunks);
  360. return result;
  361. }
  362. /******************************************************************************
  363. *
  364. * Semi-Public Functions
  365. *
  366. *****************************************************************************/
  367. /*****************************************************************************
  368. * Function: int _DtHelpFormatAsciiFile (char *filename,
  369. * CEParagraph **ret_para, int *ret_num)
  370. *
  371. * Parameters:
  372. * filename Specifies the ascii file to read.
  373. * ret_para Returns a pointer to a list of CEParagraph
  374. * structures.
  375. * ret_num Returns the number of structures in 'ret_para'.
  376. *
  377. * Returns: 0 if successful, -1 if errors
  378. *
  379. * errno Values:
  380. * EINVAL
  381. *
  382. * Purpose: _DtHelpFormatAsciiFile formats Ascii Files into a list of
  383. * CEParagraph structures.
  384. *
  385. *****************************************************************************/
  386. int
  387. _DtHelpFormatAsciiFile(
  388. XtPointer client_data,
  389. char *filename,
  390. XtPointer *ret_handle)
  391. {
  392. int myFile;
  393. int result = -1;
  394. _DtHelpFontHints fontAttrs;
  395. char buffer [BUFF_SIZE];
  396. BufFilePtr rawInput;
  397. XtPointer varHandle;
  398. _DtCvTopicPtr topic = NULL;
  399. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  400. _FrmtUiInfo myUiInfo = defUiInfo;
  401. /*
  402. * check the parameters
  403. */
  404. if (filename == NULL || ret_handle == NULL)
  405. {
  406. errno = EINVAL;
  407. return -1;
  408. }
  409. /*
  410. * Initialize the pointers, buffers and counters
  411. */
  412. *ret_handle = NULL;
  413. /*
  414. * open the file.
  415. */
  416. myFile = open (filename, O_RDONLY);
  417. if (myFile != -1)
  418. {
  419. /*
  420. * set the information
  421. */
  422. rawInput = _DtHelpCeBufFileRdWithFd(myFile);
  423. if (rawInput == 0)
  424. {
  425. close (myFile);
  426. return -1;
  427. }
  428. result = _DtHelpCeReadBuf (rawInput, buffer, BUFF_SIZE);
  429. if (result != -1)
  430. {
  431. _DtHelpCeCopyDefFontAttrList (&fontAttrs);
  432. fontAttrs.spacing = _DtHelpFontSpacingMono;
  433. _DtHelpCeXlateOpToStdLocale(DtLCX_OPER_SETLOCALE,
  434. setlocale(LC_CTYPE,NULL), NULL,
  435. &(fontAttrs.language), &(fontAttrs.char_set));
  436. /*
  437. * fill out the ui information
  438. */
  439. myUiInfo.load_font = _DtHelpDAResolveFont;
  440. myUiInfo.client_data = (_DtCvPointer) pDAS;
  441. myUiInfo.line_width = pDAS->lineThickness;
  442. myUiInfo.line_height = pDAS->lineHeight;
  443. myUiInfo.leading = pDAS->leading;
  444. myUiInfo.avg_char = (int)(pDAS->charWidth / 10 +
  445. ((pDAS->charWidth % 10) ? 1 : 0));
  446. myUiInfo.nl_to_space = pDAS->nl_to_space;
  447. /*
  448. * get the formatting structure.
  449. */
  450. varHandle = __DtHelpCeSetUpVars(fontAttrs.language,
  451. fontAttrs.char_set, &myUiInfo);
  452. if (varHandle == NULL)
  453. {
  454. free(fontAttrs.language);
  455. free(fontAttrs.char_set);
  456. return -1;
  457. }
  458. result = __DtHelpCeProcessString (varHandle, rawInput,
  459. _DtCvLITERAL,
  460. ScanString, buffer, BUFF_SIZE,
  461. 0, False, &fontAttrs);
  462. if (result != -1)
  463. result = __DtHelpCeGetParagraphList (varHandle, True,
  464. _DtCvLITERAL,
  465. &topic);
  466. free(fontAttrs.language);
  467. free(fontAttrs.char_set);
  468. free(varHandle);
  469. }
  470. _DtHelpCeBufFileClose(rawInput, True);
  471. }
  472. *ret_handle = (XtPointer) topic;
  473. return result;
  474. } /* End _DtHelpFormatAsciiFile */
  475. /*****************************************************************************
  476. * Function: int _DtHelpFormatAsciiString (char *input_string,
  477. * CEParagraph **ret_para, int *ret_num)
  478. *
  479. * Parameters:
  480. * input_string Specifies the ascii string to format.
  481. * ret_para Returns a pointer to a list of CEParagraph
  482. * structures.
  483. * ret_num Returns the number of structures in 'ret_para'.
  484. *
  485. * Returns: 0 if successful, -1 if errors
  486. *
  487. * errno Values:
  488. *
  489. * Purpose: _DtHelpFormatAsciiString formats a string as if it were a
  490. * static string - watching for newlines and using them
  491. * to force a break in the line.
  492. *
  493. *****************************************************************************/
  494. int
  495. _DtHelpFormatAsciiString(
  496. XtPointer client_data,
  497. char *input_string,
  498. XtPointer *ret_handle)
  499. {
  500. int result = -1;
  501. _DtHelpFontHints fontAttrs;
  502. XtPointer varHandle;
  503. _DtCvTopicPtr topic = NULL;
  504. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  505. _FrmtUiInfo myUiInfo = defUiInfo;
  506. /*
  507. * check the parameters.
  508. */
  509. if (input_string == NULL || ret_handle == NULL)
  510. {
  511. errno = EINVAL;
  512. return -1;
  513. }
  514. /*
  515. * fill out the ui information
  516. */
  517. myUiInfo.load_font = _DtHelpDAResolveFont;
  518. myUiInfo.client_data = (_DtCvPointer) pDAS;
  519. myUiInfo.line_width = pDAS->lineThickness;
  520. myUiInfo.line_height = pDAS->lineHeight;
  521. myUiInfo.leading = pDAS->leading;
  522. myUiInfo.avg_char = (int)(pDAS->charWidth / 10 +
  523. ((pDAS->charWidth % 10) ? 1 : 0));
  524. myUiInfo.nl_to_space = pDAS->nl_to_space;
  525. /*
  526. * Get the initialized variables
  527. */
  528. *ret_handle = NULL;
  529. _DtHelpCeCopyDefFontAttrList (&fontAttrs);
  530. _DtHelpCeXlateOpToStdLocale(DtLCX_OPER_SETLOCALE,setlocale(LC_CTYPE,NULL),
  531. NULL, &(fontAttrs.language),
  532. &(fontAttrs.char_set));
  533. varHandle = __DtHelpCeSetUpVars(fontAttrs.language, fontAttrs.char_set,
  534. &myUiInfo);
  535. if (varHandle == NULL)
  536. {
  537. free(fontAttrs.language);
  538. free(fontAttrs.char_set);
  539. return -1;
  540. }
  541. result = __DtHelpCeProcessString (varHandle, NULL,
  542. _DtCvLITERAL,
  543. ScanString, input_string,
  544. strlen(input_string),
  545. 0, False,
  546. &fontAttrs);
  547. if (result != -1)
  548. result = __DtHelpCeGetParagraphList (varHandle, True, _DtCvLITERAL,
  549. &topic);
  550. *ret_handle = (XtPointer) topic;
  551. free(fontAttrs.language);
  552. free(fontAttrs.char_set);
  553. free(varHandle);
  554. return result;
  555. } /* End _DtHelpFormatAsciiString */
  556. /*****************************************************************************
  557. * Function: int _DtHelpFormatAsciiStringDynamic (char *input_string,
  558. * CEParagraph **ret_para, int *ret_num)
  559. *
  560. * Parameters:
  561. * input_string Specifies the ascii string to format.
  562. * ret_para Returns a pointer to a list of CEParagraph
  563. * structures.
  564. * ret_num Returns the number of structures in 'ret_para'.
  565. *
  566. * Returns: 0 if successful, -1 if errors
  567. *
  568. * errno Values:
  569. *
  570. * Purpose: _DtHelpFormatAsciiStringDynamic formats a string as if it were
  571. * a dynamic string - it uses newline characters to terminate
  572. * the current paragraph, not a line.
  573. *
  574. *****************************************************************************/
  575. int
  576. _DtHelpFormatAsciiStringDynamic(
  577. XtPointer client_data,
  578. char *input_string,
  579. XtPointer *ret_handle)
  580. {
  581. int result = -1;
  582. _DtHelpFontHints fontAttrs;
  583. XtPointer varHandle;
  584. _DtCvTopicPtr topic = NULL;
  585. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  586. _FrmtUiInfo myUiInfo = defUiInfo;
  587. /*
  588. * check the parameters.
  589. */
  590. if (input_string == NULL || ret_handle == NULL)
  591. {
  592. errno = EINVAL;
  593. return -1;
  594. }
  595. /*
  596. * fill out the ui information
  597. */
  598. myUiInfo.load_font = _DtHelpDAResolveFont;
  599. myUiInfo.client_data = (_DtCvPointer) pDAS;
  600. myUiInfo.line_width = pDAS->lineThickness;
  601. myUiInfo.line_height = pDAS->lineHeight;
  602. myUiInfo.leading = pDAS->leading;
  603. myUiInfo.avg_char = (int)(pDAS->charWidth / 10 +
  604. ((pDAS->charWidth % 10) ? 1 : 0));
  605. myUiInfo.nl_to_space = pDAS->nl_to_space;
  606. /*
  607. * Fake the flag and give the string as the input buffer.
  608. */
  609. *ret_handle = NULL;
  610. _DtHelpCeCopyDefFontAttrList (&fontAttrs);
  611. _DtHelpCeXlateOpToStdLocale(DtLCX_OPER_SETLOCALE,setlocale(LC_CTYPE,NULL),
  612. NULL, &(fontAttrs.language),
  613. &(fontAttrs.char_set));
  614. varHandle = __DtHelpCeSetUpVars(fontAttrs.language, fontAttrs.char_set,
  615. &myUiInfo);
  616. if (varHandle == NULL)
  617. {
  618. free(fontAttrs.language);
  619. free(fontAttrs.char_set);
  620. return -1;
  621. }
  622. result = __DtHelpCeProcessString (varHandle, NULL,
  623. _DtCvDYNAMIC,
  624. ScanString, input_string,
  625. strlen(input_string),
  626. 0, True,
  627. &fontAttrs);
  628. if (result != -1)
  629. result = __DtHelpCeGetParagraphList (varHandle, False, _DtCvDYNAMIC,
  630. &topic);
  631. *ret_handle = (XtPointer) topic;
  632. free(fontAttrs.language);
  633. free(fontAttrs.char_set);
  634. free(varHandle);
  635. return result;
  636. } /* End _DtHelpFormatAsciiStringDynamic */
  637. /******************************************************************************
  638. * Function: int _DtHelpFormatTopicTitle (Display *dpy, _XvhVolume volume,
  639. * char *filename, int offset,
  640. * XmString *ret_title, XmFontList *ret_list,
  641. * Boolean *ret_mod)
  642. *
  643. * Parameters:
  644. * dpy Specifies the connection to the server.
  645. * volume Specifies the Help Volume the information
  646. * is associated with.
  647. * filename Specifies the file containing the Help Topic
  648. * desired.
  649. * offset Specifies the offset into 'filename' to
  650. * the Help Topic desired.
  651. * ret_title Returns XmString containing the title.
  652. * ret_list Specifies the current font list being used.
  653. * Returns a new font list if new character
  654. * sets are added to it.
  655. * ret_mod Returns True if fonts were added to the
  656. * font list.
  657. *
  658. * Returns: 0 if successful, -1 if errors
  659. *
  660. * errno Values:
  661. *
  662. * Purpose: _DtHelpFormatTopicTitle formats a topic title and associates
  663. * the correct font with it.
  664. *
  665. ******************************************************************************/
  666. int
  667. _DtHelpFormatTopicTitle(
  668. XtPointer client_data,
  669. _DtHelpVolumeHdl volume_handle,
  670. char *location_id,
  671. XmString *ret_title,
  672. XmFontList *ret_list,
  673. Boolean *ret_mod )
  674. {
  675. int result = -1;
  676. void **titleChunks = NULL;
  677. _FrmtUiInfo myUiInfo = defUiInfo;
  678. _DtHelpCeLockInfo lockInfo;
  679. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  680. /*
  681. * Check the parameters
  682. */
  683. if (ret_title == NULL || ret_list == NULL || ret_mod == NULL)
  684. {
  685. errno = EINVAL;
  686. return -1;
  687. }
  688. /*
  689. * lock the volume
  690. */
  691. if (_DtHelpCeLockVolume(volume_handle, &lockInfo) != 0)
  692. return -1;
  693. /*
  694. * set up my UI information
  695. */
  696. myUiInfo.load_graphic = _DtHelpDALoadGraphic;
  697. myUiInfo.resolve_spc = _DtHelpDAResolveSpc;
  698. myUiInfo.load_font = _DtHelpDAResolveFont;
  699. myUiInfo.exec_filter = pDAS->exec_filter;
  700. myUiInfo.destroy_region = _DtHelpDADestroyRegion;
  701. myUiInfo.client_data = (_DtCvPointer) pDAS;
  702. /* since we're going for chunks, set avg_char width to 1 */
  703. myUiInfo.line_width = 0;
  704. myUiInfo.line_height = 0;
  705. myUiInfo.leading = 0;
  706. myUiInfo.avg_char = 1;
  707. myUiInfo.nl_to_space = pDAS->nl_to_space;
  708. /*
  709. * Get the title and charsets associated with the title segments.
  710. * The format of the returned information is
  711. * [type,charset/fontptr,]type,string/spc
  712. */
  713. result = _DtHelpCeGetVolumeFlag(volume_handle);
  714. _DtHelpProcessLock();
  715. if (result == 1)
  716. result = _DtHelpCeGetSdlTitleChunks(volume_handle, location_id,
  717. &myUiInfo, &titleChunks);
  718. else if (result == 0)
  719. result = _DtHelpCeGetCcdfTitleChunks( volume_handle, location_id,
  720. &myUiInfo, &titleChunks);
  721. _DtHelpProcessUnlock();
  722. if (result != -1)
  723. result = FormatChunksToXmString(pDAS, True, titleChunks,
  724. ret_title, ret_list, ret_mod);
  725. _DtHelpCeUnlockVolume(lockInfo);
  726. return result;
  727. } /* End _DtHelpFormatTopicTitle */
  728. /******************************************************************************
  729. * Function: int _DtHelpFormatVolumeTitle (DtHelpDispAreaStruct *pDAS,
  730. * _XvhVolume volume,
  731. * XmString *ret_title, XmFontList *ret_list,
  732. * Boolean *ret_mod)
  733. *
  734. * Parameters:
  735. * volume Specifies the Help Volume the information
  736. * is associated with.
  737. * ret_title Returns XmString containing the title.
  738. * ret_list Specifies the current font list being used.
  739. * Returns a new font list if new character
  740. * sets are added to it.
  741. * ret_mod Returns True if fonts were added to the
  742. * font list.
  743. *
  744. * Returns: 0 if successful, -1 if errors
  745. *
  746. * errno Values:
  747. *
  748. * Purpose: _DtHelpFormatVolumeTitle formats a volume title and associates
  749. * the correct font with it.
  750. *
  751. ******************************************************************************/
  752. int
  753. _DtHelpFormatVolumeTitle(
  754. XtPointer client_data,
  755. _DtHelpVolumeHdl volume_handle,
  756. XmString *ret_title,
  757. XmFontList *ret_list,
  758. Boolean *ret_mod )
  759. {
  760. int result = -1;
  761. void **titleChunks = NULL;
  762. _FrmtUiInfo myUiInfo = defUiInfo;
  763. _DtHelpCeLockInfo lockInfo;
  764. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  765. /*
  766. * Check the parameters
  767. */
  768. if (ret_title == NULL || ret_list == NULL || ret_mod == NULL)
  769. {
  770. errno = EINVAL;
  771. return -1;
  772. }
  773. /*
  774. * lock the volume
  775. */
  776. *ret_title = NULL;
  777. if (_DtHelpCeLockVolume(volume_handle, &lockInfo) != 0)
  778. return -1;
  779. /*
  780. * set up my UI information
  781. */
  782. myUiInfo.load_graphic = _DtHelpDALoadGraphic;
  783. myUiInfo.resolve_spc = _DtHelpDAResolveSpc;
  784. myUiInfo.load_font = _DtHelpDAResolveFont;
  785. myUiInfo.exec_filter = pDAS->exec_filter;
  786. myUiInfo.destroy_region = _DtHelpDADestroyRegion;
  787. myUiInfo.client_data = (_DtCvPointer) pDAS;
  788. /* since we're going for chunks, set avg_char width to 1 */
  789. myUiInfo.line_width = 0;
  790. myUiInfo.line_height = 0;
  791. myUiInfo.leading = 0;
  792. myUiInfo.avg_char = 1;
  793. myUiInfo.nl_to_space = pDAS->nl_to_space;
  794. /*
  795. * Get the title and charsets associated with the volume title.
  796. * The format of the returned information is
  797. * [type,charset/fontptr,]type,string/spc
  798. */
  799. result = _DtHelpCeGetVolumeFlag(volume_handle);
  800. _DtHelpProcessLock();
  801. if (result == 1)
  802. result = _DtHelpCeGetSdlVolTitleChunks(volume_handle, &myUiInfo,
  803. &titleChunks);
  804. else if (result == 0)
  805. result = _DtHelpCeGetCcdfVolTitleChunks(
  806. (_DtHelpVolume) volume_handle,
  807. &myUiInfo,
  808. &titleChunks);
  809. _DtHelpProcessUnlock();
  810. if (result != -1)
  811. result = FormatChunksToXmString(pDAS, True, titleChunks,
  812. ret_title, ret_list, ret_mod);
  813. _DtHelpCeUnlockVolume(lockInfo);
  814. return result;
  815. } /* End _DtHelpFormatVolumeTitle */
  816. /******************************************************************************
  817. * Function: int _DtHelpFormatIndexEntries (DtHelpDispAreaStruct *pDAS,
  818. * _XvhVolume volume,
  819. * XmString *ret_title, XmFontList *ret_list,
  820. * Boolean *ret_mod)
  821. *
  822. * Parameters:
  823. * volume Specifies the Help Volume the information
  824. * is associated with.
  825. * ret_cnt number of valid entries in the array
  826. * ret_words Returns NULL-termintaed array of
  827. * XmStrings containing the words.
  828. * ret_list Specifies the current font list being used.
  829. * Returns a new font list if new character
  830. * sets are added to it.
  831. * ret_mod Returns True if fonts were added to the
  832. * font list.
  833. *
  834. * Returns: 0 if successful, -1 if errors
  835. *
  836. * errno Values:
  837. *
  838. * Purpose: _DtHelpFormatIndexEntries formats index entries and associates
  839. * the correct font with it.
  840. *
  841. ******************************************************************************/
  842. int
  843. _DtHelpFormatIndexEntries(
  844. XtPointer client_data,
  845. _DtHelpVolumeHdl volume_handle,
  846. int *ret_cnt,
  847. XmString **ret_words,
  848. XmFontList *ret_list,
  849. Boolean *ret_mod )
  850. {
  851. int i;
  852. int result = -1;
  853. void *titleChunks[4];
  854. char *charSet;
  855. char **keyWords;
  856. Boolean myMod = False;
  857. XmFontList oldList;
  858. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  859. /*
  860. * Check the parameters
  861. */
  862. if (ret_words == NULL || ret_list == NULL || ret_mod == NULL)
  863. {
  864. errno = EINVAL;
  865. return -1;
  866. }
  867. *ret_mod = False;
  868. charSet = _DtHelpGetVolumeLocale(volume_handle);
  869. if (charSet != NULL)
  870. {
  871. *ret_cnt = _DtHelpCeGetKeywordList(volume_handle, &keyWords);
  872. if (*ret_cnt > 0)
  873. {
  874. *ret_words = (XmString *) malloc (sizeof(XmString) * (*ret_cnt+1));
  875. if (*ret_words == NULL)
  876. return -1;
  877. /* the order of the string ptr and charset ptr in the titleChunks
  878. is determined by the order of the if(..) tests on the
  879. flags and subsequent processing in FormatChunksToXmString() */
  880. titleChunks[0] = (void *) (DT_HELP_CE_STRING | DT_HELP_CE_CHARSET);
  881. titleChunks[1] = (void *) charSet;
  882. titleChunks[3] = (void *) DT_HELP_CE_END;
  883. for (i = 0, result = 0; result == 0 && i < *ret_cnt; i++)
  884. {
  885. oldList = *ret_list;
  886. titleChunks[2] = (void *) keyWords[i];
  887. result = FormatChunksToXmString(pDAS, False, titleChunks,
  888. &(*ret_words)[i], ret_list, &myMod);
  889. if (myMod == True)
  890. {
  891. /*
  892. * if the list has been modified before,
  893. * free the previously modified list.
  894. */
  895. if (True == *ret_mod)
  896. XmFontListFree(oldList);
  897. *ret_mod = True;
  898. }
  899. }
  900. (*ret_words)[i] = NULL;
  901. }
  902. free(charSet);
  903. }
  904. return result;
  905. } /* End _DtHelpFormatIndexEntries */
  906. /******************************************************************************
  907. * Function: int _DtHelpFormatTopic (
  908. * DtHelpDispAreaStruct *pDAS,
  909. * _DtHelpVolumeHdl volume,
  910. * char *id_string,
  911. * Boolean look_at_id,
  912. * XtPointer *ret_handle)
  913. *
  914. * Parameters:
  915. * pDAS Specifies the display area to use.
  916. * volume Specifies the Help Volume the information
  917. * is associated with.
  918. * id_string Specifies the location id for the topic.
  919. * This location id can be contained in a
  920. * topic.
  921. * look_at_id Specifies whether or not to start the
  922. * display of the topic at the location id.
  923. * ret_handle Returns a handle to the topic information
  924. * including the number of paragraphs and the
  925. * id match segment.
  926. *
  927. * Returns: 0 if successful.
  928. * -1 if errors.
  929. * -2 if the id was not found.
  930. * -3 if unable to format the topic.
  931. *
  932. * errno Values:
  933. *
  934. * Purpose: _DtHelpParseTopic accesses and parses Help topics.
  935. *
  936. ******************************************************************************/
  937. int
  938. _DtHelpFormatTopic(
  939. XtPointer client_data,
  940. _DtHelpVolumeHdl volume,
  941. char *id_string,
  942. Boolean look_at_id,
  943. XtPointer *ret_handle )
  944. {
  945. char *filename = NULL;
  946. int offset;
  947. int result = -2;
  948. _DtHelpCeLockInfo lockInfo;
  949. _FrmtUiInfo myUiInfo = defUiInfo;
  950. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  951. _DtCvTopicInfo *topic = NULL;
  952. if (_DtHelpCeLockVolume(volume, &lockInfo) != 0)
  953. return -1;
  954. if (_DtHelpCeFindId(volume,id_string,lockInfo.fd,&filename,&offset)==True)
  955. {
  956. if (look_at_id == False)
  957. id_string = NULL;
  958. myUiInfo.load_graphic = _DtHelpDALoadGraphic;
  959. myUiInfo.resolve_spc = _DtHelpDAResolveSpc;
  960. myUiInfo.load_font = _DtHelpDAResolveFont;
  961. myUiInfo.exec_filter = pDAS->exec_filter;
  962. myUiInfo.destroy_region = _DtHelpDADestroyRegion;
  963. myUiInfo.client_data = (_DtCvPointer) pDAS;
  964. myUiInfo.line_width = pDAS->lineThickness;
  965. myUiInfo.line_height = pDAS->lineHeight;
  966. myUiInfo.leading = pDAS->leading;
  967. myUiInfo.avg_char = (int)(pDAS->charWidth / 10 +
  968. ((pDAS->charWidth % 10) ? 1 : 0));
  969. myUiInfo.nl_to_space = pDAS->nl_to_space;
  970. result = _DtHelpCeGetVolumeFlag(volume);
  971. _DtHelpProcessLock();
  972. if (result == 1)
  973. result = _DtHelpCeParseSdlTopic(volume,
  974. &myUiInfo,
  975. lockInfo.fd, offset,
  976. id_string, True, &topic);
  977. else if (result == 0)
  978. result = _DtHelpCeFrmtCcdfTopic((_DtHelpVolume) volume,
  979. filename, offset,
  980. id_string,
  981. &myUiInfo, &topic);
  982. _DtHelpProcessUnlock();
  983. *ret_handle = (XtPointer) topic;
  984. if (result != 0)
  985. result = -3;
  986. if (filename != NULL)
  987. free(filename);
  988. }
  989. _DtHelpCeUnlockVolume(lockInfo);
  990. return result;
  991. } /* End _DtHelpFormatTopic */
  992. /******************************************************************************
  993. * Function: int _DtHelpGetAsciiVolumeTitle (
  994. *
  995. * Parameters: vol Specifies the loaded volume.
  996. * retTitle Returns the title of the volume. This string is
  997. * owned by the caller and must be freed.
  998. *
  999. * Return Value: 0 if successful, -1 if a failure occurs
  1000. *
  1001. * errno Values: CEErrorMalloc
  1002. * EINVAL 'vol' or 'retTitle' is NULL.
  1003. * CEErrorMissingTitleRes
  1004. * 'vol' does not contain the resource
  1005. * 'Title' or 'title' or the resource
  1006. * is zero length.
  1007. *
  1008. * Purpose: Get the title of a volume.
  1009. *
  1010. ******************************************************************************/
  1011. int
  1012. _DtHelpGetAsciiVolumeTitle (
  1013. XtPointer client_data,
  1014. _DtHelpVolumeHdl volume,
  1015. char **ret_title)
  1016. {
  1017. int result;
  1018. _FrmtUiInfo myUiInfo = defUiInfo;
  1019. DtHelpDispAreaStruct *pDAS = (DtHelpDispAreaStruct *) client_data;
  1020. /*
  1021. * What type of volume is it?
  1022. */
  1023. result = _DtHelpCeGetVolumeFlag(volume);
  1024. if (1 == result)
  1025. {
  1026. /*
  1027. * set up my UI information
  1028. */
  1029. myUiInfo.load_graphic = _DtHelpDALoadGraphic;
  1030. myUiInfo.resolve_spc = _DtHelpDAResolveSpc;
  1031. myUiInfo.load_font = _DtHelpDAResolveFont;
  1032. myUiInfo.exec_filter = pDAS->exec_filter;
  1033. myUiInfo.destroy_region = _DtHelpDADestroyRegion;
  1034. myUiInfo.client_data = (_DtCvPointer) pDAS;
  1035. /* since we're going for a string, set avg_char width to 1 */
  1036. myUiInfo.line_width = 0;
  1037. myUiInfo.line_height = 0;
  1038. myUiInfo.leading = 0;
  1039. myUiInfo.avg_char = 1;
  1040. myUiInfo.nl_to_space = pDAS->nl_to_space;
  1041. _DtHelpProcessLock();
  1042. result = _DtHelpCeFrmtSDLVolTitleToAscii(volume, &myUiInfo, ret_title);
  1043. }
  1044. else if (0 == result)
  1045. {
  1046. _DtHelpProcessLock();
  1047. result = _DtHelpCeGetCcdfVolumeTitle(volume, ret_title);
  1048. }
  1049. _DtHelpProcessUnlock();
  1050. return result;
  1051. }
  1052. /*****************************************************************************
  1053. * Function: int _DtHelpFormatToc (
  1054. * _DtHelpVolumeHdl volume, id);
  1055. *
  1056. * Parameters:
  1057. * canvas Specifies the handle for the canvas.
  1058. *
  1059. * Returns: -1 if errors.
  1060. * 0 if no errors.
  1061. * 1 if empty path.
  1062. *
  1063. * Purpose:
  1064. *
  1065. *****************************************************************************/
  1066. int
  1067. _DtHelpFormatToc (
  1068. DtHelpDispAreaStruct *pDAS,
  1069. _DtHelpVolumeHdl volume,
  1070. char *id,
  1071. char **ret_id,
  1072. XtPointer *ret_handle)
  1073. {
  1074. int result = 0;
  1075. _DtCvTopicPtr topic = NULL;
  1076. _DtHelpCeLockInfo lockInfo;
  1077. if (volume == NULL || id == NULL)
  1078. return -1;
  1079. /*
  1080. * This becomes my volume; want to ensure that it doesn't
  1081. * get closed out from under me, so tell the system that
  1082. * i'm using it.
  1083. */
  1084. if (_DtHelpCeLockVolume(volume, &lockInfo) != 0)
  1085. return -1;
  1086. result = _DtHelpCeMapTargetToId(volume, id, ret_id);
  1087. if (result == 0)
  1088. {
  1089. _FrmtUiInfo myUiInfo = defUiInfo;
  1090. myUiInfo.client_data = (XtPointer) pDAS;
  1091. myUiInfo.load_graphic = _DtHelpDALoadGraphic;
  1092. myUiInfo.resolve_spc = _DtHelpDAResolveSpc;
  1093. myUiInfo.load_font = _DtHelpDAResolveFont;
  1094. myUiInfo.exec_filter = pDAS->exec_filter;
  1095. myUiInfo.destroy_region = _DtHelpDADestroyRegion;
  1096. myUiInfo.client_data = (_DtCvPointer) pDAS;
  1097. myUiInfo.line_width = pDAS->lineThickness;
  1098. myUiInfo.line_height = pDAS->lineHeight;
  1099. myUiInfo.leading = pDAS->leading;
  1100. myUiInfo.avg_char = (int)(pDAS->charWidth / 10 +
  1101. ((pDAS->charWidth % 10) ? 1 : 0));
  1102. myUiInfo.nl_to_space = pDAS->nl_to_space;
  1103. result = _DtHelpCeGetVolumeFlag(volume);
  1104. _DtHelpProcessLock();
  1105. if (result == 1)
  1106. result = _DtHelpCeFrmtSdlPathAndChildren(volume,
  1107. &myUiInfo,
  1108. lockInfo.fd,
  1109. *ret_id, &topic);
  1110. else if (result == 0)
  1111. result = _DtHelpCeFrmtCcdfPathAndChildren(volume,
  1112. *ret_id,
  1113. &myUiInfo, &topic);
  1114. _DtHelpProcessUnlock();
  1115. *ret_handle = (XtPointer) topic;
  1116. }
  1117. /*
  1118. * didn't successfully format a path, so close my copy
  1119. * of the volume.
  1120. */
  1121. else
  1122. _DtHelpCloseVolume (volume);
  1123. _DtHelpCeUnlockVolume(lockInfo);
  1124. return result;
  1125. } /* End _DtHelpFormatToc */