URI.Extra.QueryPairs
- Package
- purescript-uri
- Repository
- purescript-contrib/purescript-uri
#QueryPairs Source
newtype QueryPairs k v
A query string split into an array of key/value pairs. There is no precise spec for this, but the format is commonly used, so this attempts to handle these strings in a sensible way.
- The representation uses an array rather than a map, so duplicate keys are supported.
- Keys are not required to have a value associated.
&
and;
are both treated as pair delimiters.
Constructors
QueryPairs (Array (Tuple k (Maybe v)))
Instances
(Eq k, Eq v) => Eq (QueryPairs k v)
(Ord k, Ord v) => Ord (QueryPairs k v)
Generic (QueryPairs k v) _
(Show k, Show v) => Show (QueryPairs k v)
Semigroup (QueryPairs k v)
Monoid (QueryPairs k v)
#parse Source
parse :: forall k v. (Key -> Either URIPartParseError k) -> (Value -> Either URIPartParseError v) -> Query -> Either URIPartParseError (QueryPairs k v)
Parses a query into key/value pairs.
This function allows for the Key
and Value
components to be parsed
into custom representations. If this is not necessary, use pure
for both
these arguments.
#print Source
print :: forall k v. (k -> Key) -> (v -> Value) -> QueryPairs k v -> Query
A printer for key/value pairs style query string.
As a counterpart to the parser
this function also requires the Key
and Value
components to be printed back from their custom representations.
If no custom types are being used, pass identity
for both of these arguments.
#keyPartChar Source
keyPartChar :: Parser String Char
The supported key characters, excluding percent-encodings.
#valuePartChar Source
valuePartChar :: Parser String Char
The supported value characters, excluding percent-encodings.
#keyFromString Source
keyFromString :: String -> Key
Constructs a key value from a string, percent-encoding any characters
that require it. Note that running this on a string that has already had
percent-encoding applied will double-encode it, for those situations use
unsafeKeyFromString
instead.
keyFromString "foo" = unsafeKeyFromString "foo"
keyFromString "foo#bar" = unsafeKeyFromString "foo%23bar"
keyFromString "foo%23bar" = unsafeKeyFromString "foo%2523bar"
#keyToString Source
keyToString :: Key -> String
Returns the string value for a key, percent-decoding any characters that require it.
keyToString (unsafeKeyFromString "foo") = "foo"
keyToString (unsafeKeyFromString "foo%23bar") = "foo#bar"
#unsafeKeyFromString Source
unsafeKeyFromString :: String -> Key
Constructs a key value from a string directly - no percent-encoding will be applied. This is useful when using a custom encoding scheme for the key, to prevent double-encoding.
#unsafeKeyToString Source
unsafeKeyToString :: Key -> String
Returns the string value for a key without percent-decoding. Only
"unsafe" in the sense that values this produces may need further decoding,
the name is more for symmetry with the fromString
/unsafeFromString
pairing.
#valueFromString Source
valueFromString :: String -> Value
Constructs a value from a string, percent-encoding any characters
that require it. Note that running this on a string that has already had
percent-encoding applied will double-encode it, for those situations use
unsafeValueFromString
instead.
valueFromString "foo" = unsafeValueFromString "foo"
valueFromString "foo#bar" = unsafeValueFromString "foo%23bar"
valueFromString "foo%23bar" = unsafeValueFromString "foo%2523bar"
#valueToString Source
valueToString :: Value -> String
Returns the string value for a value, percent-decoding any characters that require it.
valueToString (unsafeValueFromString "foo") = "foo"
valueToString (unsafeValueFromString "foo%23bar") = "foo#bar"
#unsafeValueFromString Source
unsafeValueFromString :: String -> Value
Constructs a value from a string directly - no percent-encoding will be applied. This is useful when using a custom encoding scheme for the value, to prevent double-encoding.
#unsafeValueToString Source
unsafeValueToString :: Value -> String
Returns the string value for a value without percent-decoding. Only
"unsafe" in the sense that values this produces may need further decoding,
the name is more for symmetry with the fromString
/unsafeFromString
pairing.
- Modules
- URI
- URI.
AbsoluteURI - URI.
Authority - URI.
Common - URI.
Extra. MultiHostPortPair - URI.
Extra. QueryPairs - URI.
Extra. UserPassInfo - URI.
Fragment - URI.
HierarchicalPart - URI.
Host - URI.
Host. Gen - URI.
Host. IPv4Address - URI.
Host. IPv6Address - URI.
Host. RegName - URI.
HostPortPair - URI.
HostPortPair. Gen - URI.
Path - URI.
Path. Absolute - URI.
Path. NoScheme - URI.
Path. Rootless - URI.
Path. Segment - URI.
Port - URI.
Port. Gen - URI.
Query - URI.
RelativePart - URI.
RelativeRef - URI.
Scheme - URI.
Scheme. Common - URI.
URI - URI.
URIRef - URI.
UserInfo