Skip to content

Commit

Permalink
Merge pull request #94 from zliu41/shebang
Browse files Browse the repository at this point in the history
Sort comments properly, ignoring SrcSpan's file
  • Loading branch information
alanz authored Sep 14, 2020
2 parents ff436e7 + be076f6 commit 81c2ef9
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 15 deletions.
14 changes: 10 additions & 4 deletions src/Language/Haskell/GHC/ExactPrint/Delta.hs
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ import Control.Monad.RWS
import Control.Monad.Trans.Free

import Data.Data (Data)
import Data.List (sort, nub, partition, sortBy)
import Data.List (sort, nub, partition, sortBy, sortOn)

import Data.Ord

Expand Down Expand Up @@ -746,8 +746,15 @@ commentAllocation p k = do
cs <- getUnallocatedComments
let (allocated,cs') = allocateComments p cs
putUnallocatedComments cs'
k =<< mapM makeDeltaComment (sortBy (comparing commentIdentifier) allocated)

k =<< mapM makeDeltaComment (sortOn (unpack . commentIdentifier) allocated)
where
-- unpack a RealSrcSpan into ((start line, start col), (end line, end col)).
-- The file name is ignored.
unpack :: GHC.SrcSpan -> Maybe ((Int, Int), (Int, Int))
unpack (GHC.RealSrcSpan x) =
Just ( (GHC.srcSpanStartLine x, GHC.srcSpanStartCol x)
, (GHC.srcSpanEndLine x, GHC.srcSpanEndCol x) )
unpack _ = Nothing

makeDeltaComment :: Comment -> Delta (Comment, DeltaPos)
makeDeltaComment c = do
Expand Down Expand Up @@ -875,4 +882,3 @@ countAnnsDelta :: GHC.AnnKeywordId -> Delta Int
countAnnsDelta ann = do
ma <- peekAnnotationDelta ann
return (length ma)

4 changes: 2 additions & 2 deletions src/Language/Haskell/GHC/ExactPrint/Parsers.hs
Original file line number Diff line number Diff line change
Expand Up @@ -338,10 +338,10 @@ postParseTransform
:: Either a (GHC.ApiAnns, [Comment], GHC.DynFlags, GHC.ParsedSource)
-> DeltaOptions
-> Either a (Anns, GHC.ParsedSource)
postParseTransform parseRes opts = either Left mkAnns parseRes
postParseTransform parseRes opts = fmap mkAnns parseRes
where
mkAnns (apianns, cs, _, m) =
Right (relativiseApiAnnsWithOptions opts cs m apianns, m)
(relativiseApiAnnsWithOptions opts cs m apianns, m)

-- | Internal function. Initializes DynFlags value for parsing.
--
Expand Down
2 changes: 1 addition & 1 deletion tests/Test/Common.hs
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ import System.FilePath

-- import Debug.Trace
testPrefix :: FilePath
testPrefix = "tests" </> "examples"
testPrefix = "." </> "tests" </> "examples"

testList :: String -> [Test] -> Test
testList s ts = TestLabel s (TestList ts)
Expand Down
10 changes: 2 additions & 8 deletions tests/examples/failing/overloadedlabelsrun04.hs.bad
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,11 @@

import OverloadedLabelsRun04_A



-- Who knew that there were so many ways that a line could start with
-- a # sign in Haskell? None of these are overloaded labels:


#!notashellscript

-- But this one is:
-- a # sign in Haskell? None of these are overloaded labels:





#foo

0 comments on commit 81c2ef9

Please sign in to comment.