From 0bb7496dfee9fa89befef6032ded9bf932a3af1e Mon Sep 17 00:00:00 2001 From: Shay Banon Date: Mon, 9 Jul 2012 20:14:03 +0200 Subject: [PATCH] yuck!, hack around snappy printing to System.err the failure to load its library if its not found --- .../common/compress/snappy/xerial/XerialSnappy.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/main/java/org/elasticsearch/common/compress/snappy/xerial/XerialSnappy.java b/src/main/java/org/elasticsearch/common/compress/snappy/xerial/XerialSnappy.java index 64d3bf8f17f..e961a8dfed5 100644 --- a/src/main/java/org/elasticsearch/common/compress/snappy/xerial/XerialSnappy.java +++ b/src/main/java/org/elasticsearch/common/compress/snappy/xerial/XerialSnappy.java @@ -21,6 +21,8 @@ package org.elasticsearch.common.compress.snappy.xerial; import org.xerial.snappy.Snappy; +import java.io.PrintStream; + /** */ public class XerialSnappy { @@ -31,13 +33,19 @@ public class XerialSnappy { static { Throwable failureX = null; boolean availableX; + // Yuck!, we need to do this since snappy 1.0.4.1 does e.printStackTrace + // when failing to load the snappy library, and we don't want it displayed... + PrintStream err = System.err; try { + System.setErr(null); byte[] tests = Snappy.compress("test"); Snappy.uncompressString(tests); availableX = true; } catch (Throwable e) { availableX = false; failureX = e; + } finally { + System.setErr(err); } available = availableX; failure = failureX;