Move primitive Vec Rust shims into cxx crate
diff --git a/src/rust_vec.rs b/src/rust_vec.rs
index 32db8cc..4ca17ca 100644
--- a/src/rust_vec.rs
+++ b/src/rust_vec.rs
@@ -1,4 +1,5 @@
 use std::mem;
+use std::ptr;
 
 #[repr(C)]
 pub struct RustVec<T> {
@@ -35,5 +36,47 @@
     }
 }
 
+macro_rules! rust_vec_shims_for_primitive {
+    ($ty:ident) => {
+        const _: () = {
+            attr! {
+                #[export_name = concat!("cxxbridge02$rust_vec$", stringify!($ty), "$drop")]
+                unsafe extern "C" fn __drop(this: *mut RustVec<$ty>) {
+                    ptr::drop_in_place(this);
+                }
+            }
+            attr! {
+                #[export_name = concat!("cxxbridge02$rust_vec$", stringify!($ty), "$len")]
+                unsafe extern "C" fn __len(this: *const RustVec<$ty>) -> usize {
+                    (*this).len()
+                }
+            }
+            attr! {
+                #[export_name = concat!("cxxbridge02$rust_vec$", stringify!($ty), "$data")]
+                unsafe extern "C" fn __data(this: *const RustVec<$ty>) -> *const $ty {
+                    (*this).as_ptr()
+                }
+            }
+            attr! {
+                #[export_name = concat!("cxxbridge02$rust_vec$", stringify!($ty), "$stride")]
+                unsafe extern "C" fn __stride() -> usize {
+                    mem::size_of::<$ty>()
+                }
+            }
+        };
+    };
+}
+
+rust_vec_shims_for_primitive!(u8);
+rust_vec_shims_for_primitive!(u16);
+rust_vec_shims_for_primitive!(u32);
+rust_vec_shims_for_primitive!(u64);
+rust_vec_shims_for_primitive!(i8);
+rust_vec_shims_for_primitive!(i16);
+rust_vec_shims_for_primitive!(i32);
+rust_vec_shims_for_primitive!(i64);
+rust_vec_shims_for_primitive!(f32);
+rust_vec_shims_for_primitive!(f64);
+
 const_assert_eq!(mem::size_of::<[usize; 3]>(), mem::size_of::<Vec<i32>>());
 const_assert_eq!(mem::align_of::<usize>(), mem::align_of::<Vec<i32>>());