Skip to content

Commit

Permalink
Return unsafe methods of Slf4jLogger
Browse files Browse the repository at this point in the history
  • Loading branch information
danicheg committed Jun 16, 2022
1 parent e81ec79 commit 8edfafc
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,9 @@ import org.typelevel.log4cats.slf4j.internal._

trait Slf4jLoggerCompat {

private[slf4j] def getLogger[F[_]](implicit f: Sync[F]): SelfAwareStructuredLogger[F] =
private[slf4j] def getLoggerMacro[F[_]](implicit f: Sync[F]): SelfAwareStructuredLogger[F] =
macro GetLoggerMacros.unsafeCreateImpl[F[_]]

private[slf4j] def create[F[_]](implicit f: Sync[F]): F[SelfAwareStructuredLogger[F]] =
private[slf4j] def createMacro[F[_]](implicit f: Sync[F]): F[SelfAwareStructuredLogger[F]] =
macro GetLoggerMacros.safeCreateImpl[F[_]]
}
Original file line number Diff line number Diff line change
Expand Up @@ -25,9 +25,10 @@ import scala.annotation.nowarn
trait Slf4jLoggerCompat {

// for binary compability
private[slf4j] inline def create[F[_]](F: Sync[F]): F[SelfAwareStructuredLogger[F]] =
private[slf4j] inline def createMacro[F[_]](F: Sync[F]): F[SelfAwareStructuredLogger[F]] =
${ GetLoggerMacros.createImpl('F) }
private[slf4j] inline def getLogger[F[_]](using F: Sync[F]): SelfAwareStructuredLogger[F] =

private[slf4j] inline def getLoggerMacro[F[_]](using F: Sync[F]): SelfAwareStructuredLogger[F] =
${ GetLoggerMacros.getLoggerImpl('F) }

}
Original file line number Diff line number Diff line change
Expand Up @@ -18,23 +18,39 @@ package org.typelevel.log4cats
package slf4j

import cats.effect.Sync
import org.typelevel.log4cats.slf4j.internal.Slf4jLoggerInternal
import org.typelevel.log4cats.slf4j.internal.{GetLoggerMacros, Slf4jLoggerInternal}
import org.slf4j.{Logger => JLogger}

object Slf4jLogger extends Slf4jLoggerCompat {

def getLogger[F[_]](implicit f: Sync[F], name: LoggerName): SelfAwareStructuredLogger[F] =
getLoggerFromName(name.value)

@deprecated("0.3.0", "Use getLogger instead")
def unsafeCreate[F[_]: Sync]: SelfAwareStructuredLogger[F] =
getLoggerMacro[F]

def getLoggerFromName[F[_]: Sync](name: String): SelfAwareStructuredLogger[F] =
getLoggerFromSlf4j(org.slf4j.LoggerFactory.getLogger(name))

@deprecated("0.3.0", "Use getLoggerFromName")
def unsafeFromName[F[_]: Sync](name: String): SelfAwareStructuredLogger[F] =
getLoggerFromName[F](name)

def getLoggerFromClass[F[_]: Sync](clazz: Class[_]): SelfAwareStructuredLogger[F] =
getLoggerFromSlf4j[F](org.slf4j.LoggerFactory.getLogger(clazz))

@deprecated("0.3.0", "Use getLoggerFromClass")
def unsafeFromClass[F[_]: Sync](clazz: Class[_]): SelfAwareStructuredLogger[F] =
getLoggerFromClass[F](clazz)

def getLoggerFromSlf4j[F[_]: Sync](logger: JLogger): SelfAwareStructuredLogger[F] =
new Slf4jLoggerInternal.Slf4jLogger(logger)

@deprecated("0.3.0", "Use getLoggerFromSlf4J instead")
def unsafeFromSlf4j[F[_]: Sync](logger: JLogger): SelfAwareStructuredLogger[F] =
getLoggerFromSlf4j[F](logger)

def create[F[_]: Sync](implicit name: LoggerName): F[SelfAwareStructuredLogger[F]] =
Sync[F].delay(getLoggerFromName(name.value))

Expand Down

0 comments on commit 8edfafc

Please sign in to comment.