Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for bitvec 1.0.0 #2

Open
wants to merge 12 commits into
base: main
Choose a base branch
from
28 changes: 28 additions & 0 deletions .github/workflows/release-plz.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
name: Release-plz

permissions:
pull-requests: write
contents: write

on:
push:
branches:
- main

jobs:

release-plz:
name: Release-plz
runs-on: ubuntu-22.04
steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- name: Run release-plz
uses: MarcoIeni/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
CARGO_REGISTRY_TOKEN: ${{ secrets.CARGO_REGISTRY_TOKEN }}
191 changes: 191 additions & 0 deletions .github/workflows/rust.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,191 @@
name: Mean Bean CI

on: [push, pull_request]

jobs:
# This job downloads and stores `cross` as an artifact, so that it can be
# redownloaded across all of the jobs. Currently this copied pasted between
# `ci.yml` and `deploy.yml`. Make sure to update both places when making
# changes.
install-cross:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
with:
depth: 50
- uses: XAMPPRocky/get-github-release@v1
id: cross
with:
owner: rust-embedded
repo: cross
matches: ${{ matrix.platform }}
token: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/upload-artifact@v1
with:
name: cross-${{ matrix.platform }}
path: ${{ steps.cross.outputs.install_path }}
strategy:
matrix:
platform: [linux-musl, apple-darwin]

windows:
runs-on: windows-latest
# Windows technically doesn't need this, but if we don't block windows on it
# some of the windows jobs could fill up the concurrent job queue before
# one of the install-cross jobs has started, so this makes sure all
# artifacts are downloaded first.
needs: install-cross
steps:
- uses: actions/checkout@v2
with:
depth: 50
- run: ci/set_rust_version.bash ${{ matrix.channel }} ${{ matrix.target }}
shell: bash
- run: ci/build.bash cargo ${{ matrix.target }}
shell: bash
- run: ci/test.bash cargo ${{ matrix.target }}
shell: bash
- run: ci/fmt-check.bash cargo
shell: bash
- run: ci/clippy.bash cargo
if: matrix.target == 'stable'
shell: bash

strategy:
fail-fast: true
matrix:
channel: [stable, beta, nightly]
target:
# MSVC
- i686-pc-windows-msvc
- x86_64-pc-windows-msvc
# GNU: You typically only need to test Windows GNU if you're
# specifically targetting it, and it can cause issues with some
# dependencies if you're not so it's disabled by self.
# - i686-pc-windows-gnu
# - x86_64-pc-windows-gnu

macos:
runs-on: macos-latest
needs: install-cross
steps:
- uses: actions/checkout@v2
with:
depth: 50

- uses: actions/download-artifact@v1
with:
name: cross-apple-darwin
path: /usr/local/bin/

- run: chmod +x /usr/local/bin/cross

- run: ci/set_rust_version.bash ${{ matrix.channel }} ${{ matrix.target }}
- run: ci/build.bash cross ${{ matrix.target }}
# Only test on macOS platforms since we can't simulate the others.
- run: ci/test.bash cross ${{ matrix.target }}
if: matrix.target == 'x86_64-apple-darwin'
- run: ci/fmt-check.bash cargo
shell: bash
- run: ci/clippy.bash cargo
if: matrix.target == 'stable'
shell: bash

strategy:
fail-fast: true
matrix:
channel: [stable, beta, nightly]
target:
# macOS
- x86_64-apple-darwin
# iOS
- aarch64-apple-ios
- x86_64-apple-ios

linux:
runs-on: ubuntu-latest
needs: install-cross
steps:
- uses: actions/checkout@v2
with:
depth: 50

- name: Download Cross
uses: actions/download-artifact@v1
with:
name: cross-linux-musl
path: /tmp/
- run: chmod +x /tmp/cross
- run: ci/set_rust_version.bash ${{ matrix.channel }} ${{ matrix.target }}
- run: ci/build.bash /tmp/cross ${{ matrix.target }}
# These targets have issues with being tested so they are disabled
# by default. You can try disabling to see if they work for
# your project.
- run: ci/test.bash /tmp/cross ${{ matrix.target }}
if: |
!contains(matrix.target, 'android') &&
!contains(matrix.target, 'bsd') &&
!contains(matrix.target, 'solaris') &&
matrix.target != 'armv5te-unknown-linux-musleabi' &&
matrix.target != 'sparc64-unknown-linux-gnu'
- run: ci/fmt-check.bash cargo
shell: bash
- run: ci/clippy.bash cargo
if: matrix.target == 'stable'
shell: bash

strategy:
fail-fast: true
matrix:
channel: [stable, beta, nightly]
target:
# WASM, off by default as most rust projects aren't compatible yet.
# - wasm32-unknown-emscripten
# Linux
- aarch64-unknown-linux-gnu
- aarch64-unknown-linux-musl
- arm-unknown-linux-gnueabi
- arm-unknown-linux-gnueabihf
- arm-unknown-linux-musleabi
- arm-unknown-linux-musleabihf
- armv5te-unknown-linux-musleabi
- armv7-unknown-linux-gnueabihf
- armv7-unknown-linux-musleabihf
- i586-unknown-linux-gnu
- i586-unknown-linux-musl
- i686-unknown-linux-gnu
- i686-unknown-linux-musl
# - mips-unknown-linux-gnu
# - mips-unknown-linux-musl
# - mips64-unknown-linux-gnuabi64
# - mips64el-unknown-linux-gnuabi64
# - mipsel-unknown-linux-gnu
# - mipsel-unknown-linux-musl
- s390x-unknown-linux-gnu
- x86_64-unknown-linux-gnu
- x86_64-unknown-linux-musl
# - sparc64-unknown-linux-gnu
# Android
# - aarch64-linux-android
# - arm-linux-androideabi
# - armv7-linux-androideabi
# - i686-linux-android
# - x86_64-linux-android
# *BSD
# The FreeBSD targets can have issues linking so they are disabled
# by default.
# - i686-unknown-freebsd
# - x86_64-unknown-freebsd
# - x86_64-unknown-netbsd
# DragonFly (Doesn't currently work)
# - x86_64-unknown-dragonfly
# Solaris
# - sparcv9-sun-solaris
# - x86_64-sun-solaris
# Bare Metal
# These are no-std embedded targets, so they will only build if your
# crate is `no_std` compatible.
# - thumbv6m-none-eabi
# - thumbv7em-none-eabi
# - thumbv7em-none-eabihf
# - thumbv7m-none-eabi
14 changes: 14 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# Changelog
All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [Unreleased]

## [0.2.1](https://github.com/XAMPPRocky/nom-bitvec/compare/v0.2.0...v0.2.1) - 2024-08-16

### Other
- Create rust.yml
- Create release-plz.yaml
- Disable default `bitvec` features to avoid `std`.
6 changes: 3 additions & 3 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "nom-bitvec"
version = "0.2.0"
name = "bitvec-nom2"
version = "0.2.1"
edition = "2018"
description = "Bit level parsing for nom with bitvec"
license = "MIT"
Expand All @@ -13,7 +13,7 @@ categories = ["parsing"]
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
bitvec = "0.22.3"
bitvec = { version = "1", default-features = false, features = ["alloc"] }
nom = { version = "7.0.0", default-features = false }

[features]
Expand Down
Loading