Robbepop / apint

Arbitrary precision integers library.
Other
26 stars 4 forks source link

Issue 41 fixes: overhauling `BitWidth` construction #58

Closed AaronKutch closed 4 years ago

AaronKutch commented 4 years ago

Changing the way BitWidths are constructed is going to be a really invasive change no matter what. What this boils down to is:

When we agree on the changes, I also want to do the same treatment for BitPos and ShiftAmount.

coveralls commented 4 years ago

Coverage Status

Coverage decreased (-1.2%) to 80.712% when pulling e0f02878dd9e6e955f102c2510602b7feb0f32af on AaronKutch:issue-41 into 2818e58c779de645aab7fd6243c5fe8d0229f292 on Robbepop:master.

codecov-commenter commented 4 years ago

Codecov Report

Merging #58 into master will not change coverage. The diff coverage is n/a.

Impacted file tree graph

@@           Coverage Diff           @@
##           master      #58   +/-   ##
=======================================
  Coverage   81.87%   81.87%           
=======================================
  Files          23       23           
  Lines        5132     5132           
=======================================
  Hits         4202     4202           
  Misses        930      930           

Continue to review full report at Codecov.

Legend - Click here to learn more Δ = absolute <relative> (impact), ø = not affected, ? = missing data Powered by Codecov. Last update 2818e58...e0f0287. Read the comment docs.

AaronKutch commented 4 years ago

I realized that I should make better documentation, does the documentation explain the changes to you well?

AaronKutch commented 4 years ago

I have two months left now before university starts up again

AaronKutch commented 4 years ago

does this documentation make sense? This is in the last commit:

/// /// # Examples /// /// Most of what the functions in this library can do is self explanatory /// through the extensive function documentation, however there are details from /// across the library that need to be brought together when making things less /// verbose. /// ///

///     prelude::*,
///     Result,
/// };
///
/// use core::convert::TryFrom;
///
/// // This is just a dummy example, practical functions normally use `BitWidth`s as bit
/// // width arguments or have `TryInto<BitWidth>` based signatures like the one
/// // `ApInt::extend` uses.
/// fn example_function(input_width: usize) -> Result<ApInt> {
///     // The standard way of constructing `BitWidth`s and propogating errors up the call
///     // stack if the input is not a valid `BitWidth`.
///     let width = BitWidth::try_from(input_width)?;
///
///     // most single argument functions do not need any kind of error handling because
///     // the invariants are already handled by `BitWidth`.
///     let mut x = ApInt::signed_max_value(width);
///     x.sign_resize(width);
///     x.zero_resize(width);
///
///     // Let us resize `x` to some constant size. When using a constant or literal, a
///     // better shorthand for `BitWidth::try_from(42)?` is to use the `bw` free function
///     // instead:
///     x.sign_resize(bw(42));
///
///     // Let us extend `x` to another constant size. In this case, even though the
///     // `BitWidth` invariant is already handled, there is still error handling involved
///     // because this function returns an error if `x.width()` is larger than the target
///     // width.
///     x.sign_extend(width)?;
///
///     // Since error handling is involved no matter what, we have made the function
///     // signature accept `target_width: W` where
///     // `W: TryInto<BitWidth, Error = E>, crate::Error: From<E>`. This means that any
///     // type with an impl for `TryInto<BitWidth>` can be used as an argument. There is
///     // an `impl TryFrom<usize> for BitWidth`, so a plain `usize` can be entered into
///     // the function, and the function will handle both `BitWidth` invariant checking
///     // and its own invariants.
///     x.sign_extend(100)?;
///
///     Ok(x)
/// }
///
/// example_function(64).unwrap();
AaronKutch commented 4 years ago

I will close this PR and open up some smaller ones based on the lessons I have learned