runtime: document all functions (#7612)
parent
d87011ab78
commit
9e6575eaab
|
@ -0,0 +1,13 @@
|
|||
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
|
||||
// Use of this source code is governed by an MIT license
|
||||
// that can be found in the LICENSE file.
|
||||
|
||||
module runtime
|
||||
|
||||
//$if linux {
|
||||
fn C.sysconf(name int) i64
|
||||
//}
|
||||
|
||||
//$if windows {
|
||||
fn C.GetCurrentProcessorNumber() u32
|
||||
//}
|
|
@ -6,14 +6,10 @@ module runtime
|
|||
|
||||
import os
|
||||
|
||||
//$if linux {
|
||||
fn C.sysconf(name int) i64
|
||||
//}
|
||||
|
||||
//$if windows {
|
||||
fn C.GetCurrentProcessorNumber() u32
|
||||
//}
|
||||
|
||||
// nr_jobs returns the same as `nr_cpus` with the difference that if an
|
||||
// environment variable `VJOBS` is set, and has a value > 0,
|
||||
// then `nr_jobs` will return that number instead.
|
||||
// This is useful for runtime tweaking of e.g. threaded or concurrent code.
|
||||
pub fn nr_jobs() int {
|
||||
mut cpus := nr_cpus()
|
||||
// allow for overrides, for example using `VJOBS=32 ./v test .`
|
||||
|
@ -24,21 +20,25 @@ pub fn nr_jobs() int {
|
|||
return cpus
|
||||
}
|
||||
|
||||
// is_32bit returns true if the current executable is running on a 32 bit system.
|
||||
pub fn is_32bit() bool {
|
||||
$if x32 { return true }
|
||||
return false
|
||||
}
|
||||
|
||||
// is_64bit returns true if the current executable is running on a 64 bit system.
|
||||
pub fn is_64bit() bool {
|
||||
$if x64 { return true }
|
||||
return false
|
||||
}
|
||||
|
||||
// is_little_endian returns true if the current executable is running on a little-endian system.
|
||||
pub fn is_little_endian() bool {
|
||||
$if little_endian { return true }
|
||||
return false
|
||||
}
|
||||
|
||||
// is_big_endian returns true if the current executable is running on a big-endian system.
|
||||
pub fn is_big_endian() bool {
|
||||
$if big_endian { return true }
|
||||
return false
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
module runtime
|
||||
|
||||
// nr_cpus returns the number of virtual CPU cores found on the system.
|
||||
pub fn nr_cpus() int {
|
||||
$if linux {
|
||||
return int(C.sysconf(C._SC_NPROCESSORS_ONLN))
|
||||
|
@ -11,4 +12,4 @@ pub fn nr_cpus() int {
|
|||
return int(C.sysconf(C._SC_NPROCESSORS_ONLN))
|
||||
}
|
||||
return 1
|
||||
}
|
||||
}
|
||||
|
|
|
@ -8,6 +8,7 @@ struct C.SYSTEM_INFO {
|
|||
}
|
||||
fn C.GetSystemInfo(&C.SYSTEM_INFO)
|
||||
|
||||
// nr_cpus returns the number of virtual CPU cores found on the system.
|
||||
pub fn nr_cpus() int {
|
||||
sinfo := C.SYSTEM_INFO{}
|
||||
C.GetSystemInfo(&sinfo)
|
||||
|
|
Loading…
Reference in New Issue