Hi Pablo, The section breaks are a bit of a headache. In the old mechanism (also mkii) we used penalties between different section levels (different values so that there is some hierarchy). In mkiv we have a weighted penalty/glue mechanism which has advantages but can also create side effects. The method of a few weeks ago coul deal with \section followed by 100 \subsections i.e. no text between this. In a strict mechanism you end up with one long page fur to all the penalties. So, there was some precaution for this. However that didn't work well with content following sections that prefers breaks (read: section head followed by e.g. itemize or tabulate). So, the newer mechanism tries to analyze the page stream which (currently) is somewhat tricky. That's why we need to iterate to an acceptable solution. Some of these mkiv mechanisms are already a bit old and could be done better using some newer luatex trickery (but i need tome to do that). It would be nice to have a large test case for this (sort of hard to make one as some trial and error is involved). As you already have some, best collect them for future reference. A new beta ... Hans ----------------------------------------------------------------- Hans Hagen | PRAGMA ADE Ridderstraat 27 | 8061 GH Hasselt | The Netherlands tel: 038 477 53 69 | voip: 087 875 68 74 | www.pragma-ade.com | www.pragma-pod.nl -----------------------------------------------------------------
On 2014-06-01 07:51, Hans Hagen wrote:
Hi Pablo,
The section breaks are a bit of a headache. In the old mechanism (also mkii) we used penalties between different section levels (different values so that there is some hierarchy).
In mkiv we have a weighted penalty/glue mechanism which has advantages but can also create side effects. The method of a few weeks ago coul deal with
\section followed by 100 \subsections
i.e. no text between this. In a strict mechanism you end up with one long page fur to all the penalties. So, there was some precaution for this. However that didn't work well with content following sections that prefers breaks (read: section head followed by e.g. itemize or tabulate).
So, the newer mechanism tries to analyze the page stream which (currently) is somewhat tricky. That's why we need to iterate to an acceptable solution.
Some of these mkiv mechanisms are already a bit old and could be done better using some newer luatex trickery (but i need tome to do that).
It would be nice to have a large test case for this (sort of hard to make one as some trial and error is involved). As you already have some, best collect them for future reference.
A new beta ...
Hans
Hans, Is this also the cause of problems I noted with heading placed into the margin, as in the example below? % Extra whitespace after some marginal section headings % % When section heads are set in the margin, the following body % text should start on the same line as the heading. This is % the case with plain text, but not always the case with other % features (floats and enumerations). Wolfgang suggested adding % insidesection={blank[overlay]} to the section heading setup, but % that only helps with enumerations and with tabulate tables that do % not start with an HL (it fails with natural tables as well). And % that success only comes with start/stop sectioning. With traditional % sectioning, there are more failures. % % \setupexternalfigures[location=default] \setuphead [section] [alternative=text, command=\SectionCommand, distance=0pt, insidesection={\blank[overlay]}, ] \define[2]\SectionCommand {\inmargin{#1 -- #2}} \setuplayout[backspace=4cm] \starttext \startchapter[title={Start/Stop sectioning}] \startsection[title={Okay with text first}] Text here \starttabulate \FL \NC Knuth \NC \input{knuth} \NC\NR \stoptabulate \stopsection \startsection[title={Okay with itemize}] \startitemize \item One \item Two \item Three \stopitemize \stopsection \startsection[title={Okay with tabulate no HL}] \starttabulate \NC Knuth \NC \input{knuth} \NC\NR \stoptabulate \page \stopsection \startsection[title={Fail with tabulate HL}] \starttabulate \FL \NC Knuth \NC \input{knuth} \NC\NR \stoptabulate \stopsection \startsection[title={Fail with TABLE frame}] \bTABLE \bTR \bTD Knuth \eTD\bTD \input{knuth} \eTD\eTR \eTABLE \stopsection \startsection[title={Fail with TABLE no frame}] \bTABLE[frame=off] \bTR \bTD Knuth \eTD\bTD \input{knuth} \eTD\eTR \eTABLE \page \stopsection \startsection[title={Fails with figures}] \startplacefigure[location=right,reference={fig:2},title={Caption}] \externalfigure[cow.pdf][width=2cm] \stopplacefigure \input{tufte} \stopsection \stopchapter \chapter{Traditional sectioning} \section{Okay with text first} Text here \starttabulate \FL \NC Knuth \NC \input{knuth} \NC\NR \stoptabulate \section{Fail with itemize} \startitemize \item One \item Two \item Three \stopitemize \page \section{Fail with tabulate no HL} \starttabulate \NC Knuth \NC \input{knuth} \NC\NR \stoptabulate \section{Fail with tabulate HL} \starttabulate \FL \NC Knuth \NC \input{knuth} \NC\NR \stoptabulate \section{Fail with TABLE frame} \bTABLE \bTR \bTD Knuth \eTD\bTD \input{knuth} \eTD\eTR \eTABLE \section{Fail with TABLE no frame} \bTABLE[frame=off] \bTR \bTD Knuth \eTD\bTD \input{knuth} \eTD\eTR \eTABLE \page \section[title={Fails with figures startstop}] \startplacefigure[location=right,reference={fig:2},title={Caption}] \externalfigure[cow.pdf][width=2cm] \stopplacefigure \input{tufte} \section[title={Fails with figures traditional}] \placefigure[right][fig:2]{Caption} {\externalfigure[cow.pdf][width=2cm]} \input{tufte} \stoptext -- Rik Kabel
On 6/1/2014 5:40 PM, Rik wrote:
Is this also the cause of problems I noted with heading placed into the margin, as in the example below?
no, unrelated, try this: \setuphead [section] [after={\strut\blank[-2*line,samepage,disable]}, command=\SectionCommand, distance=0pt] \define[2]\SectionCommand{\inleft{XXXXXX}} ----------------------------------------------------------------- Hans Hagen | PRAGMA ADE Ridderstraat 27 | 8061 GH Hasselt | The Netherlands tel: 038 477 53 69 | voip: 087 875 68 74 | www.pragma-ade.com | www.pragma-pod.nl -----------------------------------------------------------------
Hi Hans, many thanks for your explanation and sorry for the trouble. I created the test case that only contains three issues related to page breaks. Many thanks for the new beta, I’m afraid I’m still experiencing issues. \showframe\showgrid \setupbodyfont[pagella,15pt] \starttext \dorecurse{100}{This is a sentence. } \startitemize \dorecurse{3}{\item This is an item.\par} \stopitemize \stoptext Previous beta located two items on the first page. Latest beta locates only one. But when items are higher than two, the first item disappears from the first page in the second run. And my first sample works fine with the new beta, but not with the real book. I’ll try to get a new sample. Many thanks for your help again, Pablo. On 06/01/2014 01:51 PM, Hans Hagen wrote:
Hi Pablo,
The section breaks are a bit of a headache. In the old mechanism (also mkii) we used penalties between different section levels (different values so that there is some hierarchy).
In mkiv we have a weighted penalty/glue mechanism which has advantages but can also create side effects. The method of a few weeks ago could deal with
\section followed by 100 \subsections
i.e. no text between this. In a strict mechanism you end up with one long page fur to all the penalties. So, there was some precaution for this. However that didn't work well with content following sections that prefers breaks (read: section head followed by e.g. itemize or tabulate).
So, the newer mechanism tries to analyze the page stream which (currently) is somewhat tricky. That's why we need to iterate to an acceptable solution.
Some of these mkiv mechanisms are already a bit old and could be done better using some newer luatex trickery (but i need tome to do that).
It would be nice to have a large test case for this (sort of hard to make one as some trial and error is involved). As you already have some, best collect them for future reference.
A new beta ...
Hans
Hi Hans, I found out that the issue I wrote about in my previous message is about widow and orphan lines. Here is the sample: \showframe\showgrid \setuplayout[setups=*lessstrict] \startsetups[*lessstrict] \setup[reset] \widowpenalty=10000 \clubpenalty=10000 \stopsetups \setupbodyfont[pagella,15pt] \starttext \chapter{Chapter} \section{Section} \dorecurse{103}{\ConTeXt\ is fun! } \subsection{Subsection} \ConTeXt\ is fun! \stoptext Many thanks for your excellent work, Pablo On 06/01/2014 01:51 PM, Hans Hagen wrote:
Hi Pablo,
The section breaks are a bit of a headache. In the old mechanism (also mkii) we used penalties between different section levels (different values so that there is some hierarchy).
In mkiv we have a weighted penalty/glue mechanism which has advantages but can also create side effects. The method of a few weeks ago coul deal with
\section followed by 100 \subsections
i.e. no text between this. In a strict mechanism you end up with one long page fur to all the penalties. So, there was some precaution for this. However that didn't work well with content following sections that prefers breaks (read: section head followed by e.g. itemize or tabulate).
So, the newer mechanism tries to analyze the page stream which (currently) is somewhat tricky. That's why we need to iterate to an acceptable solution.
Some of these mkiv mechanisms are already a bit old and could be done better using some newer luatex trickery (but i need tome to do that).
It would be nice to have a large test case for this (sort of hard to make one as some trial and error is involved). As you already have some, best collect them for future reference.
A new beta ...
Hans
On 6/1/2014 8:18 PM, Pablo Rodriguez wrote:
Hi Hans,
I found out that the issue I wrote about in my previous message is about widow and orphan lines.
indeed, when testing setting them to 0 helps (there are more cases when such penalties interfere, idem for (ex)hyphenpenalty) Hans ----------------------------------------------------------------- Hans Hagen | PRAGMA ADE Ridderstraat 27 | 8061 GH Hasselt | The Netherlands tel: 038 477 53 69 | voip: 087 875 68 74 | www.pragma-ade.com | www.pragma-pod.nl -----------------------------------------------------------------
participants (3)
-
Hans Hagen
-
Pablo Rodriguez
-
Rik