1
0
Fork 0
mirror of https://code.sup39.dev/repos/Wqawg synced 2025-01-14 14:35:09 +09:00

UI: Fix and re-enable getRepoCommitsR (i.e. repo history view)

This commit is contained in:
fr33domlover 2022-09-16 12:46:52 +00:00
parent 91cdbf51ab
commit b66bab4295
5 changed files with 37 additions and 58 deletions

View file

@ -17,9 +17,9 @@
module Vervis.Darcs module Vervis.Darcs
( --readSourceView ( --readSourceView
--, readWikiView --, readWikiView
--, readChangesView readChangesView
--, lastChange --, lastChange
readPatch , readPatch
, writePostApplyHooks , writePostApplyHooks
--, applyDarcsPatch --, applyDarcsPatch
) )
@ -220,7 +220,6 @@ readWikiView isPage isMain path dir = do
for mpage $ \ (load, mmtitle) -> mkview mmtitle <$> load for mpage $ \ (load, mmtitle) -> mkview mmtitle <$> load
-} -}
{-
readChangesView readChangesView
:: FilePath :: FilePath
-- ^ Repository path -- ^ Repository path
@ -261,7 +260,6 @@ lastChange path now = fmap maybeRight $ runExceptT $ do
intervalToEventTime $ intervalToEventTime $
FriendlyConvert $ FriendlyConvert $
now `diffUTCTime` piTime pi now `diffUTCTime` piTime pi
-}
data Change data Change
= AddFile FilePath = AddFile FilePath

View file

@ -16,9 +16,9 @@
module Vervis.Git module Vervis.Git
( --readSourceView ( --readSourceView
--, readChangesView readChangesView
--, listRefs , listRefs
readPatch , readPatch
--, lastCommitTime --, lastCommitTime
, writePostReceiveHooks , writePostReceiveHooks
--, applyGitPatches --, applyGitPatches
@ -171,6 +171,7 @@ readSourceView path ref dir = do
G.withRepo (fromString path) $ \ git -> loadSourceView git ref dir G.withRepo (fromString path) $ \ git -> loadSourceView git ref dir
let toTexts = S.mapMonotonic $ T.pack . refNameRaw let toTexts = S.mapMonotonic $ T.pack . refNameRaw
return (toTexts bs, toTexts ts, renderSources dir <$> msv) return (toTexts bs, toTexts ts, renderSources dir <$> msv)
-}
readChangesView readChangesView
:: FilePath :: FilePath
@ -213,7 +214,6 @@ readChangesView path ref off lim = G.withRepo (fromString path) $ \ git -> do
listRefs :: FilePath -> IO (Set Text, Set Text) listRefs :: FilePath -> IO (Set Text, Set Text)
listRefs path = G.withRepo (fromString path) $ \ git -> listRefs path = G.withRepo (fromString path) $ \ git ->
(,) <$> listBranches git <*> listTags git (,) <$> listBranches git <*> listTags git
-}
patch :: [Edit] -> Commit SHA1 -> P.Patch patch :: [Edit] -> Commit SHA1 -> P.Patch
patch edits c = P.Patch patch edits c = P.Patch

View file

@ -111,7 +111,7 @@ import Text.Pandoc.Highlighting
import Yesod.Auth import Yesod.Auth
import Yesod.Core hiding (joinPath) import Yesod.Core hiding (joinPath)
import Yesod.Core.Content import Yesod.Core.Content
import Yesod.Core.Handler (lookupPostParam, redirect, notFound) import Yesod.Core.Handler
import Yesod.Form.Functions (runFormPost) import Yesod.Form.Functions (runFormPost)
import Yesod.Form.Types (FormResult (..)) import Yesod.Form.Types (FormResult (..))
import Yesod.Persist.Core import Yesod.Persist.Core
@ -379,24 +379,19 @@ getRepoCommitsR repoHash = do
repoID <- decodeKeyHashid404 repoHash repoID <- decodeKeyHashid404 repoHash
repo <- runDB $ get404 repoID repo <- runDB $ get404 repoID
case repoVcs repo of case repoVcs repo of
VCSDarcs -> VCSDarcs -> getDarcsRepoChanges repoHash
error "Temporarily disabled" VCSGit -> selectRep $ do
--getDarcsRepoHeadChanges repoHash AP.provideAP (notFound :: Handler ())
VCSGit -> provideRepType typeHtml
error "Temporarily disabled" ((redirect $ RepoBranchCommitsR repoHash $ repoMainBranch repo) :: Handler ())
--getGitRepoHeadChanges repo repoHash
getRepoBranchCommitsR :: KeyHashid Repo -> Text -> Handler TypedContent getRepoBranchCommitsR :: KeyHashid Repo -> Text -> Handler TypedContent
getRepoBranchCommitsR repoHash branch = do getRepoBranchCommitsR repoHash branch = do
repoID <- decodeKeyHashid404 repoHash repoID <- decodeKeyHashid404 repoHash
repo <- runDB $ get404 repoID repo <- runDB $ get404 repoID
case repoVcs repo of case repoVcs repo of
VCSDarcs -> VCSDarcs -> notFound
error "Temporarily disabled" VCSGit -> getGitRepoChanges repoHash branch
--getDarcsRepoChanges repoHash branch
VCSGit ->
error "Temporarily disabled"
--getGitRepoChanges repoHash branch
getRepoCommitR :: KeyHashid Repo -> Text -> Handler TypedContent getRepoCommitR :: KeyHashid Repo -> Text -> Handler TypedContent
getRepoCommitR repoHash ref = do getRepoCommitR repoHash ref = do

View file

@ -1,6 +1,7 @@
{- This file is part of Vervis. {- This file is part of Vervis.
- -
- Written in 2016, 2018, 2019, 2020 by fr33domlover <fr33domlover@riseup.net>. - Written in 2016, 2018, 2019, 2020, 2022
- by fr33domlover <fr33domlover@riseup.net>.
- -
- Copying is an act of love. Please copy, reuse and share. - Copying is an act of love. Please copy, reuse and share.
- -
@ -15,9 +16,8 @@
module Vervis.Web.Darcs module Vervis.Web.Darcs
( --getDarcsRepoSource ( --getDarcsRepoSource
--, getDarcsRepoHeadChanges getDarcsRepoChanges
--, getDarcsRepoChanges , getDarcsPatch
getDarcsPatch
) )
where where
@ -72,6 +72,7 @@ import Vervis.SourceTree
import Vervis.Style import Vervis.Style
import Vervis.Time import Vervis.Time
import Vervis.Web.Repo import Vervis.Web.Repo
import Vervis.Widget.Repo
import qualified Vervis.Darcs as D import qualified Vervis.Darcs as D
@ -101,11 +102,10 @@ getDarcsRepoSource (mproject, repository) user repo dir = do
(return $ repoFollowers repository) (return $ repoFollowers repository)
-} -}
{- getDarcsRepoChanges :: KeyHashid Repo -> Handler TypedContent
getDarcsRepoHeadChanges :: ShrIdent -> RpIdent -> Handler TypedContent getDarcsRepoChanges repo = do
getDarcsRepoHeadChanges shar repo = do path <- askRepoDir repo
path <- askRepoDir shar repo let here = RepoCommitsR repo
let here = RepoHeadChangesR shar repo
encodeRouteLocal <- getEncodeRouteLocal encodeRouteLocal <- getEncodeRouteLocal
encodeRouteHome <- getEncodeRouteHome encodeRouteHome <- getEncodeRouteHome
encodeRoutePageLocal <- getEncodeRoutePageLocal encodeRoutePageLocal <- getEncodeRoutePageLocal
@ -149,20 +149,14 @@ getDarcsRepoHeadChanges shar repo = do
else Nothing else Nothing
, collectionPageStartIndex = Nothing , collectionPageStartIndex = Nothing
, collectionPageItems = , collectionPageItems =
map (encodeRouteHome . RepoCommitR shar repo . leHash) map (encodeRouteHome . RepoCommitR repo . leHash)
items items
} }
feed = changeFeed shar repo Nothing VCSDarcs items feed = changeFeed repo Nothing VCSDarcs items
in provideHtmlFeedAndAP page feed $ in provideHtmlFeedAndAP page feed $
let changes = changesW shar repo items let changes = changesW repo items
pageNav = navWidget navModel pageNav = navWidget navModel
in $(widgetFile "repo/changes-darcs") in $(widgetFile "repo/changes-darcs")
-}
{-
getDarcsRepoChanges :: ShrIdent -> RpIdent -> Text -> Handler TypedContent
getDarcsRepoChanges shar repo tag = notFound
-}
getDarcsPatch :: KeyHashid Repo -> Text -> Handler TypedContent getDarcsPatch :: KeyHashid Repo -> Text -> Handler TypedContent
getDarcsPatch hash ref = do getDarcsPatch hash ref = do

