Struct Package

Source
pub struct Package {
    pub spec: PackageSpec,
    pub target_profile_dir: PathBuf,
}
Expand description

A package, which is built from a specification written in a cargo manifest and a set of artifacts pulled from the target profile directory

Fields§

§spec: PackageSpec

The specification, which is written in [package.metadata.simics] in the crate manifest of the crate to package

§target_profile_dir: PathBuf

The target profile directory from which to pull artifacts and output the built package

Implementations§

Source§

impl Package

Source

pub fn builder() -> PackageBuilder<((), ())>

Create a builder for building Package. On the builder, call .spec(...), .target_profile_dir(...) to set the values of the fields. Finally, call .build() to create the instance of Package.

Source§

impl Package

Source

pub const INNER_PACKAGE_FILENAME: &'static str = "package.tar.gz"

The name of the inner package file which decompresses to the package directory

Source

pub const METADATA_FILENAME: &'static str = "ispm-metadata"

The name of the file containing metadata for ISPM to use when installing the package

Source

pub const ADDON_TYPE: &'static str = "addon"

The name of an addon package type

Source

pub const COMPRESSION_LEVEL: u32 = 6u32

Default level used by simics

Source

pub fn from_subcommand(subcommand: &Subcommand) -> Result<Self>

Instantiate a package from a cargo subcommand input, which is parsed from command line arguments

Source

pub fn package_dirname(&self) -> Result<String>

Construct the directory name of the package after expansion. It is an error to build a Rust crate package into any type other than an addon package (simics base is not a Rust package)

Source

pub fn full_package_name(&self) -> String

Construct the full package name, which includes the host directory name

Source

pub fn package_name(&self) -> String

Construct the package name, which is the package number and version, without an extension

Source

pub fn package_name_with_host(&self) -> String

Construct the package name with the host directory name

Source

pub fn package_filename(&self) -> String

Construct the filename for the output of this ISPM package

Source

pub fn set_header_common(header: &mut Header) -> Result<()>

Set common options on a tar header. On Unix, the modified time is set to the current time and the uid/gid are set to the current user.

Source

pub fn create_inner_tarball(&self) -> Result<(Vec<u8>, usize)>

Create the inner package.tar.gz tarball which expands to the simics package.

Source

pub fn create_tarball(&self) -> Result<Vec<u8>>

Create the outer tarball (actually an ISPM package) containing the inner package and a metadata file used by ISPM

Source

pub fn build<P>(&mut self, output: P) -> Result<PathBuf>
where P: AsRef<Path>,

Build the package, writing it to the directory specified by output and returning the path to the package

Trait Implementations§

Source§

impl Clone for Package

Source§

fn clone(&self) -> Package

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Package

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.