org.apache.pekko.grpc.internal.Codec.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pekko-grpc-runtime_2.13 Show documentation
Show all versions of pekko-grpc-runtime_2.13 Show documentation
Apache Pekko gRPC - Support for building streaming gRPC servers and clients on top of Pekko Streams.
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* license agreements; and to You under the Apache License, version 2.0:
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* This file is part of the Apache Pekko project, which was derived from Akka.
*/
/*
* Copyright (C) 2018-2021 Lightbend Inc.
*/
package org.apache.pekko.grpc.internal
import org.apache.pekko.util.ByteString
abstract class Codec {
val name: String
def compress(bytes: ByteString): ByteString
def uncompress(bytes: ByteString): ByteString
/**
* Process the given frame bytes, uncompress if the compression bit is set. Identity
* codec will fail with a [[io.grpc.StatusException]] if the compressedBit is set.
*/
def uncompress(compressedBitSet: Boolean, bytes: ByteString): ByteString
def isCompressed: Boolean = this != Identity
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy