summaryrefslogtreecommitdiff
path: root/src/utils/ByteUtils.scala
diff options
context:
space:
mode:
Diffstat (limited to 'src/utils/ByteUtils.scala')
-rw-r--r--src/utils/ByteUtils.scala34
1 files changed, 24 insertions, 10 deletions
diff --git a/src/utils/ByteUtils.scala b/src/utils/ByteUtils.scala
index 344f6f7..85c6058 100644
--- a/src/utils/ByteUtils.scala
+++ b/src/utils/ByteUtils.scala
@@ -62,20 +62,30 @@ object ByteUtils {
}
}
- implicit class RichArrayOfBytes(b: Array[Byte]) {
+ implicit class RichIterableByte(iter: Iterable[Byte]) {
def to[T : SizedNumeric : BitOps]: T = {
- val numeric = implicitly[SizedNumeric[T]]
- if(b.length < numeric.byteSize) {
- throw new RuntimeException("Byte input is not long enough")
- }
+ // Need to know length, so we must force the iter
+ iter.hasDefiniteSize match {
+ case true => throw new IllegalArgumentException("Argument is not finite!")
+ case false => {
+ val numeric = implicitly[SizedNumeric[T]]
+ if(b.length < numeric.byteSize) {
+ throw new RuntimeException("Byte input is not long enough")
+ }
- var out: Long = b(0)
- for(i <- 1 until numeric.byteSize) {
- out << 8
- out = b(i) | out
+ var out: Long = b(0)
+ for(i <- 1 until numeric.byteSize) {
+ out << 8
+ out = b(i) | out
+ }
+ numeric.fromLong(out)
+ }
}
- numeric.fromLong(out)
}
+
+ def xor(other: Iterable[Byte]): Iterable[Byte] =
+ iter.zip(other).map(_ ^@ _)
+
}
def sizedNumeric[T : Manifest](bytes: Int)(from: Long => T)(to: T => Long) = new SizedNumeric[T] {
def manifest = implicitly[Manifest[T]]
@@ -106,4 +116,8 @@ object ByteUtils {
}
buf.toString()
}
+
+ def toHexString[T : SizedNumeric : BitOps](x: Iterable[T]): String = {
+
+ }
}