Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

A fast & simple, yet powerful & flexible logging framework for Mac and iOS

License

NotificationsYou must be signed in to change notification settings

hotwirestudios/CocoaLumberjack

 
 

Repository files navigation

CocoaLumberjack

Build StatusPod VersionCarthage compatiblePod PlatformPod LicenseReference Status

CocoaLumberjack is a fast & simple, yet powerful & flexible logging framework for Mac and iOS.

How to get started

Swift version via CocoaPods
platform:ios,'8.0'pod'CocoaLumberjack/Swift'use_frameworks!

Note:Swift is a subspec which will include all the Obj-C code plus the Swift one, so this is sufficient.For more details about how to use Swift with Lumberjack, seethis conversation.

Swift Usage

If you installed using CocoaPods or manually:

import CocoaLumberjack
DDLog.addLogger(DDTTYLogger.sharedInstance()) // TTY = Xcode consoleDDLog.addLogger(DDASLLogger.sharedInstance()) // ASL = Apple System LogsletfileLogger:DDFileLogger=DDFileLogger() // File LoggerfileLogger.rollingFrequency=60*60*24  // 24 hoursfileLogger.logFileManager.maximumNumberOfLogFiles=7DDLog.addLogger(fileLogger)...DDLogVerbose("Verbose");DDLogDebug("Debug");DDLogInfo("Info");DDLogWarn("Warn");DDLogError("Error");
Obj-C version via CocoaPods
platform:ios,'7.0'pod'CocoaLumberjack'
Objc-C usage

If you're using Lumberjack as a framework, you can@import CocoaLumberjack.

Otherwise,#import <CocoaLumberjack/CocoaLumberjack.h>

[DDLogaddLogger:[DDTTYLoggersharedInstance]];// TTY = Xcode console[DDLogaddLogger:[DDASLLoggersharedInstance]];// ASL = Apple System LogsDDFileLogger *fileLogger = [[DDFileLoggeralloc]init];// File LoggerfileLogger.rollingFrequency =60 *60 *24;// 24 hour rollingfileLogger.logFileManager.maximumNumberOfLogFiles =7;[DDLogaddLogger:fileLogger];...DDLogVerbose(@"Verbose");DDLogDebug(@"Debug");DDLogInfo(@"Info");DDLogWarn(@"Warn");DDLogError(@"Error");
Installation with Carthage (iOS 8+)

Carthage is a lightweight dependency manager for Swift and Objective-C. It leverages CocoaTouch modules and is less invasive than CocoaPods.

To install with Carthage, follow the instruction onCarthage

Cartfile

github "CocoaLumberjack/CocoaLumberjack"

CocoaLumberjack 2

Migrating to 2.x

  • ReplaceDDLog.h imports by#import <CocoaLumberjack/CocoaLumberjack.h>.

Advanced users, third party libraries:

  • Replace allDDLogC macros for regularDDLog macros.
  • Replace log level (LOG_LEVEL_*) macros withDDLogLevel enum values
  • Replace log flag (LOG_FLAG_*) macros withDDLogFlag enum values
  • ReplaceDDLogMessage ivars and method calls to the new ivars and methods
    • logMsg with_message
    • logLevel with_level
    • logFlag with_flag
    • logContext with_context
    • lineNumber with_line (type changed fromint toNSUInteger)
    • file with_file (filename contains just the file name, without the extension and the full path)
    • timestamp with_timestamp
    • methodName withfunction
  • ReplaceDDAbstractLoggerformatter tologFormatter
  • YSSingleFileLogger ivars are no longer accesible, use the methods instead
  • Replace[DDLog addLogger:withLogLevel:] with[DDLog addLogger:withLevel:]

Forcing 1.x

If an included library requires it, you can force CocoaLumberjack 1.x by setting the version before the conflicting library:

pod'CocoaLumberjack','~> 1.9'pod'ConflictingLibrary'

Features

Lumberjack is Fast & Simple, yet Powerful & Flexible.

It is similar in concept to other popular logging frameworks such as log4j, yet is designed specifically for Objective-C, and takes advantage of features such as multi-threading, grand central dispatch (if available), lockless atomic operations, and the dynamic nature of the Objective-C runtime.

Lumberjack is Fast

In most cases it is an order of magnitude faster than NSLog.

Lumberjack is Simple

It takes as little as a single line of code to configure lumberjack when your application launches. Then simply replace your NSLog statements with DDLog statements and that's about it. (And the DDLog macros have the exact same format and syntax as NSLog, so it's super easy.)

Lumberjack is Powerful:

One log statement can be sent to multiple loggers, meaning you can log to a file and the console simultaneously. Want more? Create your own loggers (it's easy) and send your log statements over the network. Or to a database or distributed file system. The sky is the limit.

Lumberjack is Flexible:

Configure your logging however you want. Change log levels per file (perfect for debugging). Change log levels per logger (verbose console, but concise log file). Change log levels per xcode configuration (verbose debug, but concise release). Have your log statements compiled out of the release build. Customize the number of log levels for your application. Add your own fine-grained logging. Dynamically change log levels during runtime. Choose how & when you want your log files to be rolled. Upload your log files to a central server. Compress archived log files to save disk space...

This framework is for you if:

  • You're looking for a way to track down that impossible-to-reproduce bug that keeps popping up in the field.
  • You're frustrated with the super short console log on the iPhone.
  • You're looking to take your application to the next level in terms of support and stability.
  • You're looking for an enterprise level logging solution for your application (Mac or iPhone).

Documentation

Requirements

The current version of Lumberjack requires:

  • Xcode 7.1 or later
  • iOS 5 or later
  • OS X 10.7 or later
  • WatchOS 2 or later
  • TVOS 9 or later

Backwards compability

  • for Xcode 7.0 or earlier, use the 2.1.0 version
  • for Xcode 6 or earlier, use the 2.0.x version
  • for OS X < 10.7 support, use the 1.6.0 version

Author

  • Robbie Hanson
  • Love the project? Wanna buy me a coffee? (or a beer :D)donation

Collaborators

License

  • CocoaLumberjack is available under the BSD license. See theLICENSE file.

About

A fast & simple, yet powerful & flexible logging framework for Mac and iOS

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C92.1%
  • Swift6.2%
  • Other1.7%

[8]ページ先頭

©2009-2025 Movatter.jp