commit 2a7ec054be00fbac76efa8aefb4ae1531d981761 Author: Juergen Spitzmueller <sp...@lyx.org> Date: Sun Jun 2 11:41:54 2024 +0200
Support half und full line parskip class options (#12946) Currently only employed by the KOMA classes. Layout format change. --- lib/doc/Customization.lyx | 114 +++++++++++++++++++++++++++++++++++++++++++ lib/doc/de/Customization.lyx | 80 ++++++++++++++++++++++++++++++ lib/layouts/scrclass.inc | 5 +- lib/scripts/layout2layout.py | 7 ++- src/BufferParams.cpp | 12 ++++- src/TextClass.cpp | 20 ++++++-- src/TextClass.h | 8 +++ 7 files changed, 238 insertions(+), 8 deletions(-) diff --git a/lib/doc/Customization.lyx b/lib/doc/Customization.lyx index 83784e8c2a..fa65bde11e 100644 --- a/lib/doc/Customization.lyx +++ b/lib/doc/Customization.lyx @@ -12201,6 +12201,108 @@ status collapsed \end_inset . +\change_inserted -712698321 1717320820 + +\end_layout + +\begin_layout Description + +\change_inserted -712698321 1717321090 +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout + +\change_inserted -712698321 1717320831 +ParskipFull +\end_layout + +\end_inset + + [ +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout + +\change_inserted -712698321 1717320820 +string +\end_layout + +\end_inset + +] If the class has an option to set a full line paragraph skip, + specify it here (e.g., + +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout + +\change_inserted -712698321 1717320884 +parskip=full +\change_unchanged + +\end_layout + +\end_inset + +). + This then outputs the option rather than using the +\emph on +parskip +\emph default + package. +\end_layout + +\begin_layout Description + +\change_inserted -712698321 1717321094 +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout + +\change_inserted -712698321 1717320913 +ParskipHalf +\end_layout + +\end_inset + + [ +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout + +\change_inserted -712698321 1717320909 +string +\end_layout + +\end_inset + +] If the class has an option to set a half line paragraph skip, + specify it here (e.g., + +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout + +\change_inserted -712698321 1717320920 +parskip=half +\end_layout + +\end_inset + +). + This then outputs the option rather than using the +\emph on +parskip +\emph default + package. +\change_unchanged + \end_layout \begin_layout Description @@ -20899,6 +21001,8 @@ status collapsed \change_inserted -712698321 1715685023 -1 +\change_unchanged + \end_layout \end_inset @@ -20944,6 +21048,8 @@ status collapsed \change_inserted -712698321 1715685031 1 +\change_unchanged + \end_layout \end_inset @@ -20979,6 +21085,8 @@ status collapsed \change_inserted -712698321 1715685008 0 +\change_unchanged + \end_layout \end_inset @@ -20994,6 +21102,8 @@ status collapsed \backslash cprotect +\change_unchanged + \end_layout \end_inset @@ -21007,6 +21117,8 @@ status collapsed \change_inserted -712698321 1715685008 -1 +\change_unchanged + \end_layout \end_inset @@ -21021,6 +21133,8 @@ status collapsed \backslash cprotect +\change_unchanged + \end_layout \end_inset diff --git a/lib/doc/de/Customization.lyx b/lib/doc/de/Customization.lyx index 3c671d525b..fe07aa404a 100644 --- a/lib/doc/de/Customization.lyx +++ b/lib/doc/de/Customization.lyx @@ -10755,6 +10755,86 @@ status collapsed getrennt. \end_layout +\begin_layout Description +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout +ParskipFull +\end_layout + +\end_inset + + [ +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout +string +\end_layout + +\end_inset + +] Falls die Dokumentklasse eine Option zum Setzen eines ganzzeiligen Absatzabstandes bietet (bspw. + +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout +parskip=full +\end_layout + +\end_inset + +), + geben Sie diese hier an. + Dann wird statt des Pakets +\emph on +parskip +\emph default + diese Option verwendet. +\end_layout + +\begin_layout Description +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout +ParskipHalf +\end_layout + +\end_inset + + [ +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout +string +\end_layout + +\end_inset + +] Falls die Dokumentklasse eine Option zum Setzen eines halbzeiligen Absatzabstandes bietet (bspw. + +\begin_inset Flex Code +status collapsed + +\begin_layout Plain Layout +parskip=half +\end_layout + +\end_inset + +), + geben Sie diese hier an. + Dann wird statt des Pakets +\emph on +parskip +\emph default + diese Option verwendet. +\end_layout + \begin_layout Standard Der Abschnitt \begin_inset Flex Code diff --git a/lib/layouts/scrclass.inc b/lib/layouts/scrclass.inc index 41ac90a91b..ab85a0f3af 100644 --- a/lib/layouts/scrclass.inc +++ b/lib/layouts/scrclass.inc @@ -8,7 +8,8 @@ # Labeling is now used also in non-KOMA classes -Format 104 +Format 105 + SecNumDepth 2 TocDepth 2 DefaultStyle Standard @@ -20,6 +21,8 @@ ClassOptions FontSizeFormat fontsize=$$s PageSize a0|a1|a2|a3|a4|a5|a6|b0|b1|b2|b3|b4|b5|b6|c0|c1|c2|c3|c4|c5|c6|executive|legal|letter PageSizeFormat paper=$$s + ParskipHalf parskip=half + ParskipFull parskip=full End Style Standard diff --git a/lib/scripts/layout2layout.py b/lib/scripts/layout2layout.py index 611639412a..665e717bfb 100644 --- a/lib/scripts/layout2layout.py +++ b/lib/scripts/layout2layout.py @@ -11,7 +11,7 @@ # This script will update a .layout file to current format # The latest layout format is also defined in src/TextClass.cpp -currentFormat = 104 +currentFormat = 105 # Incremented to format 4, 6 April 2007, lasgouttes @@ -351,6 +351,9 @@ currentFormat = 104 # Incremented to format 104, 28 July 2023 by rikiheck # RefFormat for counters and PrettyFormat for floats +# Incremented to format 105, 2 June 2024 by spitz +# ParskipFull and ParskipHalf class options + # Do not forget to document format change in Customization # Manual (section "Declaring a new text class"). @@ -598,7 +601,7 @@ def convert(lines, end_format): i += 1 continue - if 101 <= format <= 103: + if 101 <= format <= 104: # nothing to do. i += 1 continue diff --git a/src/BufferParams.cpp b/src/BufferParams.cpp index 2e000e29c4..892aff5867 100644 --- a/src/BufferParams.cpp +++ b/src/BufferParams.cpp @@ -1831,6 +1831,13 @@ bool BufferParams::writeLaTeX(otexstream & os, LaTeXFeatures & features, case DEFAULT: break; } + + if (paragraph_separation) { + if (!tclass.halfparskip().empty() && getDefSkip().kind() == VSpace::HALFLINE) + clsoptions << tclass.halfparskip() << ","; + if (!tclass.fullparskip().empty() && getDefSkip().kind() == VSpace::FULLLINE) + clsoptions << tclass.fullparskip() << ","; + } // language should be a parameter to \documentclass if (language->babel() == "hebrew" @@ -2154,6 +2161,7 @@ bool BufferParams::writeLaTeX(otexstream & os, LaTeXFeatures & features, // when skip separation string psopt; bool default_skip = false; + bool by_class_option = false; switch (getDefSkip().kind()) { case VSpace::SMALLSKIP: psopt = "\\smallskipamount"; @@ -2167,9 +2175,11 @@ bool BufferParams::writeLaTeX(otexstream & os, LaTeXFeatures & features, case VSpace::HALFLINE: // default (no option) default_skip = true; + by_class_option = !tclass.halfparskip().empty(); break; case VSpace::FULLLINE: psopt = "\\baselineskip"; + by_class_option = !tclass.fullparskip().empty(); break; case VSpace::LENGTH: psopt = getDefSkip().length().asLatexString(); @@ -2186,7 +2196,7 @@ bool BufferParams::writeLaTeX(otexstream & os, LaTeXFeatures & features, // explicitly reset default (might have been changed // in a class or package) os << "\\parskip=.5\\baselineskip plus 2pt\\relax\n"; - } else { + } else if (!by_class_option) { // load parskip package with required options string psopts; if (!psopt.empty()) { diff --git a/src/TextClass.cpp b/src/TextClass.cpp index 339d8c90cf..7170cc2f2c 100644 --- a/src/TextClass.cpp +++ b/src/TextClass.cpp @@ -59,7 +59,7 @@ namespace lyx { // You should also run the development/tools/updatelayouts.py script, // to update the format of all of our layout files. // -int const LAYOUT_FORMAT = 104; // rkh: RefFormat for counters +int const LAYOUT_FORMAT = 105; // spitz: ParskipHalf and ParskipFull class options // Layout format for the current lyx file format. Controls which format is @@ -135,8 +135,8 @@ TextClass::TextClass() opt_enginetype_("authoryear|numerical"), opt_fontsize_("10|11|12"), opt_pagesize_("default|a4|a5|b5|letter|legal|executive"), opt_pagestyle_("empty|plain|headings|fancy"), fontsize_format_("$$spt"), pagesize_("default"), - pagesize_format_("$$spaper"), pagestyle_("default"), tablestyle_("default"), - docbookroot_("article"), docbookforceabstract_(false), + pagesize_format_("$$spaper"), pagestyle_("default"), parskip_full_(""), parskip_half_(""), + tablestyle_("default"), docbookroot_("article"), docbookforceabstract_(false), columns_(1), sides_(OneSide), secnumdepth_(3), tocdepth_(3), outputType_(LATEX), outputFormat_("latex"), has_output_format_(false), defaultfont_(sane_font), titletype_(TITLE_COMMAND_AFTER), titlename_("maketitle"), @@ -1027,6 +1027,8 @@ void TextClass::readClassOptions(Lexer & lexrc) CO_PAGESIZE, CO_PAGESIZE_FORMAT, CO_PAGESTYLE, + CO_PARSKIP_FULL, + CO_PARSKIP_HALF, CO_OTHER, CO_END }; @@ -1038,7 +1040,9 @@ void TextClass::readClassOptions(Lexer & lexrc) {"other", CO_OTHER }, {"pagesize", CO_PAGESIZE }, {"pagesizeformat", CO_PAGESIZE_FORMAT }, - {"pagestyle", CO_PAGESTYLE } + {"pagestyle", CO_PAGESTYLE }, + {"parskipfull", CO_PARSKIP_FULL }, + {"parskiphalf", CO_PARSKIP_HALF } }; lexrc.pushTable(classOptionsTags); @@ -1073,6 +1077,14 @@ void TextClass::readClassOptions(Lexer & lexrc) lexrc.next(); opt_pagestyle_ = rtrim(lexrc.getString()); break; + case CO_PARSKIP_FULL: + lexrc.next(); + parskip_full_ = rtrim(lexrc.getString()); + break; + case CO_PARSKIP_HALF: + lexrc.next(); + parskip_half_ = rtrim(lexrc.getString()); + break; case CO_OTHER: lexrc.next(); if (options_.empty()) diff --git a/src/TextClass.h b/src/TextClass.h index 2f42133491..5a7f4c45bd 100644 --- a/src/TextClass.h +++ b/src/TextClass.h @@ -288,6 +288,10 @@ protected: std::string pagesize_format_; /// std::string pagestyle_; + /// Option for full parskip + std::string parskip_full_; + /// Option for half parskip + std::string parskip_half_; /// std::string tablestyle_; /// @@ -480,6 +484,10 @@ public: /// std::string const & pagesizeformat() const { return pagesize_format_; } /// + std::string const & fullparskip() const { return parskip_full_; } + /// + std::string const & halfparskip() const { return parskip_half_; } + /// std::string const & pagestyle() const { return pagestyle_; } /// std::string const & tablestyle() const { return tablestyle_; } -- lyx-cvs mailing list lyx-cvs@lists.lyx.org http://lists.lyx.org/mailman/listinfo/lyx-cvs