summaryrefslogtreecommitdiff
path: root/src/main/scala
diff options
context:
space:
mode:
authorKonrad `ktoso` Malawski <ktoso@project13.pl>2017-10-24 14:04:11 +0900
committerGitHub <noreply@github.com>2017-10-24 14:04:11 +0900
commit36959ef06fa632945ff01aaa2cc558b6cc8365d7 (patch)
treea774dc1573e18cbc6205922ac935876b5c7741c7 /src/main/scala
parent11028dd4b2aa6a35a082531609c72d716f628605 (diff)
parentdd62833aca49ee5aa6a1dbb6b6d274d44c7b52dc (diff)
downloadspray-json-36959ef06fa632945ff01aaa2cc558b6cc8365d7.tar.gz
spray-json-36959ef06fa632945ff01aaa2cc558b6cc8365d7.tar.bz2
spray-json-36959ef06fa632945ff01aaa2cc558b6cc8365d7.zip
Merge pull request #164 from mattinbits/master
Added method for sorted print
Diffstat (limited to 'src/main/scala')
-rw-r--r--src/main/scala/spray/json/JsValue.scala1
-rw-r--r--src/main/scala/spray/json/PrettyPrinter.scala4
-rw-r--r--src/main/scala/spray/json/SortedPrinter.scala9
3 files changed, 13 insertions, 1 deletions
diff --git a/src/main/scala/spray/json/JsValue.scala b/src/main/scala/spray/json/JsValue.scala
index e71b68e..08a673b 100644
--- a/src/main/scala/spray/json/JsValue.scala
+++ b/src/main/scala/spray/json/JsValue.scala
@@ -28,6 +28,7 @@ sealed abstract class JsValue {
def toString(printer: (JsValue => String)) = printer(this)
def compactPrint = CompactPrinter(this)
def prettyPrint = PrettyPrinter(this)
+ def sortedPrint = SortedPrinter(this)
def convertTo[T :JsonReader]: T = jsonReader[T].read(this)
/**
diff --git a/src/main/scala/spray/json/PrettyPrinter.scala b/src/main/scala/spray/json/PrettyPrinter.scala
index 57cf35e..6af5443 100644
--- a/src/main/scala/spray/json/PrettyPrinter.scala
+++ b/src/main/scala/spray/json/PrettyPrinter.scala
@@ -37,9 +37,11 @@ trait PrettyPrinter extends JsonPrinter {
}
}
+ protected def organiseMembers(members: Map[String, JsValue]): Seq[(String, JsValue)] = members.toSeq
+
protected def printObject(members: Map[String, JsValue], sb: StringBuilder, indent: Int) {
sb.append("{\n")
- printSeq(members, sb.append(",\n")) { m =>
+ printSeq(organiseMembers(members), sb.append(",\n")) { m =>
printIndent(sb, indent + Indent)
printString(m._1, sb)
sb.append(": ")
diff --git a/src/main/scala/spray/json/SortedPrinter.scala b/src/main/scala/spray/json/SortedPrinter.scala
new file mode 100644
index 0000000..070d36c
--- /dev/null
+++ b/src/main/scala/spray/json/SortedPrinter.scala
@@ -0,0 +1,9 @@
+package spray.json
+
+trait SortedPrinter extends PrettyPrinter {
+
+ override protected def organiseMembers(members: Map[String, JsValue]): Seq[(String, JsValue)] =
+ members.toSeq.sortBy(_._1)
+}
+
+object SortedPrinter extends SortedPrinter