diff options
author | Manos Pitsidianakis <manos.pitsidianakis@linaro.org> | 2024-10-03 16:28:50 +0300 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2024-10-11 12:32:17 +0200 |
commit | 2b74dd918007d91f5fee94ad0034b5e7a30ed777 (patch) | |
tree | 71c598b2b4150e7e464954a99f14bb7086f026b2 /scripts | |
parent | 474dcfc0ab093043fee9952282bcab5f1dedc43a (diff) | |
download | qemu-2b74dd918007d91f5fee94ad0034b5e7a30ed777.zip qemu-2b74dd918007d91f5fee94ad0034b5e7a30ed777.tar.gz qemu-2b74dd918007d91f5fee94ad0034b5e7a30ed777.tar.bz2 |
rust: add utility procedural macro crate
This commit adds a helper crate library, qemu-api-macros for derive (and
other procedural) macros to be used along qemu-api.
It needs to be a separate library because in Rust, procedural macros, or
macros that can generate arbitrary code, need to be special separate
compilation units.
Only one macro is introduced in this patch, #[derive(Object)]. It
generates a constructor to register a QOM TypeInfo on init and it must
be used on types that implement qemu_api::definitions::ObjectImpl trait.
Reviewed-by: Junjie Mao <junjie.mao@hotmail.com>
Signed-off-by: Manos Pitsidianakis <manos.pitsidianakis@linaro.org>
Link: https://lore.kernel.org/r/dd645642406a6dc2060c6f3f17db2bc77ed67b59.1727961605.git.manos.pitsidianakis@linaro.org
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/archive-source.sh | 4 | ||||
-rwxr-xr-x | scripts/make-release | 4 |
2 files changed, 6 insertions, 2 deletions
diff --git a/scripts/archive-source.sh b/scripts/archive-source.sh index 9d9b2e2..62a2cf4 100755 --- a/scripts/archive-source.sh +++ b/scripts/archive-source.sh @@ -26,7 +26,9 @@ sub_file="${sub_tdir}/submodule.tar" # independent of what the developer currently has initialized # in their checkout, because the build environment is completely # different to the host OS. -subprojects="keycodemapdb libvfio-user berkeley-softfloat-3 berkeley-testfloat-3" +subprojects="keycodemapdb libvfio-user berkeley-softfloat-3 + berkeley-testfloat-3 proc-macro2-1-rs quote-1-rs + syn-2-rs unicode-ident-1-rs" sub_deinit="" function cleanup() { diff --git a/scripts/make-release b/scripts/make-release index 6e0433d..cf7d694 100755 --- a/scripts/make-release +++ b/scripts/make-release @@ -17,7 +17,9 @@ if [ $# -ne 2 ]; then fi # Only include wraps that are invoked with subproject() -SUBPROJECTS="libvfio-user keycodemapdb berkeley-softfloat-3 berkeley-testfloat-3" +SUBPROJECTS="libvfio-user keycodemapdb berkeley-softfloat-3 + berkeley-testfloat-3 proc-macro2-1-rs quote-1-rs + syn-2-rs unicode-ident-1-rs" src="$1" version="$2" |