[MacPorts] #51287: Inkscape crashes on startup if enchant is installed with +applespell

MacPorts noreply at macports.org
Mon May 23 03:19:51 PDT 2016


#51287: Inkscape crashes on startup if enchant is installed with +applespell
-------------------------------+------------------------
  Reporter:  jo.vanoost@…      |      Owner:  jeremyhu@…
      Type:  defect            |     Status:  new
  Priority:  Normal            |  Milestone:
 Component:  ports             |    Version:
Resolution:                    |   Keywords:  lion
      Port:  inkscape enchant  |
-------------------------------+------------------------

Comment (by devans@…):

 I guess I'm not being clear

 inkscape will not enable the spellchecking item in the Text menu if aspell
 is not available at build time.  See configure.ac.  Thus aspell needs to
 be a dependency of inkscape.

 inkscape uses gtkspell which uses enchant to spellcheck words in a text
 object.  This part will work with any enchant backend. Mispelled words are
 highlighted (outlined) in red.

 However, the code that allows you to add words to a dictionary bypasses
 enchant and uses aspell api directly.  Thus, new words added are added to
 the aspell dictionary only and have no effect on the spellcheck
 highlighting via enchant unless enchant is using aspell as the backend.

 This can be demonstrated as follows:

 select spellchecking in the text box so that you have the inkscape
 workspace on the left and the spellcheck dialog on the right.

 create a text box in the workspace and enter a mispelled word (e.g.
 libertee).  When you hit the start button in the spellcheck dialog the
 word will be highlighted in red.

 Then using the dialog try to add the word to the dictionary.  If enchant
 +aspell is active, the highlighting of the word will immediately disappear
 since the word is now in the dictionary. Subsequent usages of this word
 will not be highlighted. This is the proper behavior.

 However, if enchant does not have +aspell selected then this will have no
 effect, the word will still be highlighted because the word was added to
 an aspell dictionary not the one enchant is using. Only aspell will work
 here as the code is using the aspell api directly.

 Thus there are two requirements for full functionality:  inkscape must
 depend on aspell to enable the spellcheck item in the text menu and
 enchant +aspell must be installed so that the spellchecking code and the
 code for adding words to the dictionary are using the same dictionary
 (which has to be aspell).

 I admit that this is a poor way to write the spellchecking code but this
 is the way it is.

 There is other funny things as well.  For instance, although the
 appearance of the spellcheck item in text menu is dependent upon having
 aspell available at build time, the spellcheck dialog is still enabled in
 the code.  So if you use a properly configured version of inkscape to
 display the spellcheck dialog using the text menu item and then quit and
 run a version built without aspell, the spellcheck dialog will appear on
 startup because inkscape remembers the window configuration from the
 previous run but if you close the dialog there is no way to open it again
 because the text menu item is missing.  This can make you think it's
 working without aspell but its really not (or only partially).

 This all needs work upstream.

-- 
Ticket URL: <https://trac.macports.org/ticket/51287#comment:18>
MacPorts <https://www.macports.org/>
Ports system for OS X


More information about the macports-tickets mailing list