File: lib.rs

package info (click to toggle)
ruby3.4 3.4.9-1~exp1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 152,040 kB
  • sloc: ruby: 1,262,509; ansic: 831,188; yacc: 28,233; pascal: 7,359; sh: 3,910; python: 1,799; cpp: 1,158; makefile: 827; asm: 808; javascript: 414; lisp: 109; perl: 62; awk: 36; xml: 4; sed: 4
file content (31 lines) | stat: -rw-r--r-- 1,044 bytes parent folder | download | duplicates (2)
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
// Clippy disagreements
#![allow(clippy::style)] // We are laid back about style
#![allow(clippy::too_many_arguments)] // :shrug:
#![allow(clippy::identity_op)] // Sometimes we do it for style

// TODO(alan): This lint is right -- the way we use `static mut` is UB happy. We have many globals
// and take `&mut` frequently, sometimes with a method that easily allows calling it twice.
//
// All of our globals rely on us running single threaded, which outside of boot-time relies on the
// VM lock (which signals and waits for all other threads to pause). To fix this properly, we should
// gather up all the globals into a struct to centralize the safety reasoning. That way we can also
// check for re-entrance in one place.
//
// We're too close to release to do that, though, so disable the lint for now.
#![allow(unknown_lints)]
#![allow(static_mut_refs)]
#![warn(unknown_lints)]

pub mod asm;
mod backend;
mod codegen;
mod core;
mod cruby;
mod disasm;
mod invariants;
mod options;
mod stats;
mod utils;
mod yjit;
mod virtualmem;
mod log;