Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add rename rule for generated associated constant's base name #1034

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions docs.md
Original file line number Diff line number Diff line change
Expand Up @@ -837,6 +837,12 @@ deprecated_with_notes = "DEPRECATED_STRUCT_WITH_NOTE"
# default: false
# associated_constants_in_body: false

# The rename rule to apply to the struct name used for prefixing associated
# constants.
#
# default: "None"
rename_associated_constant = "None"

# Whether to derive a simple constructor that takes a value for every field.
# default: false
derive_constructor = true
Expand Down
3 changes: 3 additions & 0 deletions src/bindgen/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -493,6 +493,9 @@ pub struct StructConfig {
/// Whether associated constants should be in the body. Only applicable to
/// non-transparent structs, and in C++-only.
pub associated_constants_in_body: bool,
/// The rename rule to apply to the struct name used for prefixing associated
/// constants
pub rename_associated_constant: RenameRule,
/// The way to annotate this struct as #[must_use].
pub must_use: Option<String>,
/// The way to annotation this function as #[deprecated] without notes
Expand Down
17 changes: 16 additions & 1 deletion src/bindgen/ir/constant.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ use crate::bindgen::ir::{
};
use crate::bindgen::language_backend::LanguageBackend;
use crate::bindgen::library::Library;
use crate::bindgen::rename::{IdentifierType, RenameRule};
use crate::bindgen::writer::SourceWriter;
use crate::bindgen::Bindings;

Expand Down Expand Up @@ -666,7 +667,21 @@ impl Constant {
Cow::Borrowed(self.export_name())
} else {
let associated_name = match associated_to_struct {
Some(s) => Cow::Borrowed(s.export_name()),
Some(s) => {
let name = s.export_name();
let rules = s
.annotations
.parse_atom::<RenameRule>("rename-associated-constant");
let rules = rules
.as_ref()
.unwrap_or(&config.structure.rename_associated_constant);

if let Some(r) = rules.not_none() {
r.apply(name, IdentifierType::Type)
} else {
Cow::Borrowed(name)
}
}
None => {
let mut name = self.associated_to.as_ref().unwrap().name().to_owned();
config.export.rename(&mut name);
Expand Down
1 change: 1 addition & 0 deletions template.toml
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ rename_fields = "None"
# must_use = "MUST_USE_STRUCT"
# deprecated = "DEPRECATED_STRUCT"
# deprecated_with_note = "DEPRECATED_STRUCT_WITH_NOTE"
rename_associated_constant = "None"
derive_constructor = false
derive_eq = false
derive_neq = false
Expand Down
3 changes: 3 additions & 0 deletions tests/expectations-symbols/rename_associated_constant.c.sym
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
root;
};
12 changes: 12 additions & 0 deletions tests/expectations/rename_associated_constant.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>

typedef struct {

} Foo;
#define FOO_GA 10
#define FOO_ZO 3.14

void root(Foo x);
20 changes: 20 additions & 0 deletions tests/expectations/rename_associated_constant.compat.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>

typedef struct {

} Foo;
#define FOO_GA 10
#define FOO_ZO 3.14

#ifdef __cplusplus
extern "C" {
#endif // __cplusplus

void root(Foo x);

#ifdef __cplusplus
} // extern "C"
#endif // __cplusplus
17 changes: 17 additions & 0 deletions tests/expectations/rename_associated_constant.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
#include <cstdarg>
#include <cstdint>
#include <cstdlib>
#include <ostream>
#include <new>

struct Foo {

};
constexpr static const int32_t FOO_GA = 10;
constexpr static const float FOO_ZO = 3.14;

extern "C" {

void root(Foo x);

} // extern "C"
14 changes: 14 additions & 0 deletions tests/expectations/rename_associated_constant.pyx
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
from libc.stdint cimport int8_t, int16_t, int32_t, int64_t, intptr_t
from libc.stdint cimport uint8_t, uint16_t, uint32_t, uint64_t, uintptr_t
cdef extern from *:
ctypedef bint bool
ctypedef struct va_list

cdef extern from *:

ctypedef struct Foo:
pass
const int32_t FOO_GA # = 10
const float FOO_ZO # = 3.14

void root(Foo x);
12 changes: 12 additions & 0 deletions tests/expectations/rename_associated_constant_both.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>

typedef struct Foo {

} Foo;
#define FOO_GA 10
#define FOO_ZO 3.14

void root(struct Foo x);
20 changes: 20 additions & 0 deletions tests/expectations/rename_associated_constant_both.compat.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>

typedef struct Foo {

} Foo;
#define FOO_GA 10
#define FOO_ZO 3.14

#ifdef __cplusplus
extern "C" {
#endif // __cplusplus

void root(struct Foo x);

#ifdef __cplusplus
} // extern "C"
#endif // __cplusplus
12 changes: 12 additions & 0 deletions tests/expectations/rename_associated_constant_tag.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>

struct Foo {

};
#define FOO_GA 10
#define FOO_ZO 3.14

void root(struct Foo x);
20 changes: 20 additions & 0 deletions tests/expectations/rename_associated_constant_tag.compat.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>

struct Foo {

};
#define FOO_GA 10
#define FOO_ZO 3.14

#ifdef __cplusplus
extern "C" {
#endif // __cplusplus

void root(struct Foo x);

#ifdef __cplusplus
} // extern "C"
#endif // __cplusplus
14 changes: 14 additions & 0 deletions tests/expectations/rename_associated_constant_tag.pyx
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
from libc.stdint cimport int8_t, int16_t, int32_t, int64_t, intptr_t
from libc.stdint cimport uint8_t, uint16_t, uint32_t, uint64_t, uintptr_t
cdef extern from *:
ctypedef bint bool
ctypedef struct va_list

cdef extern from *:

cdef struct Foo:
pass
const int32_t FOO_GA # = 10
const float FOO_ZO # = 3.14

void root(Foo x);
11 changes: 11 additions & 0 deletions tests/rust/rename_associated_constant.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
/// cbindgen:rename-associated-constant=UpperCase
#[repr(C)]
struct Foo {}

impl Foo {
pub const GA: i32 = 10;
pub const ZO: f32 = 3.14;
}

#[no_mangle]
pub extern "C" fn root(x: Foo) { }
2 changes: 2 additions & 0 deletions tests/rust/rename_associated_constant.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
[struct]
rename_associated_constant = "UpperCase"