View file

@ -16,10 +16,9 @@
module Vervis.Web.Git module Vervis.Web.Git
( --getGitRepoSource ( --getGitRepoSource
--, getGitRepoHeadChanges
--, getGitRepoBranch --, getGitRepoBranch
--, getGitRepoChanges getGitRepoChanges
getGitPatch , getGitPatch
) )
where where
@ -89,6 +88,7 @@ import Vervis.SourceTree
import Vervis.Style import Vervis.Style
import Vervis.Time (showDate) import Vervis.Time (showDate)
import Vervis.Web.Repo import Vervis.Web.Repo
import Vervis.Widget.Repo
import qualified Data.ByteString.Lazy as BL (ByteString) import qualified Data.ByteString.Lazy as BL (ByteString)
import qualified Vervis.Git as G import qualified Vervis.Git as G
@ -119,12 +119,6 @@ getGitRepoSource (mproject, repository) user repo ref dir = do
(return $ repoFollowers repository) (return $ repoFollowers repository)
-} -}
{-
getGitRepoHeadChanges :: Repo -> ShrIdent -> RpIdent -> Handler TypedContent
getGitRepoHeadChanges repository shar repo =
getGitRepoChanges shar repo $ repoMainBranch repository
-}
{- {-
getGitRepoBranch :: ShrIdent -> RpIdent -> Text -> Handler TypedContent getGitRepoBranch :: ShrIdent -> RpIdent -> Text -> Handler TypedContent
getGitRepoBranch shar repo ref = do getGitRepoBranch shar repo ref = do
@ -143,14 +137,13 @@ getGitRepoBranch shar repo ref = do
else notFound else notFound
-} -}
{- getGitRepoChanges :: KeyHashid Repo -> Text -> Handler TypedContent
getGitRepoChanges :: ShrIdent -> RpIdent -> Text -> Handler TypedContent getGitRepoChanges repo ref = do
getGitRepoChanges shar repo ref = do path <- askRepoDir repo
path <- askRepoDir shar repo
(branches, tags) <- liftIO $ G.listRefs path (branches, tags) <- liftIO $ G.listRefs path
unless (ref `S.member` branches || ref `S.member` tags) unless (ref `S.member` branches || ref `S.member` tags)
notFound notFound
let here = RepoChangesR shar repo ref let here = RepoBranchCommitsR repo ref
encodeRouteLocal <- getEncodeRouteLocal encodeRouteLocal <- getEncodeRouteLocal
encodeRouteHome <- getEncodeRouteHome encodeRouteHome <- getEncodeRouteHome
encodeRoutePageLocal <- getEncodeRoutePageLocal encodeRoutePageLocal <- getEncodeRoutePageLocal
@ -190,16 +183,15 @@ getGitRepoChanges shar repo ref = do
else Nothing else Nothing
, collectionPageStartIndex = Nothing , collectionPageStartIndex = Nothing
, collectionPageItems = , collectionPageItems =
map (encodeRouteHome . RepoCommitR shar repo . leHash) map (encodeRouteHome . RepoCommitR repo . leHash)
items items
} }
feed = changeFeed shar repo (Just ref) VCSGit items feed = changeFeed repo (Just ref) VCSGit items
in provideHtmlFeedAndAP page feed $ in provideHtmlFeedAndAP page feed $
let refSelect = refSelectW shar repo branches tags let refSelect = refSelectW repo branches tags
changes = changesW shar repo items changes = changesW repo items
pageNav = navWidget navModel pageNav = navWidget navModel
in $(widgetFile "repo/changes-git") in $(widgetFile "repo/changes-git")
-}
getGitPatch :: KeyHashid Repo -> Text -> Handler TypedContent getGitPatch :: KeyHashid Repo -> Text -> Handler TypedContent
getGitPatch hash ref = do getGitPatch hash ref = do