Send Beginners mailing list submissions to
[email protected]
To subscribe or unsubscribe via the World Wide Web, visit
http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners
or, via email, send a message with subject or body 'help' to
[email protected]
You can reach the person managing the list at
[email protected]
When replying, please edit your Subject line so it is more specific
than "Re: Contents of Beginners digest..."
Today's Topics:
1. Setup.hs woes (Ramnath R Iyer)
2. Traversable Instance of the Constant type (Atrudyjane)
----------------------------------------------------------------------
Message: 1
Date: Wed, 19 Apr 2017 16:21:58 +0000
From: Ramnath R Iyer <[email protected]>
To: The Haskell-Beginners Mailing List - Discussion of primarily
beginner-level topics related to Haskell <[email protected]>
Subject: [Haskell-beginners] Setup.hs woes
Message-ID:
<CACL-Fmyr3JkGwUvkkqCe83VJa17T1=ohytygcajdnsjg5jd...@mail.gmail.com>
Content-Type: text/plain; charset="utf-8"
Hello,
I've been having some trouble with Setup.hs and could use some help. I'm
using stack for building my project, and would like to auto-generate an
HTML file as part of the build process. I'm able to specify hooks in
Setup.hs to do this, but I'm running into problems.
1. I'm not sure what the "correct" or suitable paths are for publishing
HTML documentation. The closest I could find was the doc dir on the install
path (see below). Should the HTML be created in a built folder and later
copied over to an install/dist dir? The semantics associated with each of
these is not clear to me.
2. I played around with some hooks. I was able to generate the HTML file in
the installation's doc dir, but it looks like that dir is only created as
part of the install hook (naturally), whereas the install hook is never
triggered by `stack build`. (The code below never executes if I use the
instHook.) What is the right hook to use, and how?
import Distribution.PackageDescription (PackageDescription)
import Distribution.Simple (defaultMainWithHooks, simpleUserHooks)
import Distribution.Simple.InstallDirs (InstallDirs(..), docdir)
import Distribution.Simple.LocalBuildInfo (LocalBuildInfo(..),
installDirTemplates, fromPathTemplate)
import Distribution.Simple.Setup (InstallFlags)
import Distribution.Simple.UserHooks (UserHooks, instHook)
import System.Exit (ExitCode(..))
import System.Process (system)
main :: IO ()
main = defaultMainWithHooks simpleUserHooks { instHook = readme } -- does
not get invoked; postBuild does work, but where to put the generated file?
readme :: PackageDescription -> LocalBuildInfo -> UserHooks -> InstallFlags
-> IO ()
readme _ (LocalBuildInfo { installDirTemplates = InstallDirs { docdir =
docdir' }}) _ _ = do
putStrLn "Generating README.html from README.md..."
exitCode <- system $ "./doc/generate " ++ (show destination)
case exitCode of ExitSuccess -> return ()
ExitFailure _ -> fail "README.html could not be
generated from README.md"
return ()
where destination = fromPathTemplate docdir'
***
(Apologies if this is a duplicate email, wasn't sure if this already got
sent previously.)
-------------- next part --------------
An HTML attachment was scrubbed...
URL:
<http://mail.haskell.org/pipermail/beginners/attachments/20170419/451c7081/attachment-0001.html>
------------------------------
Message: 2
Date: Thu, 20 Apr 2017 01:53:05 -0400
From: Atrudyjane <[email protected]>
To: The Haskell-Beginners Mailing List - Discussion of primarily
beginner-level topics related to Haskell <[email protected]>
Subject: [Haskell-beginners] Traversable Instance of the Constant type
Message-ID:
<80UdLI1sUOnx-ehLufWkeUeOdHHrnubv8bRr3w8uuNM0TJizIPj-rb3CiCEuLFabbUw-jgYZhdYUSAuAIzBQ3AwTcj9x9a7mWSIl3L2pf_c=@protonmail.com>
Content-Type: text/plain; charset="utf-8"
Pretty sure I'm getting bogged down on something simple, but how does the
traverse function actually embed the Constant type in the f context passed to
it? Or is it the pure defined in the f context that's being called?
Thank you,
Andrea
newtype Constant a b = Constant { getConstant :: a } deriving (Eq, Show)
instance Functor (Constant a) where
fmap f (Constant a) = Constant a
instance Monoid a => Applicative (Constant a) where
pure a = Constant { getConstant = mempty }
Constant a <*> Constant b = Constant { getConstant = a `mappend` b }
instance Foldable (Constant a) where
foldMap f (Constant a) = mempty
instance Traversable (Constant a) where
traverse f (Constant a) = pure $ Constant a
λ> traverse (\x -> Just x) (Constant 1)
Just (Constant {getConstant = 1})
Sent with [ProtonMail](https://protonmail.com) Secure Email.
-------------- next part --------------
An HTML attachment was scrubbed...
URL:
<http://mail.haskell.org/pipermail/beginners/attachments/20170420/1fa6e012/attachment-0001.html>
------------------------------
Subject: Digest Footer
_______________________________________________
Beginners mailing list
[email protected]
http://mail.haskell.org/cgi-bin/mailman/listinfo/beginners
------------------------------
End of Beginners Digest, Vol 106, Issue 14
******************************************