|  09-18-2024, 10:02 AM | #1 | 
| Addict       Posts: 304 Karma: 516 Join Date: Nov 2015 Location: Europe EEC Device: Kindle Fire HD6 & HD8 | 
				
				Sigil's error messages
			 
			
			Sigil's error messages, displayed in a pink box at the top of the Preview pane, are difficult to read and misleading in several respects. This causes difficulty in explaining to fellow authors who I'm trying to convert to Sigil. In making small edits using copy/paste, they quite frequently damage a tag. 1. If the Preview pane is not wide enough, the message runs off the side of the screen. The text does not wrap. See Ex-1.png 2. Depending on what's wrong in the code, the message refers to the wrong line/column combination. See Ex-2.png In the example screenshots, there is a missing < at the closing </p> tag on line 14, column 433 (as witnessed at the bottom, RHS of the screen). See Ex-3.png The error message reports "line 75, column 8" which in reality is the location in this file at the end of the </body> tag. 3. If the closing > is the one missing at the end of the same paragraph, (on line 14, column 436), the error message returns error at line 16, column 3. I can see a certain logic in this case because after the use of the 'Mend and Prettify' tool, there is a blank line 15 and line 16 starts at column 3. Encouraging the use of Prettify complicates the finding of a simple error. Instead of reporting the last available place where the missing element could be, could Sigil report the first possible place? There are several instances where the message is difficult to understand but the location is ok. Also, there are occasions when the message gets truncated like this: "error on line 16 at column 44: Opening and ending tag mismatch: h2 line 16 and a". And that is not a case of the Preview pane having insufficient width. Moreover, the error in this case was a missing < at column 27, inside an edited internet link. Links are another item that our non-tech authors often mangle. | 
|   |   | 
|  09-18-2024, 11:12 AM | #2 | 
| Grand Sorcerer            Posts: 28,854 Karma: 207000000 Join Date: Jan 2010 Device: Nexus 7, Kindle Fire HD | 
			
			Have you considered recommending to non xhtml code savvy authors that they use PageEdit to make small edits? Pretty hard to damage tags in a wysiwyg editor. If we could easily make the pink QtWebEngine error messages more helpful/accurate, we most certainly would. But we have very little control over them. | 
|   |   | 
|  09-18-2024, 11:25 AM | #3 | 
| Guru            Posts: 899 Karma: 3501166 Join Date: Jan 2017 Location: Poland Device: Various | 
			
			Point 1 can be fixed and the others are IMHO beyond the reach of Sigil, which has no control over the content of these messages on the pink background. To ensure that the error text does not escape outside the pink frame – create or edit the custom_preview_style.css file in the Sigil Preferences folder. Where's the folder? Open "Preferences" and click on the "Open Preferences Location" button in the lower left corner. It's there. Add to custom_preview_style.css file this line: Code: html parsererror h3, html parsererror div {white-space: normal;} | 
