Skip to content

Commit

Permalink
Basic version with example
Browse files Browse the repository at this point in the history
This is not a complete solution but has the base form for how the
project is laid out and has an example showing how it can be used in a
project.

To test with telegraf you'll need to use the changes in this PR:
influxdata/telegraf#6024
  • Loading branch information
Timidger committed Jun 20, 2019
1 parent d23c530 commit b47c600
Show file tree
Hide file tree
Showing 10 changed files with 732 additions and 0 deletions.
6 changes: 6 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
[submodule "example/telegraf-plugin-go-glue"]
path = example/telegraf-plugin-go-glue
url = https://github.com/StarryInternet/telegraf-plugin-go-glue
[submodule "telegraf-plugin-go-glue"]
path = telegraf-plugin-go-glue
url = https://github.com/StarryInternet/telegraf-plugin-go-glue
18 changes: 18 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
[package]
name = "telegraf-plugin"
version = "0.1.0"
authors = ["Timidger <pcarpenter@starry.com>"]
edition = "2018"
build = "build.rs"

[lib]
proc-macro = true

[build-dependencies]
bindgen = "0.49.*"

[dependencies]
libc = "0.2"
syn = { version = "0.15", features = ["full", "fold"] }
quote = "0.6"
proc-macro2 = "0.4"
15 changes: 15 additions & 0 deletions build.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
// Copyright 2019. Starry, Inc. All Rights Reserved.
fn main() {
let builder = bindgen::builder()
.derive_debug(true)
.derive_default(true)
.derive_copy(true)
.generate_comments(true)
.blacklist_function("sample_config")
.blacklist_function("description")
.blacklist_function("gather")
.header("telegraf-plugin-go-glue/c_api.h")
.ctypes_prefix("libc");
let generated = builder.generate().unwrap();
generated.write_to_file("src/gen.rs").unwrap();
}
12 changes: 12 additions & 0 deletions example/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
[package]
name = "telegraf-plugin-example"
version = "0.1.0"
authors = ["Timidger <pcarpenter@starry.com>"]
edition = "2018"

[lib]
crate_type = ["staticlib"]

[dependencies]
libc = "0.2"
telegraf-plugin = { path = "../" }
43 changes: 43 additions & 0 deletions example/makefile-template.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
[tasks.rust_build]
command = "cargo"
args = ["build"]

[tasks.copy_go_files]
script = [
'''
cp target/debug/libtelegraf_plugin_example.a ./plugin.a
cp telegraf-plugin-go-glue/lib.go ./
cp telegraf-plugin-go-glue/c_api.h ./
cp telegraf-plugin-go-glue/go_defs.h ./
'''
]

[tasks.go_build]
command = "go"
args = ["build", "-buildmode=plugin", "-o=plugin.so"]
dependencies = ["rust_build", "copy_go_files"]

[tasks.cleanup]
script = [
'''
rm plugin.a
rm lib.go
rm c_api.h
rm go_defs.h
if [ -f plugin.so ]; then
chmod a+x plugin.so
fi
'''
]

# This must run after the Rust build,
# so that it can link the Rust artifact to it.
[tasks.build]
dependencies = [
"rust_build",
"go_build",
"cleanup"
]

[config]
on_error_task = "cleanup"
24 changes: 24 additions & 0 deletions example/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
// Copyright 2019. Starry, Inc. All Rights Reserved.
use telegraf_plugin::link_to_go;

macro_rules! map(
{ $($key:expr => $value:expr),* } => {
{
#[allow(unused_mut)]
let mut m = ::std::collections::HashMap::new();
$(
m.insert($key, $value);
)*
m
}
};
);

#[link_to_go("Description of the plugin", "<sample_config>")]
fn collect_metric() {
AddField(
"rust-metric".into(),
map! {"rust_key".into() => "rust_value".into()},
map! {"rust_field".into() => 100000000.into()},
)
}
1 change: 1 addition & 0 deletions example/telegraf-plugin-go-glue
Loading

0 comments on commit b47c600

Please sign in to comment.