2020-01-11 20:15:05 +00:00
|
|
|
{-# OPTIONS_GHC -Wno-orphans #-}
|
|
|
|
|
|
|
|
{-# LANGUAGE DataKinds #-}
|
|
|
|
{-# LANGUAGE DeriveGeneric #-}
|
|
|
|
{-# LANGUAGE FlexibleContexts #-}
|
|
|
|
{-# LANGUAGE FlexibleInstances #-}
|
|
|
|
{-# LANGUAGE MultiParamTypeClasses #-}
|
2020-03-21 21:19:37 +00:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
2020-01-11 20:15:05 +00:00
|
|
|
{-# LANGUAGE QuasiQuotes #-}
|
|
|
|
{-# LANGUAGE TemplateHaskell #-}
|
|
|
|
{-# LANGUAGE TypeFamilies #-}
|
|
|
|
|
2020-07-21 23:08:58 +00:00
|
|
|
{-|
|
|
|
|
Module : GHCup.Types.JSON
|
|
|
|
Description : GHCup JSON types/instances
|
|
|
|
Copyright : (c) Julian Ospald, 2020
|
2020-07-30 18:04:02 +00:00
|
|
|
License : LGPL-3.0
|
2020-07-21 23:08:58 +00:00
|
|
|
Maintainer : hasufell@hasufell.de
|
|
|
|
Stability : experimental
|
2021-05-14 21:09:45 +00:00
|
|
|
Portability : portable
|
2020-07-21 23:08:58 +00:00
|
|
|
-}
|
2020-01-11 20:15:05 +00:00
|
|
|
module GHCup.Types.JSON where
|
|
|
|
|
|
|
|
import GHCup.Types
|
2022-02-05 23:32:18 +00:00
|
|
|
import GHCup.Types.JSON.Utils
|
2022-05-21 20:54:18 +00:00
|
|
|
import GHCup.Prelude.MegaParsec
|
2020-01-11 20:15:05 +00:00
|
|
|
|
2020-08-10 20:22:48 +00:00
|
|
|
import Control.Applicative ( (<|>) )
|
2021-10-13 17:47:14 +00:00
|
|
|
import Data.Aeson hiding (Key)
|
2020-01-11 20:15:05 +00:00
|
|
|
import Data.Aeson.TH
|
2021-10-13 17:47:14 +00:00
|
|
|
import Data.Aeson.Types hiding (Key)
|
2020-11-20 17:37:48 +00:00
|
|
|
import Data.List.NonEmpty ( NonEmpty(..) )
|
2020-01-11 20:15:05 +00:00
|
|
|
import Data.Text.Encoding as E
|
|
|
|
import Data.Versions
|
2020-11-20 17:37:48 +00:00
|
|
|
import Data.Void
|
2020-01-11 20:15:05 +00:00
|
|
|
import URI.ByteString
|
2020-10-24 20:03:00 +00:00
|
|
|
import Text.Casing
|
2020-01-11 20:15:05 +00:00
|
|
|
|
2020-11-20 17:37:48 +00:00
|
|
|
import qualified Data.List.NonEmpty as NE
|
2020-01-11 20:15:05 +00:00
|
|
|
import qualified Data.Text as T
|
2022-02-05 23:32:18 +00:00
|
|
|
import qualified Data.Text.Encoding.Error as E
|
2020-11-20 17:37:48 +00:00
|
|
|
import qualified Text.Megaparsec as MP
|
|
|
|
import qualified Text.Megaparsec.Char as MPC
|
2020-01-11 20:15:05 +00:00
|
|
|
|
|
|
|
|
2023-01-01 11:04:00 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''MetaMode
|
2021-08-29 12:50:49 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''Architecture
|
2020-01-11 20:15:05 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''LinuxDistro
|
2021-05-14 21:09:45 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''VSep
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''VUnit
|
2020-10-24 20:55:35 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''MChunk
|
2020-01-11 20:15:05 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''Platform
|
2021-05-14 21:09:45 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''Mess
|
2020-01-11 20:15:05 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''SemVer
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''Tool
|
2021-05-14 21:09:45 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''GlobalTool
|
2020-10-24 20:03:00 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''KeepDirs
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''Downloader
|
2021-09-18 17:45:32 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''GPGSetting
|
2022-11-12 06:12:13 +00:00
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = \str' -> maybe str' T.unpack . T.stripPrefix (T.pack "r-") . T.pack . kebab . tail $ str' } ''PlatformRequest
|
2020-01-11 20:15:05 +00:00
|
|
|
|
2020-04-22 00:33:35 +00:00
|
|
|
instance ToJSON Tag where
|
2020-04-25 10:06:41 +00:00
|
|
|
toJSON Latest = String "Latest"
|
|
|
|
toJSON Recommended = String "Recommended"
|
2020-07-28 18:55:00 +00:00
|
|
|
toJSON Prerelease = String "Prerelease"
|
2020-10-09 20:55:33 +00:00
|
|
|
toJSON Old = String "old"
|
2020-04-25 10:06:41 +00:00
|
|
|
toJSON (Base pvp'') = String ("base-" <> prettyPVP pvp'')
|
|
|
|
toJSON (UnknownTag x ) = String (T.pack x)
|
2020-04-22 00:33:35 +00:00
|
|
|
|
|
|
|
instance FromJSON Tag where
|
|
|
|
parseJSON = withText "Tag" $ \t -> case T.unpack t of
|
2020-04-25 10:06:41 +00:00
|
|
|
"Latest" -> pure Latest
|
|
|
|
"Recommended" -> pure Recommended
|
2020-07-28 18:55:00 +00:00
|
|
|
"Prerelease" -> pure Prerelease
|
2020-10-09 20:55:33 +00:00
|
|
|
"old" -> pure Old
|
2020-04-25 10:06:41 +00:00
|
|
|
('b' : 'a' : 's' : 'e' : '-' : ver') -> case pvp (T.pack ver') of
|
|
|
|
Right x -> pure $ Base x
|
|
|
|
Left e -> fail . show $ e
|
2020-04-22 00:33:35 +00:00
|
|
|
x -> pure (UnknownTag x)
|
2020-01-11 20:15:05 +00:00
|
|
|
|
|
|
|
instance ToJSON URI where
|
2022-02-05 23:32:18 +00:00
|
|
|
toJSON = toJSON . E.decodeUtf8With E.lenientDecode . serializeURIRef'
|
2020-01-11 20:15:05 +00:00
|
|
|
|
2022-03-10 19:26:51 +00:00
|
|
|
|
2020-01-11 20:15:05 +00:00
|
|
|
instance FromJSON URI where
|
|
|
|
parseJSON = withText "URL" $ \t ->
|
|
|
|
case parseURI strictURIParserOptions (encodeUtf8 t) of
|
|
|
|
Right x -> pure x
|
|
|
|
Left e -> fail . show $ e
|
|
|
|
|
|
|
|
instance ToJSON Versioning where
|
|
|
|
toJSON = toJSON . prettyV
|
|
|
|
|
|
|
|
instance FromJSON Versioning where
|
|
|
|
parseJSON = withText "Versioning" $ \t -> case versioning t of
|
|
|
|
Right x -> pure x
|
|
|
|
Left e -> fail $ "Failure in Version (FromJSON)" <> show e
|
|
|
|
|
|
|
|
instance ToJSONKey Versioning where
|
|
|
|
toJSONKey = toJSONKeyText $ \x -> prettyV x
|
|
|
|
|
|
|
|
instance FromJSONKey Versioning where
|
|
|
|
fromJSONKey = FromJSONKeyTextParser $ \t -> case versioning t of
|
|
|
|
Right x -> pure x
|
|
|
|
Left e -> fail $ "Failure in Versioning (FromJSONKey)" <> show e
|
|
|
|
|
|
|
|
instance ToJSONKey (Maybe Versioning) where
|
|
|
|
toJSONKey = toJSONKeyText $ \case
|
|
|
|
Just x -> prettyV x
|
2020-04-10 15:36:27 +00:00
|
|
|
Nothing -> T.pack "unknown_versioning"
|
2020-01-11 20:15:05 +00:00
|
|
|
|
|
|
|
instance FromJSONKey (Maybe Versioning) where
|
|
|
|
fromJSONKey = FromJSONKeyTextParser $ \t ->
|
2020-11-20 21:39:39 +00:00
|
|
|
if t == T.pack "unknown_versioning" then pure Nothing else just t
|
2020-01-11 20:15:05 +00:00
|
|
|
where
|
|
|
|
just t = case versioning t of
|
2020-11-20 21:39:39 +00:00
|
|
|
Right x -> pure $ Just x
|
2020-01-11 20:15:05 +00:00
|
|
|
Left e -> fail $ "Failure in (Maybe Versioning) (FromJSONKey)" <> show e
|
|
|
|
|
|
|
|
instance ToJSONKey Platform where
|
|
|
|
toJSONKey = toJSONKeyText $ \case
|
|
|
|
Darwin -> T.pack "Darwin"
|
|
|
|
FreeBSD -> T.pack "FreeBSD"
|
|
|
|
Linux d -> T.pack ("Linux_" <> show d)
|
2021-05-14 21:09:45 +00:00
|
|
|
Windows -> T.pack "Windows"
|
2020-01-11 20:15:05 +00:00
|
|
|
|
|
|
|
instance FromJSONKey Platform where
|
|
|
|
fromJSONKey = FromJSONKeyTextParser $ \t -> if
|
|
|
|
| T.pack "Darwin" == t -> pure Darwin
|
|
|
|
| T.pack "FreeBSD" == t -> pure FreeBSD
|
2021-05-14 21:09:45 +00:00
|
|
|
| T.pack "Windows" == t -> pure Windows
|
2020-01-11 20:15:05 +00:00
|
|
|
| T.pack "Linux_" `T.isPrefixOf` t -> case
|
|
|
|
T.stripPrefix (T.pack "Linux_") t
|
|
|
|
of
|
|
|
|
Just dstr ->
|
|
|
|
case
|
|
|
|
(decodeStrict (E.encodeUtf8 (T.pack "\"" <> dstr <> T.pack "\"")) :: Maybe
|
|
|
|
LinuxDistro
|
|
|
|
)
|
|
|
|
of
|
|
|
|
Just d -> pure $ Linux d
|
|
|
|
Nothing ->
|
|
|
|
fail
|
|
|
|
$ "Unexpected failure in decoding LinuxDistro: "
|
|
|
|
<> show dstr
|
|
|
|
Nothing -> fail "Unexpected failure in Platform stripPrefix"
|
2021-03-11 16:03:51 +00:00
|
|
|
| otherwise -> fail "Failure in Platform (FromJSONKey)"
|
2020-01-11 20:15:05 +00:00
|
|
|
|
|
|
|
instance ToJSONKey Architecture where
|
|
|
|
toJSONKey = genericToJSONKey defaultJSONKeyOptions
|
|
|
|
|
|
|
|
instance FromJSONKey Architecture where
|
|
|
|
fromJSONKey = genericFromJSONKey defaultJSONKeyOptions
|
|
|
|
|
2020-04-10 15:36:27 +00:00
|
|
|
instance ToJSONKey (Maybe Version) where
|
|
|
|
toJSONKey = toJSONKeyText $ \case
|
|
|
|
Just x -> prettyVer x
|
|
|
|
Nothing -> T.pack "unknown_version"
|
|
|
|
|
|
|
|
instance FromJSONKey (Maybe Version) where
|
|
|
|
fromJSONKey = FromJSONKeyTextParser $ \t ->
|
2020-11-20 21:39:39 +00:00
|
|
|
if t == T.pack "unknown_version" then pure Nothing else just t
|
2020-04-10 15:36:27 +00:00
|
|
|
where
|
|
|
|
just t = case version t of
|
2020-11-20 21:39:39 +00:00
|
|
|
Right x -> pure $ Just x
|
2020-04-10 15:36:27 +00:00
|
|
|
Left e -> fail $ "Failure in (Maybe Version) (FromJSONKey)" <> show e
|
|
|
|
|
2020-01-11 20:15:05 +00:00
|
|
|
instance ToJSON Version where
|
|
|
|
toJSON = toJSON . prettyVer
|
|
|
|
|
|
|
|
instance FromJSON Version where
|
|
|
|
parseJSON = withText "Version" $ \t -> case version t of
|
|
|
|
Right x -> pure x
|
|
|
|
Left e -> fail $ "Failure in Version (FromJSON)" <> show e
|
|
|
|
|
|
|
|
instance ToJSONKey Version where
|
|
|
|
toJSONKey = toJSONKeyText $ \x -> prettyVer x
|
|
|
|
|
|
|
|
instance FromJSONKey Version where
|
|
|
|
fromJSONKey = FromJSONKeyTextParser $ \t -> case version t of
|
|
|
|
Right x -> pure x
|
|
|
|
Left e -> fail $ "Failure in Version (FromJSONKey)" <> show e
|
|
|
|
|
2020-04-22 00:33:35 +00:00
|
|
|
instance ToJSON PVP where
|
|
|
|
toJSON = toJSON . prettyPVP
|
|
|
|
|
|
|
|
instance FromJSON PVP where
|
|
|
|
parseJSON = withText "PVP" $ \t -> case pvp t of
|
|
|
|
Right x -> pure x
|
|
|
|
Left e -> fail $ "Failure in PVP (FromJSON)" <> show e
|
|
|
|
|
2020-01-11 20:15:05 +00:00
|
|
|
instance ToJSONKey Tool where
|
|
|
|
toJSONKey = genericToJSONKey defaultJSONKeyOptions
|
|
|
|
|
|
|
|
instance FromJSONKey Tool where
|
|
|
|
fromJSONKey = genericFromJSONKey defaultJSONKeyOptions
|
|
|
|
|
2021-05-14 21:09:45 +00:00
|
|
|
instance ToJSONKey GlobalTool where
|
|
|
|
toJSONKey = genericToJSONKey defaultJSONKeyOptions
|
2020-08-06 11:28:20 +00:00
|
|
|
|
2021-05-14 21:09:45 +00:00
|
|
|
instance FromJSONKey GlobalTool where
|
|
|
|
fromJSONKey = genericFromJSONKey defaultJSONKeyOptions
|
2020-08-06 11:28:20 +00:00
|
|
|
|
2020-08-10 20:22:48 +00:00
|
|
|
instance ToJSON TarDir where
|
|
|
|
toJSON (RealDir p) = toJSON p
|
|
|
|
toJSON (RegexDir r) = object ["RegexDir" .= r]
|
2020-08-06 11:28:20 +00:00
|
|
|
|
2020-08-10 20:22:48 +00:00
|
|
|
instance FromJSON TarDir where
|
|
|
|
parseJSON v = realDir v <|> regexDir v
|
|
|
|
where
|
|
|
|
realDir = withText "TarDir" $ \t -> do
|
|
|
|
fp <- parseJSON (String t)
|
|
|
|
pure (RealDir fp)
|
|
|
|
regexDir = withObject "TarDir" $ \o -> do
|
|
|
|
r <- o .: "RegexDir"
|
|
|
|
pure $ RegexDir r
|
2020-11-20 17:37:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
instance ToJSON VersionCmp where
|
|
|
|
toJSON = String . versionCmpToText
|
|
|
|
|
|
|
|
instance FromJSON VersionCmp where
|
|
|
|
parseJSON = withText "VersionCmp" $ \t -> do
|
|
|
|
case MP.parse versionCmpP "" t of
|
|
|
|
Right r -> pure r
|
|
|
|
Left e -> fail (MP.errorBundlePretty e)
|
|
|
|
|
|
|
|
versionCmpToText :: VersionCmp -> T.Text
|
|
|
|
versionCmpToText (VR_gt ver') = "> " <> prettyV ver'
|
|
|
|
versionCmpToText (VR_gteq ver') = ">= " <> prettyV ver'
|
|
|
|
versionCmpToText (VR_lt ver') = "< " <> prettyV ver'
|
|
|
|
versionCmpToText (VR_lteq ver') = "<= " <> prettyV ver'
|
|
|
|
versionCmpToText (VR_eq ver') = "== " <> prettyV ver'
|
|
|
|
|
|
|
|
versionCmpP :: MP.Parsec Void T.Text VersionCmp
|
|
|
|
versionCmpP =
|
|
|
|
fmap VR_gt (MP.try $ MPC.space *> MP.chunk ">" *> MPC.space *> versioningEnd)
|
|
|
|
<|> fmap
|
|
|
|
VR_gteq
|
|
|
|
(MP.try $ MPC.space *> MP.chunk ">=" *> MPC.space *> versioningEnd)
|
|
|
|
<|> fmap
|
|
|
|
VR_lt
|
|
|
|
(MP.try $ MPC.space *> MP.chunk "<" *> MPC.space *> versioningEnd)
|
|
|
|
<|> fmap
|
|
|
|
VR_lteq
|
|
|
|
(MP.try $ MPC.space *> MP.chunk "<=" *> MPC.space *> versioningEnd)
|
|
|
|
<|> fmap
|
|
|
|
VR_eq
|
|
|
|
(MP.try $ MPC.space *> MP.chunk "==" *> MPC.space *> versioningEnd)
|
|
|
|
<|> fmap
|
|
|
|
VR_eq
|
|
|
|
(MP.try $ MPC.space *> versioningEnd)
|
|
|
|
|
|
|
|
instance ToJSON VersionRange where
|
|
|
|
toJSON = String . verRangeToText
|
|
|
|
|
|
|
|
verRangeToText :: VersionRange -> T.Text
|
|
|
|
verRangeToText (SimpleRange cmps) =
|
|
|
|
let inner = foldr1 (\x y -> x <> " && " <> y)
|
|
|
|
(versionCmpToText <$> NE.toList cmps)
|
|
|
|
in "( " <> inner <> " )"
|
|
|
|
verRangeToText (OrRange cmps range) =
|
2021-03-11 16:03:51 +00:00
|
|
|
let left = verRangeToText (SimpleRange cmps)
|
2020-11-20 17:37:48 +00:00
|
|
|
right = verRangeToText range
|
|
|
|
in left <> " || " <> right
|
|
|
|
|
|
|
|
instance FromJSON VersionRange where
|
|
|
|
parseJSON = withText "VersionRange" $ \t -> do
|
|
|
|
case MP.parse versionRangeP "" t of
|
|
|
|
Right r -> pure r
|
|
|
|
Left e -> fail (MP.errorBundlePretty e)
|
|
|
|
|
|
|
|
versionRangeP :: MP.Parsec Void T.Text VersionRange
|
|
|
|
versionRangeP = go <* MP.eof
|
|
|
|
where
|
|
|
|
go =
|
|
|
|
MP.try orParse
|
|
|
|
<|> MP.try (fmap SimpleRange andParse)
|
2021-03-11 16:03:51 +00:00
|
|
|
<|> fmap (SimpleRange . pure) versionCmpP
|
2020-11-20 17:37:48 +00:00
|
|
|
|
|
|
|
orParse :: MP.Parsec Void T.Text VersionRange
|
|
|
|
orParse =
|
|
|
|
(\a o -> OrRange a o)
|
|
|
|
<$> (MP.try andParse <|> fmap pure versionCmpP)
|
|
|
|
<*> (MPC.space *> MP.chunk "||" *> MPC.space *> go)
|
|
|
|
|
|
|
|
andParse :: MP.Parsec Void T.Text (NonEmpty VersionCmp)
|
|
|
|
andParse =
|
|
|
|
fmap (\h t -> h :| t)
|
|
|
|
(MPC.space *> MP.chunk "(" *> MPC.space *> versionCmpP)
|
2021-03-11 16:03:51 +00:00
|
|
|
<*> MP.try (MP.many (MPC.space *> MP.chunk "&&" *> MPC.space *> versionCmpP))
|
2020-11-20 17:37:48 +00:00
|
|
|
<* MPC.space
|
|
|
|
<* MP.chunk ")"
|
|
|
|
<* MPC.space
|
|
|
|
|
|
|
|
versioningEnd :: MP.Parsec Void T.Text Versioning
|
|
|
|
versioningEnd =
|
|
|
|
MP.try (verP (MP.chunk " " <|> MP.chunk ")" <|> MP.chunk "&&") <* MPC.space)
|
|
|
|
<|> versioning'
|
|
|
|
|
|
|
|
instance ToJSONKey (Maybe VersionRange) where
|
|
|
|
toJSONKey = toJSONKeyText $ \case
|
|
|
|
Just x -> verRangeToText x
|
|
|
|
Nothing -> "unknown_versioning"
|
|
|
|
|
|
|
|
instance FromJSONKey (Maybe VersionRange) where
|
|
|
|
fromJSONKey = FromJSONKeyTextParser $ \t ->
|
|
|
|
if t == T.pack "unknown_versioning" then pure Nothing else just t
|
|
|
|
where
|
|
|
|
just t = case MP.parse versionRangeP "" t of
|
|
|
|
Right x -> pure $ Just x
|
|
|
|
Left e -> fail $ "Failure in (Maybe VersionRange) (FromJSONKey)" <> MP.errorBundlePretty e
|
2021-05-14 21:09:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''Requirements
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''DownloadInfo
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''VersionInfo
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = removeLensFieldLabel } ''GHCupInfo
|
2022-03-10 19:26:51 +00:00
|
|
|
deriveToJSON defaultOptions { sumEncoding = ObjectWithSingleField } ''URLSource
|
2021-05-14 21:09:45 +00:00
|
|
|
deriveJSON defaultOptions { sumEncoding = ObjectWithSingleField } ''Key
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = \str' -> maybe str' T.unpack . T.stripPrefix (T.pack "k-") . T.pack . kebab $ str' } ''UserKeyBindings
|
2021-08-03 06:09:47 +00:00
|
|
|
deriveToJSON defaultOptions { fieldLabelModifier = kebab } ''Settings
|
|
|
|
deriveToJSON defaultOptions { fieldLabelModifier = drop 2 . kebab } ''KeyBindings -- move under key-bindings key
|
2022-06-04 21:15:06 +00:00
|
|
|
|
|
|
|
instance FromJSON URLSource where
|
|
|
|
parseJSON v =
|
|
|
|
parseGHCupURL v
|
|
|
|
<|> parseOwnSourceLegacy v
|
|
|
|
<|> parseOwnSourceNew1 v
|
|
|
|
<|> parseOwnSourceNew2 v
|
|
|
|
<|> parseOwnSpec v
|
|
|
|
<|> legacyParseAddSource v
|
|
|
|
<|> newParseAddSource v
|
|
|
|
where
|
|
|
|
parseOwnSourceLegacy = withObject "URLSource" $ \o -> do
|
|
|
|
r :: URI <- o .: "OwnSource"
|
|
|
|
pure (OwnSource [Right r])
|
|
|
|
parseOwnSourceNew1 = withObject "URLSource" $ \o -> do
|
|
|
|
r :: [URI] <- o .: "OwnSource"
|
|
|
|
pure (OwnSource (fmap Right r))
|
|
|
|
parseOwnSourceNew2 = withObject "URLSource" $ \o -> do
|
|
|
|
r :: [Either GHCupInfo URI] <- o .: "OwnSource"
|
|
|
|
pure (OwnSource r)
|
|
|
|
parseOwnSpec = withObject "URLSource" $ \o -> do
|
|
|
|
r :: GHCupInfo <- o .: "OwnSpec"
|
|
|
|
pure (OwnSpec r)
|
|
|
|
parseGHCupURL = withObject "URLSource" $ \o -> do
|
|
|
|
_ :: [Value] <- o .: "GHCupURL"
|
|
|
|
pure GHCupURL
|
|
|
|
legacyParseAddSource = withObject "URLSource" $ \o -> do
|
|
|
|
r :: Either GHCupInfo URI <- o .: "AddSource"
|
|
|
|
pure (AddSource [r])
|
|
|
|
newParseAddSource = withObject "URLSource" $ \o -> do
|
|
|
|
r :: [Either GHCupInfo URI] <- o .: "AddSource"
|
|
|
|
pure (AddSource r)
|
|
|
|
|
|
|
|
deriveJSON defaultOptions { fieldLabelModifier = \str' -> maybe str' T.unpack . T.stripPrefix (T.pack "u-") . T.pack . kebab $ str' } ''UserSettings
|
|
|
|
|