|   |   | 
|  09-18-2024, 11:50 AM | #4 | 
| Grand Sorcerer            Posts: 28,854 Karma: 207000000 Join Date: Jan 2010 Device: Nexus 7, Kindle Fire HD | 
			
			I'm wondering if we can safely inject that into Preview's CSS (via Sigil's code) without throwing any line counts off too badly?
		 | 
|   |   | 
|  09-18-2024, 11:57 AM | #5 | 
| Sigil Developer            Posts: 9,070 Karma: 6361556 Join Date: Nov 2009 Device: many | 
			
			Yes, those error messages are not generated by Sigil.  They are generated by the Chrome/QtWebengine browser widget used by Qt.  They can not guess where the best "fix" is just where they detect that a "fix" (error) has definitely happened in the first place. Simple missing < and > chars should also be detectable and reported by using Sigil's simple Well Formed check (aka SanityCheck) in the Validation window. So if in doubt you can get a second opinion. I assume if a user wanted, instead of using the custom preview injected stylesheet for BeckyEbook's solution the user could simply add that css to their own stylesheet while they debug / build their epubs. Last edited by KevinH; 09-18-2024 at 12:00 PM. | 
|   |   | 
|  09-18-2024, 01:26 PM | #6 | |
| Addict       Posts: 304 Karma: 516 Join Date: Nov 2015 Location: Europe EEC Device: Kindle Fire HD6 & HD8 | Quote: 
 | |
|   |   | 
|  09-18-2024, 01:33 PM | #7 | |
| Addict       Posts: 304 Karma: 516 Join Date: Nov 2015 Location: Europe EEC Device: Kindle Fire HD6 & HD8 | Quote: 
 From what I remember in reading other threads, PageEdit was made independent of Sigil so is not integrated and is limited to Wysiwyg code editing and Sigil is still required for other work on an eBook. | |
|   |   | 
|  09-18-2024, 01:47 PM | #8 | |
| Addict       Posts: 304 Karma: 516 Join Date: Nov 2015 Location: Europe EEC Device: Kindle Fire HD6 & HD8 | Quote: 
 Certainly, the Well Formed Check provides a correct error position indication but describes the error as "illegal character in text" rather than a missing character or even saying what character it expected to find. | |
|   |   | 
|  09-18-2024, 03:55 PM | #9 | |
| Grand Sorcerer            Posts: 28,854 Karma: 207000000 Join Date: Jan 2010 Device: Nexus 7, Kindle Fire HD | Quote: 
 I was mainly thinking of the fellow authors you mentioned who were making small edits to epubs. My thinking was that if they're not that xhtml inclined, then a wysiwyg editor could be perfect for the small edits you talked about. You can't destroy tags/links you're not copying over (but you can still format text and create/edit links in wysiwyg fashion). Save Sigil for the heavy lifting if/when it's needed. Once the epub is fully fleshed out, making simple edits to any of the content in PageEdit's wysiwyg editor is quite possible. Last edited by DiapDealer; 09-18-2024 at 04:01 PM. | |
|   |   | 
|  09-18-2024, 04:13 PM | #10 | 
| Bibliophagist            Posts: 47,959 Karma: 174315098 Join Date: Jul 2010 Location: Vancouver Device: Kobo Sage, Libra Colour, Lenovo M8 FHD, Paperwhite 4, Tolino epos | 
			
			For what it may be worth, the authors I have worked with use Word/Libre Office/other word processor to create their documents. After beating the use of styles into their heads, it is relatively simple to convert the .docx to an ePub and work on formatting from there. There are only two of the authors I've worked with who were willing to take the time and effort to learn to use Sigil or calibre's ebook-editor to get down and dirty with their ebooks and even those two prefer to have me prepare the ePubs for sending to the publishers. | 
|   |   | 
|  09-30-2024, 11:05 AM | #11 | 
| Addict       Posts: 304 Karma: 516 Join Date: Nov 2015 Location: Europe EEC Device: Kindle Fire HD6 & HD8 | 
				
				missing or unmatched quotes on class names cause various problems
			 
			
			Unmatched or missing quotes on a class name cause various problems on W10 with Sigil 2.3.1 and on MacBook with 2.3.0 <p class=Textbody"> is picked up by the QtWebengine although as noted above in this thread its line/column location is a bit doubtful. But it is not picked up by Sigil's 'Well-Formed Check EPUB' tool although <p class="Textbody> is caught by Well-Formed Check Missing quotes <p class=Textbody> is not picked up by Well-Formed Check <p class='Textbody"> These unmatched quotes are picked up by Well-Formed Check and QtWebengine. And most curious of all for me is that a single occurence of one of these "quotes" examples produces a whole range of "Fragment identifier not defined" errors by the EpubCheck plugin with references to various pages, lines, and columns. These fragments are nowhere in the vicinity of the missing or unmatched quotes which the plugin does correctly locate. As soon as the "quotes" error is fixed, a rerun of the EpubCheck plugin finds no faults at all. So fixing a missing quote cures undefined fragments - hard to believe. | 
|   |   | 
|  09-30-2024, 12:28 PM | #12 | |
| Grand Sorcerer            Posts: 28,854 Karma: 207000000 Join Date: Jan 2010 Device: Nexus 7, Kindle Fire HD | 
			
			I'm quite surprised that Sigil's well-formed check picks up on ANY mismatched attribute quotation marks, to be honest (in any version of Sigil). The Well-formed check is primarily concerned with mismatched tags or improperly nested tags. Quote: 
 It's not the first time that one error will move the goalpost to a different error in a validation routine. And it won't be the last. Not one of them are perfect in detecting all the various ways a user can mess code up. Last edited by DiapDealer; 09-30-2024 at 12:34 PM. | |
|   |   | 
|  09-30-2024, 01:03 PM | #13 | 
| Grand Sorcerer            Posts: 28,854 Karma: 207000000 Join Date: Jan 2010 Device: Nexus 7, Kindle Fire HD | 
			
			Having said that, however, the sanity check IS supposed to look for mismatched attribute quotes. And it does not look like it's currently finding any missing open quote instances. Only missing ending quotes.
		 Last edited by DiapDealer; 09-30-2024 at 01:14 PM. | 
|   |   | 
|  09-30-2024, 02:46 PM | #14 | 
| Grand Sorcerer            Posts: 28,854 Karma: 207000000 Join Date: Jan 2010 Device: Nexus 7, Kindle Fire HD | 
			
			Potential solution: https://github.com/Sigil-Ebook/Sigil/pull/777 Unfortunately, Well-Formed Check Epub feature is not likely to ever be able flag attributes with no quotes at all. Not without a complete overhaul, anyway. But it's not really intended to be a complete xhtml validator. It's a quick, down and dirty sanity check. | 
|   |   | 
|  09-30-2024, 03:14 PM | #15 | 
| Guru            Posts: 899 Karma: 3501166 Join Date: Jan 2017 Location: Poland Device: Various | 
			
			Hmmm… My two cents: 1. Missing quotes are fixed by Mend & Prettify, not matched quotes are removed (if one occurrence) or shredded (if two or more). 1a. <p class='test">Blah</p> Single occurrence -> will be removed after Mend 1b. <p class='test">Blah</p> <p class='test">Blah</p> Double occurrences -> will be "fixed" by Mend to: <p class='test">Blah</p> <p class=' test"="">Blah</p> 1c. Other case (unmatched inverted quotes): <p class='test">Blah</p> <p class="test'>Blah</p> will be "fixed" by Mend to: <p class='test">Blah</p> <p class="test'>Blah</p> 2. Possible real detect missing quotes. In sanitycheck.py after line 185: Code:                     ...
                    val = s[b:p]
                    error_msg = 'Attribute "' + aname + '" has missing quotes surrounding the value'
                    self.errors.append((self.tag_start[0], self.tag_start[1], error_msg))
                    self.has_error = True
                    return None, None, None
                tattr[aname] = val
                ...Of course, this is worth checking. Fortunately, the sanitycheck.py file is available for editing directly (C:\Program Files\Sigil\python3lib\sanitycheck.py), so the tests don't require rebuilding Sigil, just restarting it. Of course, it's better to test it; I've only done about a dozen trials. Last edited by BeckyEbook; 09-30-2024 at 04:12 PM. | 
|   |   | 
|  | 
| Thread Tools | Search this Thread | 
| 
 | 
|  Similar Threads | ||||
| Thread | Thread Starter | Forum | Replies | Last Post | 
| Sigil Font use without error messages | qkiazd | Sigil | 16 | 11-18-2023 11:04 AM | 
| Copying error messages | AlanHK | Sigil | 1 | 09-27-2017 02:07 PM | 
| About translation and error messages | hermida | Development | 12 | 05-05-2016 04:34 PM | 
| What's with the DRM error messages? | AndyElk | Calibre | 3 | 02-28-2016 08:14 PM | 
| error messages on new PC | huskerruth | Devices | 1 | 02-16-2011 11:56 AM |