Struct simics_package::package::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 copy 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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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.