rabbitizer 2.0.0-alpha.9

MIPS instruction decoder
Documentation
/* SPDX-FileCopyrightText: © 2022-2025 Decompollaborate */
/* SPDX-License-Identifier: MIT */

/* Automatically generated. DO NOT MODIFY */

use crate::register_descriptors::RegisterDescriptor;
use crate::registers_meta::IntRegisterConversionError;
use core::ops::Index;
#[derive(Debug, Copy, Clone, Hash, PartialEq, Eq, PartialOrd, Ord)]
#[allow(non_camel_case_types)]
#[allow(clippy::exhaustive_enums)]
pub enum R5900EEVF {
    vf0 = 0,
    vf1 = 1,
    vf2 = 2,
    vf3 = 3,
    vf4 = 4,
    vf5 = 5,
    vf6 = 6,
    vf7 = 7,
    vf8 = 8,
    vf9 = 9,
    vf10 = 10,
    vf11 = 11,
    vf12 = 12,
    vf13 = 13,
    vf14 = 14,
    vf15 = 15,
    vf16 = 16,
    vf17 = 17,
    vf18 = 18,
    vf19 = 19,
    vf20 = 20,
    vf21 = 21,
    vf22 = 22,
    vf23 = 23,
    vf24 = 24,
    vf25 = 25,
    vf26 = 26,
    vf27 = 27,
    vf28 = 28,
    vf29 = 29,
    vf30 = 30,
    vf31 = 31,
}
pub static R5900EE_VF: [RegisterDescriptor; 32] = {
    let mut table = [RegisterDescriptor::default(); 32];
    table[R5900EEVF::vf0 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf0"), 0, concat!("$vf", "0"), true)
    };
    table[R5900EEVF::vf1 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf1"), 1, concat!("$vf", "1"), true)
    };
    table[R5900EEVF::vf2 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf2"), 2, concat!("$vf", "2"), true)
    };
    table[R5900EEVF::vf3 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf3"), 3, concat!("$vf", "3"), true)
    };
    table[R5900EEVF::vf4 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf4"), 4, concat!("$vf", "4"), true)
    };
    table[R5900EEVF::vf5 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf5"), 5, concat!("$vf", "5"), true)
    };
    table[R5900EEVF::vf6 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf6"), 6, concat!("$vf", "6"), true)
    };
    table[R5900EEVF::vf7 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf7"), 7, concat!("$vf", "7"), true)
    };
    table[R5900EEVF::vf8 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf8"), 8, concat!("$vf", "8"), true)
    };
    table[R5900EEVF::vf9 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf9"), 9, concat!("$vf", "9"), true)
    };
    table[R5900EEVF::vf10 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf10"), 10, concat!("$vf", "10"), true)
    };
    table[R5900EEVF::vf11 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf11"), 11, concat!("$vf", "11"), true)
    };
    table[R5900EEVF::vf12 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf12"), 12, concat!("$vf", "12"), true)
    };
    table[R5900EEVF::vf13 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf13"), 13, concat!("$vf", "13"), true)
    };
    table[R5900EEVF::vf14 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf14"), 14, concat!("$vf", "14"), true)
    };
    table[R5900EEVF::vf15 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf15"), 15, concat!("$vf", "15"), true)
    };
    table[R5900EEVF::vf16 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf16"), 16, concat!("$vf", "16"), true)
    };
    table[R5900EEVF::vf17 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf17"), 17, concat!("$vf", "17"), true)
    };
    table[R5900EEVF::vf18 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf18"), 18, concat!("$vf", "18"), true)
    };
    table[R5900EEVF::vf19 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf19"), 19, concat!("$vf", "19"), true)
    };
    table[R5900EEVF::vf20 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf20"), 20, concat!("$vf", "20"), true)
    };
    table[R5900EEVF::vf21 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf21"), 21, concat!("$vf", "21"), true)
    };
    table[R5900EEVF::vf22 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf22"), 22, concat!("$vf", "22"), true)
    };
    table[R5900EEVF::vf23 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf23"), 23, concat!("$vf", "23"), true)
    };
    table[R5900EEVF::vf24 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf24"), 24, concat!("$vf", "24"), true)
    };
    table[R5900EEVF::vf25 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf25"), 25, concat!("$vf", "25"), true)
    };
    table[R5900EEVF::vf26 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf26"), 26, concat!("$vf", "26"), true)
    };
    table[R5900EEVF::vf27 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf27"), 27, concat!("$vf", "27"), true)
    };
    table[R5900EEVF::vf28 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf28"), 28, concat!("$vf", "28"), true)
    };
    table[R5900EEVF::vf29 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf29"), 29, concat!("$vf", "29"), true)
    };
    table[R5900EEVF::vf30 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf30"), 30, concat!("$vf", "30"), true)
    };
    table[R5900EEVF::vf31 as usize] = RegisterDescriptor {
        ..RegisterDescriptor::new(concat!("$", "vf31"), 31, concat!("$vf", "31"), true)
    };
    table
};
impl R5900EEVF {
    pub const fn try_from_u32(value: u32) -> Result<Self, IntRegisterConversionError> {
        match value {
            0 => Ok(Self::vf0),
            1 => Ok(Self::vf1),
            2 => Ok(Self::vf2),
            3 => Ok(Self::vf3),
            4 => Ok(Self::vf4),
            5 => Ok(Self::vf5),
            6 => Ok(Self::vf6),
            7 => Ok(Self::vf7),
            8 => Ok(Self::vf8),
            9 => Ok(Self::vf9),
            10 => Ok(Self::vf10),
            11 => Ok(Self::vf11),
            12 => Ok(Self::vf12),
            13 => Ok(Self::vf13),
            14 => Ok(Self::vf14),
            15 => Ok(Self::vf15),
            16 => Ok(Self::vf16),
            17 => Ok(Self::vf17),
            18 => Ok(Self::vf18),
            19 => Ok(Self::vf19),
            20 => Ok(Self::vf20),
            21 => Ok(Self::vf21),
            22 => Ok(Self::vf22),
            23 => Ok(Self::vf23),
            24 => Ok(Self::vf24),
            25 => Ok(Self::vf25),
            26 => Ok(Self::vf26),
            27 => Ok(Self::vf27),
            28 => Ok(Self::vf28),
            29 => Ok(Self::vf29),
            30 => Ok(Self::vf30),
            31 => Ok(Self::vf31),
            x => Err(IntRegisterConversionError::new_out_of_range(
                x,
                32,
                "R5900EEVF",
            )),
        }
    }
    #[must_use]
    pub const fn count() -> usize {
        32
    }
}
impl TryFrom<u32> for R5900EEVF {
    type Error = IntRegisterConversionError;
    fn try_from(value: u32) -> Result<Self, Self::Error> {
        Self::try_from_u32(value)
    }
}
impl Default for R5900EEVF {
    fn default() -> Self {
        Self::default()
    }
}
impl Index<R5900EEVF> for [RegisterDescriptor] {
    type Output = RegisterDescriptor;
    fn index(&self, index: R5900EEVF) -> &Self::Output {
        &self[index as usize]
    }
}
#[cfg(test)]
mod tests {
    use super::*;
    #[test]
    fn check_dollar() {
        for x in &R5900EE_VF {
            if x.has_dollar {
                assert!(
                    x.name.starts_with('$'),
                    "Register {} is missing dollar sign",
                    x.name
                );
                assert!(
                    x.name_o32.is_none_or(|x| x.starts_with('$')),
                    "Register {:?} is missing dollar sign",
                    x.name_o32
                );
                assert!(
                    x.name_o64.is_none_or(|x| x.starts_with('$')),
                    "Register {:?} is missing dollar sign",
                    x.name_o64
                );
                assert!(
                    x.name_n32.is_none_or(|x| x.starts_with('$')),
                    "Register {:?} is missing dollar sign",
                    x.name_n32
                );
                assert!(
                    x.name_n64.is_none_or(|x| x.starts_with('$')),
                    "Register {:?} is missing dollar sign",
                    x.name_n64
                );
                assert!(
                    x.name_eabi32.is_none_or(|x| x.starts_with('$')),
                    "Register {:?} is missing dollar sign",
                    x.name_eabi32
                );
                assert!(
                    x.name_eabi64.is_none_or(|x| x.starts_with('$')),
                    "Register {:?} is missing dollar sign",
                    x.name_eabi64
                );
            } else {
                assert!(
                    !x.name.starts_with('$'),
                    "Register {} has dollar sign when it shouldn't",
                    x.name
                );
                assert!(
                    x.name_o32.is_none_or(|x| !x.starts_with('$')),
                    "Register {:?} has dollar sign when it shouldn't",
                    x.name_o32
                );
                assert!(
                    x.name_o64.is_none_or(|x| !x.starts_with('$')),
                    "Register {:?} has dollar sign when it shouldn't",
                    x.name_o64
                );
                assert!(
                    x.name_n32.is_none_or(|x| !x.starts_with('$')),
                    "Register {:?} has dollar sign when it shouldn't",
                    x.name_n32
                );
                assert!(
                    x.name_n64.is_none_or(|x| !x.starts_with('$')),
                    "Register {:?} has dollar sign when it shouldn't",
                    x.name_n64
                );
                assert!(
                    x.name_eabi32.is_none_or(|x| !x.starts_with('$')),
                    "Register {:?} has dollar sign when it shouldn't",
                    x.name_eabi32
                );
                assert!(
                    x.name_eabi64.is_none_or(|x| !x.starts_with('$')),
                    "Register {:?} has dollar sign when it shouldn't",
                    x.name_eabi64
                );
            }
        }
    }
    #[test]
    fn check_descriptor_valid() {
        for (i, x) in R5900EE_VF.iter().enumerate() {
            assert!(x.value() as usize == i, "Broken register index?");
            x.check_valid_entry();
        }
    }
}