File: ShowGist.hs

package info (click to toggle)
haskell-github 0.8-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 444 kB
  • sloc: haskell: 2,572; makefile: 2
file content (20 lines) | stat: -rw-r--r-- 642 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
module ShowGist where

import qualified Github.Gists as Github
import Data.List (intercalate)

main = do
  possibleGist <- Github.gist "23084"
  case possibleGist of
    (Left error)  -> putStrLn $ "Error: " ++ (show error)
    (Right gist) -> putStrLn $ formatGist gist

formatGist gist =
  (Github.gistId gist) ++ "\n" ++
    (maybe "indescribable" id $ Github.gistDescription gist) ++ "\n" ++
    (Github.gistHtmlUrl gist) ++ "\n\n" ++
    (intercalate "\n\n" $ map formatGistFile $ Github.gistFiles gist)

formatGistFile gistFile =
  (Github.gistFileFilename gistFile) ++ ":\n" ++
    maybe "[empty]" id (Github.gistFileContent gistFile)