1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
use libc::c_void;

use crate::util::{go_iowritter::GoIOWritter, util::ref_free_drop, go_type::FFIError};

use self::ffi::nosqldb_logger_new;

pub(crate) mod ffi {
    use std::mem;

    use crate::util::{go_iowritter::{GoIOWritterPtr, GoIOWritter}, util::{ffi::FfiNosqldbPtrAndErrorNewReturn, c_char_to_str}, go_type::FFIError};

    use super::{NosqldbLogger, LoggerLogLevel};

    extern "C" {
        pub fn ffi_nosqldb_logger_new(ioWritter_ptr: GoIOWritterPtr, level: LoggerLogLevel, useLocalTime: bool) -> FfiNosqldbPtrAndErrorNewReturn;
    }

    pub fn nosqldb_logger_new(
        writter: GoIOWritter,
        level: LoggerLogLevel,
        use_local_time: bool,
    ) -> Result<NosqldbLogger, FFIError> {
        let FfiNosqldbPtrAndErrorNewReturn { ptr: logger_ptr, go_error_ptr } = unsafe { ffi_nosqldb_logger_new(writter.go_io_writter_ptr, level, use_local_time) };
        mem::forget(writter);
        if go_error_ptr.is_null() {
            Ok(NosqldbLogger { nosqldb_logger: logger_ptr })
        } else {
            Err(FFIError::GoError(c_char_to_str(go_error_ptr)?))
        }
    }
}

#[repr(C)]
pub enum LoggerLogLevel {
    // Fine represents a level used to log the most detailed output.
    Fine = 10,

    // Trace represents a level used to log tracing messages.
    Trace = 15,

    // Debug represents a level used to log debug messages.
    Debug = 20,

    // Info represents a level used to log informative messages.
    Info = 30,

    // Warn represents a level used to log warning messages.
    Warn = 40,

    // Error represents a level used to log error messages.
    Error = 50,

    // Off turns off logging.
    Off = 99,
}

pub(crate) type NosqldbLoggerPtr = *const c_void;

pub struct NosqldbLogger {
    pub(crate) nosqldb_logger: NosqldbLoggerPtr,
}

impl NosqldbLogger {
    pub fn new <T: std::io::Write + 'static> (
        writter: T,
        level: LoggerLogLevel,
        use_local_time: bool,
    ) -> Result<Self, FFIError>  {
        let writter = GoIOWritter::new(writter);
        nosqldb_logger_new(writter, level, use_local_time)
    }
}

impl Drop for NosqldbLogger {
    fn drop(&mut self) {
        ref_free_drop(self.nosqldb_logger);
    }
}