chore(fmt): add legacy stubs and strip trailing whitespace to unblock cargo fmt
This commit is contained in:
@ -1,37 +1,37 @@
|
||||
/*! 🚫 NullBox - NULL値表現Box
|
||||
*
|
||||
*
|
||||
* ## 📝 概要
|
||||
* null/void値を表現する特別なBox。
|
||||
* JavaScript null、Python None、C# nullと同等の機能を提供。
|
||||
* NULL安全プログラミングをサポート。
|
||||
*
|
||||
*
|
||||
* ## 🛠️ 利用可能メソッド
|
||||
* - `isNull()` - null判定 (常にtrue)
|
||||
* - `isNotNull()` - 非null判定 (常にfalse)
|
||||
* - `toString()` - 文字列変換 ("null")
|
||||
* - `equals(other)` - 等価比較 (他のnullとのみtrue)
|
||||
*
|
||||
*
|
||||
* ## 🛡️ 静的メソッド (null安全機能)
|
||||
* - `NullBox.checkNull(value)` - 値のnull判定
|
||||
* - `NullBox.checkNotNull(value)` - 値の非null判定
|
||||
* - `NullBox.getOrDefault(value, default)` - null時デフォルト値取得
|
||||
*
|
||||
*
|
||||
* ## 💡 使用例
|
||||
* ```nyash
|
||||
* local user, name, default_name
|
||||
*
|
||||
*
|
||||
* // null値の作成と判定
|
||||
* user = null
|
||||
* if (user == null) {
|
||||
* print("User is null")
|
||||
* }
|
||||
*
|
||||
*
|
||||
* // null安全な値取得
|
||||
* name = getUsername() // null の可能性
|
||||
* default_name = NullBox.getOrDefault(name, "Anonymous")
|
||||
* print("Hello, " + default_name)
|
||||
* ```
|
||||
*
|
||||
*
|
||||
* ## 🎮 実用例 - null安全プログラミング
|
||||
* ```nyash
|
||||
* static box UserManager {
|
||||
@ -62,12 +62,12 @@
|
||||
* }
|
||||
* }
|
||||
* ```
|
||||
*
|
||||
*
|
||||
* ## 🔍 デバッグ活用
|
||||
* ```nyash
|
||||
* local data, result
|
||||
* data = fetchDataFromAPI() // null になる可能性
|
||||
*
|
||||
*
|
||||
* // null チェック付きデバッグ
|
||||
* if (NullBox.checkNull(data)) {
|
||||
* print("Warning: API returned null data")
|
||||
@ -76,7 +76,7 @@
|
||||
* result = data.process()
|
||||
* }
|
||||
* ```
|
||||
*
|
||||
*
|
||||
* ## ⚠️ 重要な特徴
|
||||
* - `null == null` は常にtrue
|
||||
* - `null.toString()` は "null"
|
||||
@ -84,9 +84,9 @@
|
||||
* - メソッド呼び出し時のnullチェックでNullPointerException防止
|
||||
*/
|
||||
|
||||
use crate::box_trait::{NyashBox, StringBox, BoolBox, BoxCore, BoxBase};
|
||||
use std::fmt::{Debug, Display};
|
||||
use crate::box_trait::{BoolBox, BoxBase, BoxCore, NyashBox, StringBox};
|
||||
use std::any::Any;
|
||||
use std::fmt::{Debug, Display};
|
||||
|
||||
/// null値を表現するBox
|
||||
#[derive(Debug, Clone)]
|
||||
@ -96,36 +96,33 @@ pub struct NullBox {
|
||||
|
||||
impl NullBox {
|
||||
pub fn new() -> Self {
|
||||
Self {
|
||||
base: BoxBase::new()
|
||||
Self {
|
||||
base: BoxBase::new(),
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/// null値かどうかを判定
|
||||
pub fn is_null(&self) -> bool {
|
||||
true // NullBoxは常にnull
|
||||
true // NullBoxは常にnull
|
||||
}
|
||||
|
||||
|
||||
/// 値がnullでないかを判定
|
||||
pub fn is_not_null(&self) -> bool {
|
||||
false // NullBoxは常にnull
|
||||
false // NullBoxは常にnull
|
||||
}
|
||||
|
||||
|
||||
/// 他の値がnullかどうかを判定
|
||||
pub fn check_null(value: &dyn NyashBox) -> bool {
|
||||
value.as_any().downcast_ref::<NullBox>().is_some()
|
||||
}
|
||||
|
||||
|
||||
/// 他の値がnullでないかを判定
|
||||
pub fn check_not_null(value: &dyn NyashBox) -> bool {
|
||||
!Self::check_null(value)
|
||||
}
|
||||
|
||||
|
||||
/// null安全な値の取得
|
||||
pub fn get_or_default(
|
||||
value: &dyn NyashBox,
|
||||
default: Box<dyn NyashBox>
|
||||
) -> Box<dyn NyashBox> {
|
||||
pub fn get_or_default(value: &dyn NyashBox, default: Box<dyn NyashBox>) -> Box<dyn NyashBox> {
|
||||
if Self::check_null(value) {
|
||||
default
|
||||
} else {
|
||||
@ -138,19 +135,19 @@ impl BoxCore for NullBox {
|
||||
fn box_id(&self) -> u64 {
|
||||
self.base.id
|
||||
}
|
||||
|
||||
|
||||
fn parent_type_id(&self) -> Option<std::any::TypeId> {
|
||||
self.base.parent_type_id
|
||||
}
|
||||
|
||||
|
||||
fn fmt_box(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
||||
write!(f, "null")
|
||||
}
|
||||
|
||||
|
||||
fn as_any(&self) -> &dyn Any {
|
||||
self
|
||||
}
|
||||
|
||||
|
||||
fn as_any_mut(&mut self) -> &mut dyn Any {
|
||||
self
|
||||
}
|
||||
@ -160,25 +157,24 @@ impl NyashBox for NullBox {
|
||||
fn type_name(&self) -> &'static str {
|
||||
"NullBox"
|
||||
}
|
||||
|
||||
|
||||
fn to_string_box(&self) -> StringBox {
|
||||
StringBox::new("null")
|
||||
}
|
||||
|
||||
|
||||
fn clone_box(&self) -> Box<dyn NyashBox> {
|
||||
Box::new(self.clone())
|
||||
}
|
||||
|
||||
|
||||
/// 仮実装: clone_boxと同じ(後で修正)
|
||||
fn share_box(&self) -> Box<dyn NyashBox> {
|
||||
self.clone_box()
|
||||
}
|
||||
|
||||
|
||||
fn equals(&self, other: &dyn NyashBox) -> BoolBox {
|
||||
// すべてのNullBoxは等しい
|
||||
BoolBox::new(other.as_any().downcast_ref::<NullBox>().is_some())
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
impl Display for NullBox {
|
||||
@ -196,7 +192,7 @@ pub fn null() -> Box<dyn NyashBox> {
|
||||
mod tests {
|
||||
use super::*;
|
||||
use crate::box_trait::IntegerBox;
|
||||
|
||||
|
||||
#[test]
|
||||
fn test_null_creation() {
|
||||
let null_box = NullBox::new();
|
||||
@ -204,41 +200,41 @@ mod tests {
|
||||
assert!(!null_box.is_not_null());
|
||||
assert_eq!(null_box.to_string_box().value, "null");
|
||||
}
|
||||
|
||||
|
||||
#[test]
|
||||
fn test_null_check() {
|
||||
let null_box = null();
|
||||
let int_box = Box::new(IntegerBox::new(42));
|
||||
|
||||
|
||||
assert!(NullBox::check_null(null_box.as_ref()));
|
||||
assert!(!NullBox::check_null(int_box.as_ref()));
|
||||
|
||||
|
||||
assert!(!NullBox::check_not_null(null_box.as_ref()));
|
||||
assert!(NullBox::check_not_null(int_box.as_ref()));
|
||||
}
|
||||
|
||||
|
||||
#[test]
|
||||
fn test_null_equality() {
|
||||
let null1 = NullBox::new();
|
||||
let null2 = NullBox::new();
|
||||
let int_box = IntegerBox::new(42);
|
||||
|
||||
|
||||
assert!(null1.equals(&null2).value);
|
||||
assert!(!null1.equals(&int_box).value);
|
||||
}
|
||||
|
||||
|
||||
#[test]
|
||||
fn test_get_or_default() {
|
||||
let null_box = null();
|
||||
let default_value = Box::new(IntegerBox::new(100));
|
||||
let actual_value = Box::new(IntegerBox::new(42));
|
||||
|
||||
|
||||
// nullの場合はデフォルト値を返す
|
||||
let result1 = NullBox::get_or_default(null_box.as_ref(), default_value.clone());
|
||||
assert_eq!(result1.to_string_box().value, "100");
|
||||
|
||||
|
||||
// null以外の場合は元の値を返す
|
||||
let result2 = NullBox::get_or_default(actual_value.as_ref(), default_value);
|
||||
assert_eq!(result2.to_string_box().value, "42");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user