1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// This file is part of the mem-rs distribution (https://github.com/FrankvdStam/mem-rs).
// Copyright (c) 2022 Frank van der Stam.
// https://github.com/FrankvdStam/mem-rs/blob/main/LICENSE
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, version 3.
//
// This program is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.

use std::path::Path;
use windows::core::{PCSTR, PCWSTR};

pub fn scan(code: &[u8], pattern: &[Option<u8>]) -> Option<usize>
{
    if code.len() == 0
    {
        return None;
    }

    for i in 0..code.len() - pattern.len()
    {
        let mut found = true;
        for j in 0..pattern.len()
        {
            if let Some(byte) = pattern[j]
            {
                if byte != code[i + j]
                {
                    found = false;
                    break;
                }
            }
        }
        if found
        {
            return Some(i);
        }
    }
    return None;
}

pub fn to_pattern(str: &str) -> Vec<Option<u8>>
{
    let mut vec = Vec::new();
    for substr in str.split(" ")
    {
        if substr == "?"
        {
            vec.push(None);
        }
        else
        {
            vec.push(Some(u8::from_str_radix(substr, 16).expect("invalid hex string in pattern string")));
        }
    }
    return vec;
}

pub fn vec_u16_to_u8(vec_u16: &Vec<u16>) -> Vec<u8>
{
    return unsafe { vec_u16.align_to::<u8>().1.to_vec() };
}

pub fn w32str_to_string(w32str: &Vec<u16>) -> String
{
    return w32str.iter().map(|&v| (v & 0xFF) as u8).take_while(|&c| c != 0).map(|c| c as char).collect();
}

pub fn get_file_name_from_string(str: &String) -> String
{
    return String::from(Path::new(&str).file_name().unwrap().to_str().unwrap());
}

pub fn get_w32str_from_str(str: &str) -> Vec<u16>
{
    return str.encode_utf16().collect();
}
pub fn get_pcwstr_from_str(str: &str) -> PCWSTR
{
    let vec: Vec<u16> = str.encode_utf16().collect();
    return PCWSTR(vec.as_ptr());
}

pub fn get_pcstr_from_str(str: &str) -> PCSTR
{
    return PCSTR(str.as_ptr());
}