Last active
June 21, 2023 05:30
-
-
Save owainlewis/1e7d1e68a6818ee4d50e to your computer and use it in GitHub Desktop.
Revisions
-
owainlewis revised this gist
Mar 16, 2016 . 2 changed files with 10 additions and 0 deletions.There are no files selected for viewing
File renamed without changes.This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,10 @@ class GzipSpec extends WordSpecLike with Matchers { "The GZIP object" should { "decompress a compressed string" in { val input = Gzip.compress("Hello World".getBytes("UTF-8")) Gzip.decompress(input) shouldBe Some("Hello World") } } } -
owainlewis created this gist
Mar 16, 2016 .There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,23 @@ import java.io.{ByteArrayOutputStream, ByteArrayInputStream} import java.util.zip.{GZIPOutputStream, GZIPInputStream} import scala.util.Try object Gzip { def compress(input: Array[Byte]): Array[Byte] = { val bos = new ByteArrayOutputStream(input.length) val gzip = new GZIPOutputStream(bos) gzip.write(input) gzip.close() val compressed = bos.toByteArray bos.close() compressed } def decompress(compressed: Array[Byte]): Option[String] = Try { val inputStream = new GZIPInputStream(new ByteArrayInputStream(compressed)) scala.io.Source.fromInputStream(inputStream).mkString }.toOption }