Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
haskell-gargantext
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Christian Merten
haskell-gargantext
Commits
ca7ecf6d
Commit
ca7ecf6d
authored
Jun 27, 2022
by
Przemyslaw Kaminski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[Ngrams] reordering of type fields
parent
7e48f5a8
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
54 additions
and
71 deletions
+54
-71
Ngrams.hs
src/Gargantext/Core/Types/Ngrams.hs
+54
-71
No files found.
src/Gargantext/Core/Types/Ngrams.hs
View file @
ca7ecf6d
...
@@ -13,7 +13,7 @@ import qualified Data.HashMap.Strict.InsOrd as InsOrdHashMap
...
@@ -13,7 +13,7 @@ import qualified Data.HashMap.Strict.InsOrd as InsOrdHashMap
import
Data.Foldable
(
foldMap
)
import
Data.Foldable
(
foldMap
)
import
qualified
Data.List
as
List
import
qualified
Data.List
as
List
import
Data.Map.Strict.Patch
(
PatchMap
)
import
Data.Map.Strict.Patch
(
PatchMap
)
import
Data.Patch.Class
(
Composable
,
ConflictResolution
,
ConflictResolutionReplace
,
Group
,
Patched
,
Replace
,
Transformable
(
..
))
import
Data.Patch.Class
(
Action
(
..
),
Applicable
(
..
),
Composable
,
ConflictResolution
,
ConflictResolutionReplace
,
Group
,
MaybePatch
(
Mod
),
Patched
,
PairPatch
(
..
)
,
Replace
,
Transformable
(
..
))
import
Data.Proxy
(
Proxy
(
..
))
import
Data.Proxy
(
Proxy
(
..
))
import
Data.Semigroup
(
Semigroup
)
import
Data.Semigroup
(
Semigroup
)
import
Data.Map.Strict
(
Map
)
import
Data.Map.Strict
(
Map
)
...
@@ -37,17 +37,13 @@ import Test.QuickCheck.Arbitrary (Arbitrary, arbitrary)
...
@@ -37,17 +37,13 @@ import Test.QuickCheck.Arbitrary (Arbitrary, arbitrary)
newtype
MSet
a
=
MSet
(
Map
a
()
)
newtype
MSet
a
=
MSet
(
Map
a
()
)
deriving
(
Eq
,
Ord
,
Show
,
Generic
,
Arbitrary
,
Semigroup
,
Monoid
)
deriving
(
Eq
,
Ord
,
Show
,
Generic
,
Arbitrary
,
Semigroup
,
Monoid
)
instance
ToJSON
a
=>
ToJSON
(
MSet
a
)
where
instance
ToJSON
a
=>
ToJSON
(
MSet
a
)
where
toJSON
(
MSet
m
)
=
toJSON
(
Map
.
keys
m
)
toJSON
(
MSet
m
)
=
toJSON
(
Map
.
keys
m
)
toEncoding
(
MSet
m
)
=
toEncoding
(
Map
.
keys
m
)
toEncoding
(
MSet
m
)
=
toEncoding
(
Map
.
keys
m
)
instance
Foldable
MSet
where
instance
Foldable
MSet
where
foldMap
f
(
MSet
m
)
=
Map
.
foldMapWithKey
(
\
k
_
->
f
k
)
m
foldMap
f
(
MSet
m
)
=
Map
.
foldMapWithKey
(
\
k
_
->
f
k
)
m
instance
(
Ord
a
,
FromJSON
a
)
=>
FromJSON
(
MSet
a
)
where
instance
(
Ord
a
,
FromJSON
a
)
=>
FromJSON
(
MSet
a
)
where
parseJSON
=
fmap
mSetFromList
.
parseJSON
parseJSON
=
fmap
mSetFromList
.
parseJSON
instance
(
ToJSONKey
a
,
ToSchema
a
)
=>
ToSchema
(
MSet
a
)
where
instance
(
ToJSONKey
a
,
ToSchema
a
)
=>
ToSchema
(
MSet
a
)
where
-- TODO
-- TODO
declareNamedSchema
_
=
wellNamedSchema
""
(
Proxy
::
Proxy
TODO
)
declareNamedSchema
_
=
wellNamedSchema
""
(
Proxy
::
Proxy
TODO
)
...
@@ -70,19 +66,14 @@ mSetToList (MSet a) = Map.keys a
...
@@ -70,19 +66,14 @@ mSetToList (MSet a) = Map.keys a
newtype
NgramsTerm
=
NgramsTerm
{
unNgramsTerm
::
Text
}
newtype
NgramsTerm
=
NgramsTerm
{
unNgramsTerm
::
Text
}
deriving
(
Ord
,
Eq
,
Show
,
Generic
,
ToJSONKey
,
ToJSON
,
FromJSON
,
Semigroup
,
Arbitrary
,
Serialise
,
ToSchema
,
Hashable
,
NFData
)
deriving
(
Ord
,
Eq
,
Show
,
Generic
,
ToJSONKey
,
ToJSON
,
FromJSON
,
Semigroup
,
Arbitrary
,
Serialise
,
ToSchema
,
Hashable
,
NFData
)
instance
IsHashable
NgramsTerm
where
instance
IsHashable
NgramsTerm
where
hash
(
NgramsTerm
t
)
=
hash
t
hash
(
NgramsTerm
t
)
=
hash
t
instance
Monoid
NgramsTerm
where
instance
Monoid
NgramsTerm
where
mempty
=
NgramsTerm
""
mempty
=
NgramsTerm
""
instance
FromJSONKey
NgramsTerm
where
instance
FromJSONKey
NgramsTerm
where
fromJSONKey
=
FromJSONKeyTextParser
$
\
t
->
pure
$
NgramsTerm
$
strip
t
fromJSONKey
=
FromJSONKeyTextParser
$
\
t
->
pure
$
NgramsTerm
$
strip
t
instance
IsString
NgramsTerm
where
instance
IsString
NgramsTerm
where
fromString
s
=
NgramsTerm
$
pack
s
fromString
s
=
NgramsTerm
$
pack
s
instance
FromField
NgramsTerm
instance
FromField
NgramsTerm
where
where
fromField
field
mb
=
do
fromField
field
mb
=
do
...
@@ -103,6 +94,10 @@ data NgramsRepoElement = NgramsRepoElement
...
@@ -103,6 +94,10 @@ data NgramsRepoElement = NgramsRepoElement
,
_nre_children
::
!
(
MSet
NgramsTerm
)
,
_nre_children
::
!
(
MSet
NgramsTerm
)
}
}
deriving
(
Ord
,
Eq
,
Show
,
Generic
)
deriving
(
Ord
,
Eq
,
Show
,
Generic
)
instance
ToSchema
NgramsRepoElement
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_nre_"
)
instance
Serialise
(
MSet
NgramsTerm
)
instance
Serialise
NgramsRepoElement
deriveJSON
(
unPrefix
"_nre_"
)
''
N
gramsRepoElement
deriveJSON
(
unPrefix
"_nre_"
)
''
N
gramsRepoElement
-- TODO
-- TODO
...
@@ -111,12 +106,10 @@ deriveJSON (unPrefix "_nre_") ''NgramsRepoElement
...
@@ -111,12 +106,10 @@ deriveJSON (unPrefix "_nre_") ''NgramsRepoElement
makeLenses
''
N
gramsRepoElement
makeLenses
''
N
gramsRepoElement
instance
ToSchema
NgramsRepoElement
where
type
NgramsTableMap
=
Map
NgramsTerm
NgramsRepoElement
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_nre_"
)
instance
Serialise
(
MSet
NgramsTerm
)
instance
Serialise
NgramsRepoElement
type
AddRem
=
Replace
(
Maybe
()
)
instance
Serialise
AddRem
newtype
PatchMSet
a
=
PatchMSet
(
PatchMap
a
AddRem
)
newtype
PatchMSet
a
=
PatchMSet
(
PatchMap
a
AddRem
)
...
@@ -133,10 +126,6 @@ instance (Serialise a, Ord a) => Serialise (PatchMap a AddRem)
...
@@ -133,10 +126,6 @@ instance (Serialise a, Ord a) => Serialise (PatchMap a AddRem)
instance
(
Serialise
a
,
Ord
a
)
=>
Serialise
(
PatchMSet
a
)
instance
(
Serialise
a
,
Ord
a
)
=>
Serialise
(
PatchMSet
a
)
type
AddRem
=
Replace
(
Maybe
()
)
instance
Serialise
AddRem
data
NgramsPatch
data
NgramsPatch
=
NgramsPatch
{
_patch_children
::
!
(
PatchMSet
NgramsTerm
)
=
NgramsPatch
{
_patch_children
::
!
(
PatchMSet
NgramsTerm
)
,
_patch_list
::
!
(
Replace
ListType
)
-- TODO Map UserId ListType
,
_patch_list
::
!
(
Replace
ListType
)
-- TODO Map UserId ListType
...
@@ -145,7 +134,6 @@ data NgramsPatch
...
@@ -145,7 +134,6 @@ data NgramsPatch
,
_patch_new
::
!
(
Maybe
NgramsRepoElement
)
,
_patch_new
::
!
(
Maybe
NgramsRepoElement
)
}
}
deriving
(
Eq
,
Show
,
Generic
)
deriving
(
Eq
,
Show
,
Generic
)
instance
Semigroup
NgramsPatch
where
instance
Semigroup
NgramsPatch
where
p
<>
q
=
_NgramsPatch
#
(
p
^.
_NgramsPatch
<>
q
^.
_NgramsPatch
)
p
<>
q
=
_NgramsPatch
#
(
p
^.
_NgramsPatch
<>
q
^.
_NgramsPatch
)
instance
Monoid
NgramsPatch
where
instance
Monoid
NgramsPatch
where
...
@@ -160,14 +148,6 @@ instance Transformable NgramsPatch where
...
@@ -160,14 +148,6 @@ instance Transformable NgramsPatch where
transformWith
conflict
p
q
=
(
_NgramsPatch
#
p'
,
_NgramsPatch
#
q'
)
transformWith
conflict
p
q
=
(
_NgramsPatch
#
p'
,
_NgramsPatch
#
q'
)
where
where
(
p'
,
q'
)
=
transformWith
conflict
(
p
^.
_NgramsPatch
)
(
q
^.
_NgramsPatch
)
(
p'
,
q'
)
=
transformWith
conflict
(
p
^.
_NgramsPatch
)
(
q
^.
_NgramsPatch
)
-- The JSON encoding is untagged, this is OK since the field names are disjoints and thus the encoding is unambiguous.
-- TODO: the empty object should be accepted and treated as mempty.
deriveJSON
(
unPrefixUntagged
"_"
)
''
N
gramsPatch
makeLenses
''
N
gramsPatch
-- TODO: This instance is simplified since we should either have the fields children and/or list
-- or the fields old and/or new.
instance
ToSchema
NgramsPatch
where
instance
ToSchema
NgramsPatch
where
declareNamedSchema
_
=
do
declareNamedSchema
_
=
do
childrenSch
<-
declareSchemaRef
(
Proxy
::
Proxy
(
PatchMSet
NgramsTerm
))
childrenSch
<-
declareSchemaRef
(
Proxy
::
Proxy
(
PatchMSet
NgramsTerm
))
...
@@ -182,50 +162,36 @@ instance ToSchema NgramsPatch where
...
@@ -182,50 +162,36 @@ instance ToSchema NgramsPatch where
,
(
"old"
,
nreSch
)
,
(
"old"
,
nreSch
)
,
(
"new"
,
nreSch
)
,
(
"new"
,
nreSch
)
]
]
instance
Arbitrary
NgramsPatch
where
instance
Arbitrary
NgramsPatch
where
arbitrary
=
frequency
[
(
9
,
NgramsPatch
<$>
arbitrary
<*>
(
replace
<$>
arbitrary
<*>
arbitrary
))
arbitrary
=
frequency
[
(
9
,
NgramsPatch
<$>
arbitrary
<*>
(
replace
<$>
arbitrary
<*>
arbitrary
))
,
(
1
,
NgramsReplace
<$>
arbitrary
<*>
arbitrary
)
,
(
1
,
NgramsReplace
<$>
arbitrary
<*>
arbitrary
)
]
]
instance
Serialise
NgramsPatch
instance
Serialise
NgramsPatch
-- The JSON encoding is untagged, this is OK since the field names are disjoints and thus the encoding is unambiguous.
-- TODO: the empty object should be accepted and treated as mempty.
deriveJSON
(
unPrefixUntagged
"_"
)
''
N
gramsPatch
makeLenses
''
N
gramsPatch
------------------------------------------------------------------------
_NgramsPatch
::
Iso'
NgramsPatch
NgramsPatchIso
type
NgramsTableMap
=
Map
NgramsTerm
NgramsRepoElement
_NgramsPatch
=
iso
unwrap
wrap
newtype
NgramsTablePatch
=
NgramsTablePatch
(
PatchMap
NgramsTerm
NgramsPatch
)
deriving
(
Eq
,
Show
,
Generic
,
ToJSON
,
FromJSON
,
Semigroup
,
Monoid
,
Validity
,
Transformable
)
instance
Serialise
NgramsTablePatch
instance
Serialise
(
PatchMap
NgramsTerm
NgramsPatch
)
instance
FromField
NgramsTablePatch
where
fromField
=
fromField'
instance
FromField
(
PatchMap
SchemaNgrams
.
NgramsType
(
PatchMap
NodeId
NgramsTablePatch
))
where
where
fromField
=
fromField'
unwrap
(
NgramsPatch
c
l
)
=
Mod
$
PairPatch
(
c
,
l
)
unwrap
(
NgramsReplace
o
n
)
=
replace
o
n
wrap
x
=
case
unMod
x
of
type
PatchedNgramsPatch
=
Maybe
NgramsRepoElement
Just
(
PairPatch
(
c
,
l
))
->
NgramsPatch
c
l
type
instance
Patched
NgramsPatch
=
PatchedNgramsPatch
Nothing
->
NgramsReplace
(
x
^?
old
.
_Just
)
(
x
^?
new
.
_Just
)
type
PatchedNgramsTablePatch
=
Map
NgramsTerm
PatchedNgramsPatch
-- ~ Patched (PatchMap NgramsTerm NgramsPatch)
type
instance
Patched
NgramsTablePatch
=
PatchedNgramsTablePatch
makePrisms
''
N
gramsTablePatch
-- TODO: This instance is simplified since we should either have the fields children and/or list
instance
ToSchema
(
PatchMap
NgramsTerm
NgramsPatch
)
-- or the fields old and/or new.
instance
ToSchema
NgramsTablePatch
instance
Applicable
NgramsTablePatch
(
Maybe
NgramsTableMap
)
where
type
NgramsPatchIso
=
applicable
p
=
applicable
(
p
^.
_NgramsTablePatch
)
MaybePatch
NgramsRepoElement
(
PairPatch
(
PatchMSet
NgramsTerm
)
(
Replace
ListType
)
)
------------------------------------------------------------------------
type
ConflictResolutionNgramsPatch
=
type
ConflictResolutionNgramsPatch
=
(
ConflictResolutionReplace
(
Maybe
NgramsRepoElement
)
(
ConflictResolutionReplace
(
Maybe
NgramsRepoElement
)
...
@@ -237,8 +203,8 @@ type ConflictResolutionNgramsPatch =
...
@@ -237,8 +203,8 @@ type ConflictResolutionNgramsPatch =
type
instance
ConflictResolution
NgramsPatch
=
type
instance
ConflictResolution
NgramsPatch
=
ConflictResolutionNgramsPatch
ConflictResolutionNgramsPatch
type
instance
ConflictResolution
NgramsTablePatch
=
type
PatchedNgramsPatch
=
Maybe
NgramsRepoElement
NgramsTerm
->
ConflictResolution
NgramsPatch
type
instance
Patched
NgramsPatch
=
Patched
NgramsPatch
instance
Applicable
(
PairPatch
(
PatchMSet
NgramsTerm
)
(
Replace
ListType
))
NgramsRepoElement
where
instance
Applicable
(
PairPatch
(
PatchMSet
NgramsTerm
)
(
Replace
ListType
))
NgramsRepoElement
where
applicable
(
PairPatch
(
c
,
l
))
n
=
applicable
c
(
n
^.
nre_children
)
<>
applicable
l
(
n
^.
nre_list
)
applicable
(
PairPatch
(
c
,
l
))
n
=
applicable
c
(
n
^.
nre_children
)
<>
applicable
l
(
n
^.
nre_list
)
...
@@ -254,16 +220,33 @@ instance Action NgramsPatch (Maybe NgramsRepoElement) where
...
@@ -254,16 +220,33 @@ instance Action NgramsPatch (Maybe NgramsRepoElement) where
act
p
=
act
(
p
^.
_NgramsPatch
)
act
p
=
act
(
p
^.
_NgramsPatch
)
type
NgramsPatchIso
=
MaybePatch
NgramsRepoElement
(
PairPatch
(
PatchMSet
NgramsTerm
)
(
Replace
ListType
))
_NgramsPatch
::
Iso'
NgramsPatch
NgramsPatchIso
newtype
NgramsTablePatch
=
NgramsTablePatch
(
PatchMap
NgramsTerm
NgramsPatch
)
_NgramsPatch
=
iso
unwrap
wrap
deriving
(
Eq
,
Show
,
Generic
,
ToJSON
,
FromJSON
,
Semigroup
,
Monoid
,
Validity
,
Transformable
)
instance
Serialise
NgramsTablePatch
instance
Serialise
(
PatchMap
NgramsTerm
NgramsPatch
)
instance
FromField
NgramsTablePatch
where
where
unwrap
(
NgramsPatch
c
l
)
=
Mod
$
PairPatch
(
c
,
l
)
fromField
=
fromField'
unwrap
(
NgramsReplace
o
n
)
=
replace
o
n
instance
FromField
(
PatchMap
SchemaNgrams
.
NgramsType
(
PatchMap
NodeId
NgramsTablePatch
))
wrap
x
=
where
case
unMod
x
of
fromField
=
fromField'
Just
(
PairPatch
(
c
,
l
))
->
NgramsPatch
c
l
Nothing
->
NgramsReplace
(
x
^?
old
.
_Just
)
(
x
^?
new
.
_Just
)
type
PatchedNgramsTablePatch
=
Map
NgramsTerm
PatchedNgramsPatch
-- ~ Patched (PatchMap NgramsTerm NgramsPatch)
type
instance
Patched
NgramsTablePatch
=
PatchedNgramsTablePatch
makePrisms
''
N
gramsTablePatch
instance
ToSchema
(
PatchMap
NgramsTerm
NgramsPatch
)
instance
ToSchema
NgramsTablePatch
instance
Applicable
NgramsTablePatch
(
Maybe
NgramsTableMap
)
where
applicable
p
=
applicable
(
p
^.
_NgramsTablePatch
)
type
instance
ConflictResolution
NgramsTablePatch
=
NgramsTerm
->
ConflictResolutionNgramsPatch
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment