Compare commits
14 Commits
062e5bb60e
...
f0d7ec56b3
| Author | SHA1 | Date | |
|---|---|---|---|
| f0d7ec56b3 | |||
| e34b7546a4 | |||
| e12212cd2c | |||
| 104cb98d9e | |||
| 7f59bb7c02 | |||
| 6c0b368f6b | |||
| 52ce39d579 | |||
|
7348681b65
|
|||
|
5178a7b8ea
|
|||
|
a3ff953e50
|
|||
|
b0f68fa7e0
|
|||
|
c25294333b
|
|||
|
08fac67f73
|
|||
|
06deeb3ae7
|
@@ -180,3 +180,16 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
meson setup -Ddocs=enabled docs
|
meson setup -Ddocs=enabled docs
|
||||||
ninja rustdoc -C docs
|
ninja rustdoc -C docs
|
||||||
|
|
||||||
|
grep:
|
||||||
|
runs-on: brutalisk
|
||||||
|
needs: [build-oci-image]
|
||||||
|
container:
|
||||||
|
image: ${{ vars.REGISTRY_URL }}/${{ gitea.repository }}:${{ needs.build-oci-image.outputs.image_tag }}
|
||||||
|
steps:
|
||||||
|
- name: Checkout repo
|
||||||
|
uses: actions/checkout@v5
|
||||||
|
|
||||||
|
- name: grep for patterns
|
||||||
|
run: |
|
||||||
|
git grep -E 'todo!|dbg!' -- '*.rs' && exit 1 || exit 0
|
||||||
|
|||||||
@@ -3,3 +3,4 @@ ninja rustfmt -C build
|
|||||||
ninja rustdoc -C build
|
ninja rustdoc -C build
|
||||||
ninja clippy -C build
|
ninja clippy -C build
|
||||||
ninja test -C build
|
ninja test -C build
|
||||||
|
git grep -E 'todo!|dbg!' -- '*.rs' && exit 1 || exit 0
|
||||||
|
|||||||
@@ -4,25 +4,12 @@
|
|||||||
use core::slice;
|
use core::slice;
|
||||||
use gentoo_utils::{Parseable, atom::Atom};
|
use gentoo_utils::{Parseable, atom::Atom};
|
||||||
use std::{
|
use std::{
|
||||||
|
env::{self},
|
||||||
io::{self, Write},
|
io::{self, Write},
|
||||||
sync::{LazyLock, Mutex},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Debug)]
|
|
||||||
struct State {
|
|
||||||
input: io::Stdin,
|
|
||||||
output: io::Stdout,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[unsafe(no_mangle)]
|
#[unsafe(no_mangle)]
|
||||||
pub unsafe extern "C" fn LLVMFuzzerTestOneInput(input: *const u8, len: usize) -> i32 {
|
pub unsafe extern "C" fn LLVMFuzzerTestOneInput(input: *const u8, len: usize) -> i32 {
|
||||||
static PIPES: LazyLock<Mutex<State>> = LazyLock::new(|| {
|
|
||||||
Mutex::new(State {
|
|
||||||
input: io::stdin(),
|
|
||||||
output: io::stdout(),
|
|
||||||
})
|
|
||||||
});
|
|
||||||
|
|
||||||
let slice = unsafe { slice::from_raw_parts(input, len) };
|
let slice = unsafe { slice::from_raw_parts(input, len) };
|
||||||
let str = str::from_utf8(slice).expect("expected ascii input");
|
let str = str::from_utf8(slice).expect("expected ascii input");
|
||||||
|
|
||||||
@@ -30,13 +17,13 @@ pub unsafe extern "C" fn LLVMFuzzerTestOneInput(input: *const u8, len: usize) ->
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut state = PIPES.lock().unwrap();
|
let stdin = io::stdin();
|
||||||
|
let mut stdout = io::stdout();
|
||||||
writeln!(&mut state.output, "{str}").unwrap();
|
|
||||||
|
|
||||||
let mut buffer = String::new();
|
let mut buffer = String::new();
|
||||||
|
|
||||||
state.input.read_line(&mut buffer).unwrap();
|
writeln!(&mut stdout, "{str}").unwrap();
|
||||||
|
|
||||||
|
stdin.read_line(&mut buffer).unwrap();
|
||||||
|
|
||||||
let control = match buffer.as_str().trim() {
|
let control = match buffer.as_str().trim() {
|
||||||
"0" => Ok(()),
|
"0" => Ok(()),
|
||||||
@@ -48,24 +35,33 @@ pub unsafe extern "C" fn LLVMFuzzerTestOneInput(input: *const u8, len: usize) ->
|
|||||||
|
|
||||||
match (control, gentoo_utils) {
|
match (control, gentoo_utils) {
|
||||||
(Ok(_), Ok(_)) => {
|
(Ok(_), Ok(_)) => {
|
||||||
|
if env::var("FUZZER_LOG").is_ok() {
|
||||||
eprintln!("agreement that {str} is valid");
|
eprintln!("agreement that {str} is valid");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
(Err(_), Err(_)) => {
|
(Err(_), Err(_)) => {
|
||||||
|
if env::var("FUZZER_LOG").is_ok() {
|
||||||
eprintln!("agreement that {str} is invalid");
|
eprintln!("agreement that {str} is invalid");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
(Ok(_), Err(rest)) => {
|
(Ok(_), Err(rest)) => {
|
||||||
panic!("disagreement on {str}\ncontrol:Ok\ngentoo-utils:Err({rest})");
|
panic!("disagreement on {str}\ncontrol:Ok\ngentoo-utils:Err({rest})");
|
||||||
}
|
}
|
||||||
(Err(_), Ok(atom))
|
(Err(_), Ok(atom))
|
||||||
if atom
|
if atom.usedeps().iter().any(|usedep| {
|
||||||
.usedeps()
|
atom.usedeps()
|
||||||
.iter()
|
.iter()
|
||||||
.any(|usedep| atom.usedeps().iter().filter(|u| usedep == *u).count() > 1) =>
|
.filter(|u| *usedep.flag() == *u.flag())
|
||||||
|
.count()
|
||||||
|
> 1
|
||||||
|
}) =>
|
||||||
{
|
{
|
||||||
|
if env::var("FUZZER_LOG").is_ok() {
|
||||||
eprintln!(
|
eprintln!(
|
||||||
"disagreement, but we will allow it since its probably because of duplicated usdeps"
|
"disagreement, but we will allow it since its probably because of duplicated usdeps"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
(Err(_), Ok(_)) => {
|
(Err(_), Ok(_)) => {
|
||||||
panic!("disagreement on {str}\ncontrol:Err\ngentoo-utils:Ok")
|
panic!("disagreement on {str}\ncontrol:Err\ngentoo-utils:Ok")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,12 +2,13 @@
|
|||||||
|
|
||||||
import sys
|
import sys
|
||||||
from portage.dep import Atom
|
from portage.dep import Atom
|
||||||
|
from portage.exception import InvalidAtom
|
||||||
|
|
||||||
for line in sys.stdin.buffer:
|
for line in sys.stdin.buffer:
|
||||||
try:
|
try:
|
||||||
Atom(line.decode().strip())
|
Atom(line.decode().strip())
|
||||||
sys.stdout.buffer.write(b"0\n")
|
sys.stdout.buffer.write(b"0\n")
|
||||||
except:
|
except InvalidAtom:
|
||||||
sys.stdout.buffer.write(b"1\n")
|
sys.stdout.buffer.write(b"1\n")
|
||||||
finally:
|
finally:
|
||||||
sys.stdout.buffer.flush()
|
sys.stdout.buffer.flush()
|
||||||
|
|||||||
@@ -102,7 +102,7 @@ impl Iterator for Ebuilds {
|
|||||||
Ok(ebuild) => break Some(Ok(ebuild)),
|
Ok(ebuild) => break Some(Ok(ebuild)),
|
||||||
Err(e) => break Some(Err(e)),
|
Err(e) => break Some(Err(e)),
|
||||||
},
|
},
|
||||||
_ => todo!(),
|
Err(e) => break Some(Err(Error::ReadDir(self.0.clone(), e))),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user