Auto merge of #1441 - scoopr:fix_namespace_macro, r=emilio

Fix namespaces with macro names

This fixes
1. When the name of the namespace is actually a `#define` macro, which previosly got the name of the macro
2. When the namespace is started from a included file (the header is wrapped in a `nsbegin.h`/`nsend.h` includes), which previously got generated name for the namespace

The change is small, but I feel it is a bit of a hack. It wasn't obvious to me what is a better path though.
tree: d774d2db11d15f4663a537ad4eb5e66fc8f7cf55
  1. .github/
  2. bindgen-integration/
  3. book/
  4. ci/
  5. csmith-fuzzing/
  6. releases/
  7. src/
  8. tests/
  9. .gitattributes
  10. .gitignore
  11. .travis.yml
  12. appveyor.yml
  13. build.rs
  14. Cargo.lock
  15. Cargo.toml
  16. CHANGELOG.md
  17. CONTRIBUTING.md
  18. example-graphviz-ir.png
  19. LICENSE
  20. README.md
  21. rustfmt.toml
README.md

bindgen

impl period has been started! Join us at Gitter.im.

bindgen automatically generates Rust FFI bindings to C (and some C++) libraries.

For example, given the C header doggo.h:

typedef struct Doggo {
    int many;
    char wow;
} Doggo;

void eleven_out_of_ten_majestic_af(Doggo* pupper);

bindgen produces Rust FFI code allowing you to call into the doggo library's functions and use its types:

/* automatically generated by rust-bindgen */

#[repr(C)]
pub struct Doggo {
    pub many: ::std::os::raw::c_int,
    pub wow: ::std::os::raw::c_char,
}

extern "C" {
    pub fn eleven_out_of_ten_majestic_af(pupper: *mut Doggo);
}

Users Guide

📚 Read the bindgen users guide here! 📚

API Reference

API reference documentation is on docs.rs

Contributing

See CONTRIBUTING.md for hacking on bindgen!