From 130e338431fe852417cc3f42eef86905d23e507a Mon Sep 17 00:00:00 2001 From: Benjamin Date: Wed, 20 Nov 2024 13:02:55 +0000 Subject: [PATCH] inline existing functions for nonnull --- mono-traversable/src/Data/NonNull.hs | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/mono-traversable/src/Data/NonNull.hs b/mono-traversable/src/Data/NonNull.hs index 834c1d2..ba45b3c 100644 --- a/mono-traversable/src/Data/NonNull.hs +++ b/mono-traversable/src/Data/NonNull.hs @@ -72,16 +72,23 @@ instance GrowingAppend mono => GrowingAppend (NonNull mono) instance (Semigroup mono, GrowingAppend mono) => Semigroup (NonNull mono) where (<>) = unsafeMap2 (<>) + {-# INLINE (<>) #-} instance SemiSequence seq => SemiSequence (NonNull seq) where type Index (NonNull seq) = Index seq intersperse e = unsafeMap $ intersperse e + {-# INLINE intersperse #-} reverse = unsafeMap reverse + {-# INLINE reverse #-} find f = find f . toNullable + {-# INLINE find #-} cons x = unsafeMap $ cons x + {-# INLINE cons #-} snoc xs x = unsafeMap (flip snoc x) xs + {-# INLINE snoc #-} sortBy f = unsafeMap $ sortBy f + {-# INLINE sortBy #-} instance SemiSetContainer set => SemiSetContainer (NonNull set) where type ContainerKey (NonNull set) = ContainerKey set