File: ShowCommits.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 (21 lines) | stat: -rw-r--r-- 776 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
21
module ShowCommits where

import qualified Github.PullRequests as Github
import Data.List
import Data.Maybe

main = do
  possiblePullRequestCommits <- Github.pullRequestCommits "thoughtbot" "paperclip" 575
  case possiblePullRequestCommits of
       (Left error)    -> putStrLn $ "Error: " ++ (show error)
       (Right commits) -> putStrLn $ intercalate "\n" $ map formatCommit commits

formatCommit commit =
  (formatAuthor $ Github.gitCommitAuthor gitCommit) ++ "\n" ++
    (maybe "unknown SHA" id $ Github.gitCommitSha gitCommit) ++ "\n" ++
    (Github.gitCommitMessage gitCommit)
  where gitCommit = Github.commitGitCommit commit

formatAuthor :: Github.GitUser -> String
formatAuthor author =
  (Github.gitUserName author) ++ " <" ++ (Github.gitUserEmail author) ++ ">"