# ohos_hilog-rs **Repository Path**: keeyou/ohos_hilog-rs ## Basic Information - **Project Name**: ohos_hilog-rs - **Description**: https://crates.io/crates/ohos_hilog - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-12-12 - **Last Updated**: 2024-12-12 ## Categories & Tags **Categories**: Uncategorized **Tags**: OpenHarmony组件, OpenHarmony, Rust ## README ## Send Rust logs to Logcat [![Version](https://img.shields.io/crates/v/ohos_hilog.svg)](https://crates.io/crates/ohos_hilog) This library is a drop-in replacement for `env_logger`. Instead, it outputs messages to ohos's logcat. This only works on Open Harmony and requires linking to `hilog.z` which is only available under open harmony. With Cargo, it is possible to conditionally require this library: ```toml [target.'cfg(all(target_os = "linux", target_env = "ohos"))'.dependencies] ohos_hilog = "0.1" ``` Example of initialization on activity creation, with log configuration: ```rust #[macro_use] extern crate log; extern crate ohos_hilog; use log::LevelFilter; use ohos_hilog::{Config,FilterBuilder}; fn native_activity_create() { ohos_hilog::init_once( Config::default() .with_max_level(LevelFilter::Trace) // limit log level .with_tag("mytag") // logs will show under mytag tag .with_filter( // configure messages for specific crate FilterBuilder::new() .parse("debug,hello::crate=error") .build()) ); trace!("this is a verbose {}", "message"); error!("this is printed by default"); } ``` To allow all logs, use the default configuration with min level Trace: ```rust #[macro_use] extern crate log; extern crate ohos_hilog; use log::LevelFilter; use ohos_hilog::Config; fn native_activity_create() { ohos_hilog::init_once( Config::default().with_max_level(LevelFilter::Trace), ); } ``` There is a caveat that this library can only be initialized once (hence the `init_once` function name). Therefore this library will only log a warning for subsequent `init_once` calls. This library ensures that logged messages do not overflow open harmony hilog log message limits by efficiently splitting messages into chunks. ## License Licensed under either of * Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) at your option. ### Contribution Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.