Compare commits
No commits in common. "3ff858cef9dd50a2ac9a6715f5a62c7e64d2b39a" and "d5d7288938c5364cddb311c8920e33523d3f0db2" have entirely different histories.
3ff858cef9
...
d5d7288938
5 changed files with 62 additions and 90 deletions
10
.travis.yml
10
.travis.yml
|
|
@ -1,10 +0,0 @@
|
|||
language: rust
|
||||
|
||||
before_script:
|
||||
- rustup component add rustfmt-preview
|
||||
|
||||
script:
|
||||
- cargo fmt --all -- --check
|
||||
- cargo build
|
||||
- cargo test
|
||||
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
[package]
|
||||
name = "logwatcher"
|
||||
version = "0.1.1"
|
||||
version = "0.1.0"
|
||||
authors = ["Aravinda VK <mail@aravindavk.in>"]
|
||||
|
||||
description = "A lib to watch log files for new Changes, just like tail -f"
|
||||
|
|
|
|||
23
README.md
23
README.md
|
|
@ -1,7 +1,5 @@
|
|||
# Log Watcher
|
||||
|
||||
[](https://travis-ci.org/aravindavk/logwatcher)
|
||||
|
||||
A [Rust](https://www.rust-lang.org/) library to watch the log files.
|
||||
|
||||
Note: Tested only in Linux
|
||||
|
|
@ -14,25 +12,22 @@ Note: Tested only in Linux
|
|||
|
||||
First, add the following to your `Cargo.toml`
|
||||
|
||||
```toml
|
||||
[dependencies]
|
||||
logwatcher = "0.1"
|
||||
```
|
||||
|
||||
Add to your code,
|
||||
|
||||
```rust
|
||||
extern crate logwatcher;
|
||||
use logwatcher::LogWatcher;
|
||||
```
|
||||
|
||||
Register the logwatcher, pass a closure and watch it!
|
||||
Create a callback function, which accepts String as input
|
||||
|
||||
```rust
|
||||
let mut log_watcher = LogWatcher::register("/var/log/check.log".to_string()).unwrap();
|
||||
|
||||
log_watcher.watch(&mut move |line: String| {
|
||||
fn parse_line(line: String) {
|
||||
println!("Line {}", line);
|
||||
LogWatcherAction::None
|
||||
});
|
||||
```
|
||||
}
|
||||
|
||||
Register the logwatcher and watch it!
|
||||
|
||||
let mut log_watcher = LogWatcher::register("/var/log/check.log".to_string()).unwrap();
|
||||
log_watcher.watch(parse_line);
|
||||
|
||||
|
|
|
|||
67
src/lib.rs
67
src/lib.rs
|
|
@ -1,57 +1,46 @@
|
|||
use std::fs::File;
|
||||
use std::io;
|
||||
use std::io::prelude::*;
|
||||
use std::io::BufReader;
|
||||
use std::io::ErrorKind;
|
||||
use std::io::SeekFrom;
|
||||
use std::os::unix::fs::MetadataExt;
|
||||
use std::path::Path;
|
||||
use std::io::BufReader;
|
||||
use std::io::prelude::*;
|
||||
use std::io;
|
||||
use std::thread::sleep;
|
||||
use std::time::Duration;
|
||||
|
||||
pub enum LogWatcherAction {
|
||||
None,
|
||||
SeekToEnd,
|
||||
}
|
||||
use std::os::unix::fs::MetadataExt;
|
||||
use std::io::ErrorKind;
|
||||
|
||||
pub struct LogWatcher{
|
||||
filename: String,
|
||||
inode: u64,
|
||||
pos: u64,
|
||||
reader: BufReader<File>,
|
||||
finish: bool,
|
||||
finish: bool
|
||||
}
|
||||
|
||||
impl LogWatcher {
|
||||
pub fn register<P: AsRef<Path>>(filename: P) -> Result<LogWatcher, io::Error> {
|
||||
let f = match File::open(&filename) {
|
||||
pub fn register(filename: String) -> Result<LogWatcher, io::Error> {
|
||||
let f = match File::open(filename.clone()) {
|
||||
Ok(x) => x,
|
||||
Err(err) => return Err(err),
|
||||
Err(err) => return Err(err)
|
||||
};
|
||||
|
||||
let metadata = match f.metadata() {
|
||||
Ok(x) => x,
|
||||
Err(err) => return Err(err),
|
||||
Err(err) => return Err(err)
|
||||
};
|
||||
|
||||
let mut reader = BufReader::new(f);
|
||||
let pos = metadata.len();
|
||||
reader.seek(SeekFrom::Start(pos)).unwrap();
|
||||
Ok(LogWatcher {
|
||||
filename: filename.as_ref().to_string_lossy().to_string(),
|
||||
Ok(LogWatcher{filename: filename,
|
||||
inode: metadata.ino(),
|
||||
pos: pos,
|
||||
reader: reader,
|
||||
finish: false,
|
||||
})
|
||||
finish: false})
|
||||
}
|
||||
|
||||
fn reopen_if_log_rotated<F: ?Sized>(&mut self, callback: &mut F)
|
||||
where
|
||||
F: FnMut(String) -> LogWatcherAction,
|
||||
{
|
||||
fn reopen_if_log_rotated(&mut self, callback: fn (line: String)){
|
||||
loop {
|
||||
match File::open(&self.filename) {
|
||||
match File::open(self.filename.clone()) {
|
||||
Ok(x) => {
|
||||
let f = x;
|
||||
let metadata = match f.metadata() {
|
||||
|
|
@ -69,11 +58,12 @@ impl LogWatcher {
|
|||
self.reader = BufReader::new(f);
|
||||
self.pos = 0;
|
||||
self.inode = metadata.ino();
|
||||
} else {
|
||||
}
|
||||
else{
|
||||
sleep(Duration::new(1, 0));
|
||||
}
|
||||
break;
|
||||
}
|
||||
},
|
||||
Err(err) => {
|
||||
if err.kind() == ErrorKind::NotFound{
|
||||
sleep(Duration::new(1, 0));
|
||||
|
|
@ -84,10 +74,7 @@ impl LogWatcher {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn watch<F: ?Sized>(&mut self, callback: &mut F)
|
||||
where
|
||||
F: FnMut(String) -> LogWatcherAction,
|
||||
{
|
||||
pub fn watch(&mut self, callback: fn (line: String)) {
|
||||
loop{
|
||||
let mut line = String::new();
|
||||
let resp = self.reader.read_line(&mut line);
|
||||
|
|
@ -96,23 +83,18 @@ impl LogWatcher {
|
|||
if len > 0{
|
||||
self.pos += len as u64;
|
||||
self.reader.seek(SeekFrom::Start(self.pos)).unwrap();
|
||||
match callback(line.replace("\n", "")) {
|
||||
LogWatcherAction::SeekToEnd => {
|
||||
println!("SeekToEnd");
|
||||
self.reader.seek(SeekFrom::End(0)).unwrap();
|
||||
}
|
||||
LogWatcherAction::None => {}
|
||||
}
|
||||
callback(line.replace("\n", ""));
|
||||
line.clear();
|
||||
}else {
|
||||
if self.finish{
|
||||
break;
|
||||
} else {
|
||||
}
|
||||
else{
|
||||
self.reopen_if_log_rotated(callback);
|
||||
self.reader.seek(SeekFrom::Start(self.pos)).unwrap();
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
Err(err) => {
|
||||
println!("{}", err);
|
||||
}
|
||||
|
|
@ -120,3 +102,8 @@ impl LogWatcher {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#[test]
|
||||
fn it_works() {
|
||||
}
|
||||
|
|
|
|||
14
src/main.rs
14
src/main.rs
|
|
@ -2,7 +2,12 @@ use std::env::args;
|
|||
use std::process::exit;
|
||||
|
||||
extern crate logwatcher;
|
||||
use logwatcher::{LogWatcher, LogWatcherAction};
|
||||
use logwatcher::LogWatcher;
|
||||
|
||||
|
||||
fn parse_line(line: String) {
|
||||
println!("Line {}", line);
|
||||
}
|
||||
|
||||
fn main(){
|
||||
let filename = match args().nth(1) {
|
||||
|
|
@ -12,11 +17,6 @@ fn main() {
|
|||
exit(1);
|
||||
}
|
||||
};
|
||||
|
||||
let mut log_watcher = LogWatcher::register(filename).unwrap();
|
||||
|
||||
log_watcher.watch(&mut move |line: String| {
|
||||
println!("Line {}", line);
|
||||
LogWatcherAction::None
|
||||
});
|
||||
log_watcher.watch(parse_line);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue