File lout.spec of Package lout

# spec file for package lout
# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany.
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.

# Please submit bugfixes or comments via

%global makedocs 0
Name:           lout
Version:        3.40
Release:        1%{?dist}
Summary:        A document formatting system
License:        GPL-2.0-or-later
Group:          Productivity/Publishing/PS
Patch0:         makefile.patch
BuildRequires:  fdupes
BuildRequires:  ghostscript
%if !%{makedocs}
Source1:        design.pdf
Source2:        expert-guide.pdf
Source3:        user-guide.pdf
Source4:        slides.pdf

Lout is a document formatting system. The system reads a high-level
description of a document similar in style to LaTeX and produces a
PostScript file. Plain text output is also available, PDF output is
limited but working (e.g. no graphics). Either of these may be
fed to a printer. Lout is offered in multiple languages.

%setup -q
%patch0 -p1

make COPTS="%{optflags}" \
     BINDIR=%{_bindir} \
     LOUTLIBDIR=%{_datadir}/%{name} \
     LOUTDOCDIR=%{_datadir}/%{name}/doc \
     MANDIR=%{_mandir}/man1 \
     prg2lout lout

function render_docs {

    pushd doc/$subdir

    # We need to set the PATH variable here, because lout eventually exec's
    #   prg2lout.  In order for lout to find the latter, we have to set the
    #   PATH.
    # We also need to tell lout where to find its files, since we haven't
    #   installed them in their final location under %%{_datadir}/lout/ yet.
    PATH=$curdir lout \
       -I $curdir/include \
       -D $curdir/data \
       -F $curdir/font \
       -H $curdir/hyph \
       -C $curdir/maps \
       -r${passes} all >
    # Note that the above clobbers the prebuilt file that is
    # included in Lout's source tarball.
    ps2pdf ../${pdf_file}
    rm *.li *.ld

# For some reason, ps2pdf segfaults in koji.
%if %{makedocs}
render_docs design design.pdf       3
render_docs expert expert-guide.pdf 4
render_docs slides slides.pdf       2
render_docs user   user-guide.pdf   6
cp %{SOURCE1} %{SOURCE2} %{SOURCE3} %{SOURCE4} doc/

mkdir -p %{buildroot}/%{_bindir}
mkdir -p %{buildroot}/%{_datadir}/%{name}/doc
mkdir -p %{buildroot}/%{_mandir}/man1
make BINDIR=%{buildroot}%{_bindir} \
     LOUTLIBDIR=%{buildroot}%{_datadir}/%{name} \
     LOUTDOCDIR=%{buildroot}%{_datadir}/%{name}/doc \
     MANDIR=%{buildroot}%{_mandir}/man1 \
     install installman installdoc

# Looks like vim dump?
rm -rf %{buildroot}%{_datadir}/%{name}/doc/user/.pie_intr.swp

%fdupes %{buildroot}%{_datadir}/%{name}

%doc %attr(0644,-,-) README READMEPDF
%license COPYING
%dir %{_datadir}/%{name}