Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
GHC
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Iterations
Merge Requests
0
Merge Requests
0
Requirements
Requirements
List
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Operations
Operations
Incidents
Environments
Packages & Registries
Packages & Registries
Package Registry
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issue
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Alex D
GHC
Commits
e6e95fc2
Commit
e6e95fc2
authored
Oct 30, 2017
by
Andrey Mokhov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move Sphinx builder into the library
See #347
parent
e04d2072
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
53 additions
and
41 deletions
+53
-41
hadrian.cabal
hadrian.cabal
+1
-1
src/Builder.hs
src/Builder.hs
+1
-10
src/Hadrian/Builder/Sphinx.hs
src/Hadrian/Builder/Sphinx.hs
+39
-0
src/Settings/Builders/Sphinx.hs
src/Settings/Builders/Sphinx.hs
+0
-22
src/Settings/Default.hs
src/Settings/Default.hs
+12
-8
No files found.
hadrian.cabal
View file @
e6e95fc2
...
@@ -28,6 +28,7 @@ executable hadrian
...
@@ -28,6 +28,7 @@ executable hadrian
, GHC
, GHC
, Hadrian.Builder
, Hadrian.Builder
, Hadrian.Builder.Ar
, Hadrian.Builder.Ar
, Hadrian.Builder.Sphinx
, Hadrian.Builder.Tar
, Hadrian.Builder.Tar
, Hadrian.Expression
, Hadrian.Expression
, Hadrian.Haskell.Cabal
, Hadrian.Haskell.Cabal
...
@@ -77,7 +78,6 @@ executable hadrian
...
@@ -77,7 +78,6 @@ executable hadrian
, Settings.Builders.HsCpp
, Settings.Builders.HsCpp
, Settings.Builders.Ld
, Settings.Builders.Ld
, Settings.Builders.Make
, Settings.Builders.Make
, Settings.Builders.Sphinx
, Settings.Builders.Xelatex
, Settings.Builders.Xelatex
, Settings.Default
, Settings.Default
, Settings.Flavours.Development
, Settings.Flavours.Development
...
...
src/Builder.hs
View file @
e6e95fc2
...
@@ -19,6 +19,7 @@ import GHC.Generics
...
@@ -19,6 +19,7 @@ import GHC.Generics
import
qualified
Hadrian.Builder
as
H
import
qualified
Hadrian.Builder
as
H
import
Hadrian.Builder
hiding
(
Builder
)
import
Hadrian.Builder
hiding
(
Builder
)
import
Hadrian.Builder.Ar
import
Hadrian.Builder.Ar
import
Hadrian.Builder.Sphinx
import
Hadrian.Builder.Tar
import
Hadrian.Builder.Tar
import
Hadrian.Oracles.Path
import
Hadrian.Oracles.Path
import
Hadrian.Oracles.TextFile
import
Hadrian.Oracles.TextFile
...
@@ -68,16 +69,6 @@ instance Binary HaddockMode
...
@@ -68,16 +69,6 @@ instance Binary HaddockMode
instance
Hashable
HaddockMode
instance
Hashable
HaddockMode
instance
NFData
HaddockMode
instance
NFData
HaddockMode
-- | Sphinx can be used in three different modes:
-- * Convert RST to HTML
-- * Convert RST to LaTeX
-- * Convert RST to Man pages
data
SphinxMode
=
Html
|
Latex
|
Man
deriving
(
Eq
,
Generic
,
Show
)
instance
Binary
SphinxMode
instance
Hashable
SphinxMode
instance
NFData
SphinxMode
-- | A 'Builder' is an external command invoked in a separate process via 'cmd'.
-- | A 'Builder' is an external command invoked in a separate process via 'cmd'.
-- @Ghc Stage0@ is the bootstrapping compiler.
-- @Ghc Stage0@ is the bootstrapping compiler.
-- @Ghc StageN@, N > 0, is the one built in stage (N - 1).
-- @Ghc StageN@, N > 0, is the one built in stage (N - 1).
...
...
src/Hadrian/Builder/Sphinx.hs
0 → 100644
View file @
e6e95fc2
-----------------------------------------------------------------------------
-- |
-- Module : Hadrian.Builder.Sphinx
-- Copyright : (c) Andrey Mokhov 2014-2017
-- License : MIT (see the file LICENSE)
-- Maintainer : andrey.mokhov@gmail.com
-- Stability : experimental
--
-- Support for invoking the documentation utility Sphinx.
-----------------------------------------------------------------------------
module
Hadrian.Builder.Sphinx
(
SphinxMode
(
..
),
args
)
where
import
Development.Shake
import
Development.Shake.Classes
import
GHC.Generics
import
Hadrian.Expression
import
Hadrian.Utilities
-- | Sphinx can be used in three different modes to convert reStructuredText
-- documents into HTML, LaTeX or Man pages.
data
SphinxMode
=
Html
|
Latex
|
Man
deriving
(
Eq
,
Generic
,
Show
)
instance
Binary
SphinxMode
instance
Hashable
SphinxMode
instance
NFData
SphinxMode
-- | Default command line arguments for invoking the archiving utility @tar@.
args
::
(
ShakeValue
c
,
ShakeValue
b
)
=>
SphinxMode
->
Args
c
b
args
mode
=
do
outPath
<-
getOutput
mconcat
[
arg
"-b"
,
arg
modeString
,
arg
"-d"
,
arg
$
outPath
-/-
(
".doctrees-"
++
modeString
)
,
arg
=<<
getInput
,
arg
outPath
]
where
modeString
=
case
mode
of
Html
->
"html"
Latex
->
"latex"
Man
->
"man"
src/Settings/Builders/Sphinx.hs
deleted
100644 → 0
View file @
e04d2072
module
Settings.Builders.Sphinx
(
sphinxBuilderArgs
)
where
import
Settings.Builders.Common
sphinxBuilderArgs
::
Args
sphinxBuilderArgs
=
do
outPath
<-
getOutput
mconcat
[
builder
(
Sphinx
Html
)
?
mconcat
[
arg
"-b"
,
arg
"html"
,
arg
"-d"
,
arg
$
outPath
-/-
".doctrees-html"
,
arg
=<<
getInput
,
arg
outPath
]
,
builder
(
Sphinx
Latex
)
?
mconcat
[
arg
"-b"
,
arg
"latex"
,
arg
"-d"
,
arg
$
outPath
-/-
".doctrees-latex"
,
arg
=<<
getInput
,
arg
outPath
]
,
builder
(
Sphinx
Man
)
?
mconcat
[
arg
"-b"
,
arg
"man"
,
arg
"-d"
,
arg
$
outPath
-/-
".doctrees-man"
,
arg
=<<
getInput
,
arg
outPath
]
]
src/Settings/Default.hs
View file @
e6e95fc2
...
@@ -6,6 +6,7 @@ module Settings.Default (
...
@@ -6,6 +6,7 @@ module Settings.Default (
import
qualified
Hadrian.Builder.Ar
import
qualified
Hadrian.Builder.Ar
import
qualified
Hadrian.Builder.Tar
import
qualified
Hadrian.Builder.Tar
import
qualified
Hadrian.Builder.Sphinx
import
CommandLine
import
CommandLine
import
Expression
import
Expression
...
@@ -28,7 +29,6 @@ import Settings.Builders.Hsc2Hs
...
@@ -28,7 +29,6 @@ import Settings.Builders.Hsc2Hs
import
Settings.Builders.HsCpp
import
Settings.Builders.HsCpp
import
Settings.Builders.Ld
import
Settings.Builders.Ld
import
Settings.Builders.Make
import
Settings.Builders.Make
import
Settings.Builders.Sphinx
import
Settings.Builders.Xelatex
import
Settings.Builders.Xelatex
import
Settings.Packages.Base
import
Settings.Packages.Base
import
Settings.Packages.Cabal
import
Settings.Packages.Cabal
...
@@ -39,7 +39,7 @@ import Settings.Packages.Ghci
...
@@ -39,7 +39,7 @@ import Settings.Packages.Ghci
import
Settings.Packages.GhcPkg
import
Settings.Packages.GhcPkg
import
Settings.Packages.GhcPrim
import
Settings.Packages.GhcPrim
import
Settings.Packages.Haddock
import
Settings.Packages.Haddock
import
Settings.Packages.Haskeline
(
haskelinePackageArgs
)
import
Settings.Packages.Haskeline
import
Settings.Packages.IntegerGmp
import
Settings.Packages.IntegerGmp
import
Settings.Packages.Rts
import
Settings.Packages.Rts
import
Settings.Packages.RunGhc
import
Settings.Packages.RunGhc
...
@@ -140,9 +140,8 @@ defaultSplitObjects = do
...
@@ -140,9 +140,8 @@ defaultSplitObjects = do
-- | All 'Builder'-dependent command line arguments.
-- | All 'Builder'-dependent command line arguments.
defaultBuilderArgs
::
Args
defaultBuilderArgs
::
Args
defaultBuilderArgs
=
mconcat
defaultBuilderArgs
=
mconcat
-- GHC-specific builders:
[
alexBuilderArgs
[
alexBuilderArgs
,
builder
(
Ar
Pack
)
?
Hadrian
.
Builder
.
Ar
.
args
Pack
,
builder
(
Ar
Unpack
)
?
Hadrian
.
Builder
.
Ar
.
args
Unpack
,
ccBuilderArgs
,
ccBuilderArgs
,
configureBuilderArgs
,
configureBuilderArgs
,
deriveConstantsBuilderArgs
,
deriveConstantsBuilderArgs
...
@@ -158,10 +157,15 @@ defaultBuilderArgs = mconcat
...
@@ -158,10 +157,15 @@ defaultBuilderArgs = mconcat
,
hsCppBuilderArgs
,
hsCppBuilderArgs
,
ldBuilderArgs
,
ldBuilderArgs
,
makeBuilderArgs
,
makeBuilderArgs
,
sphinxBuilderArgs
,
xelatexBuilderArgs
,
builder
(
Tar
Create
)
?
Hadrian
.
Builder
.
Tar
.
args
Create
-- Generic builders from the Hadrian library:
,
builder
(
Tar
Extract
)
?
Hadrian
.
Builder
.
Tar
.
args
Extract
,
builder
(
Ar
Pack
)
?
Hadrian
.
Builder
.
Ar
.
args
Pack
,
xelatexBuilderArgs
]
,
builder
(
Ar
Unpack
)
?
Hadrian
.
Builder
.
Ar
.
args
Unpack
,
builder
(
Sphinx
Html
)
?
Hadrian
.
Builder
.
Sphinx
.
args
Html
,
builder
(
Sphinx
Latex
)
?
Hadrian
.
Builder
.
Sphinx
.
args
Latex
,
builder
(
Sphinx
Man
)
?
Hadrian
.
Builder
.
Sphinx
.
args
Man
,
builder
(
Tar
Create
)
?
Hadrian
.
Builder
.
Tar
.
args
Create
,
builder
(
Tar
Extract
)
?
Hadrian
.
Builder
.
Tar
.
args
Extract
]
-- TODO: Disable warnings for Windows specifics.
-- TODO: Disable warnings for Windows specifics.
-- TODO: Move this elsewhere?
-- TODO: Move this elsewhere?
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment