use dust_lang::*; #[test] fn empty_list() { let source = "[]"; assert_eq!( compile(source), Ok(Chunk::with_data( None, FunctionType { type_parameters: None, value_parameters: None, return_type: Type::List(Box::new(Type::Any)), }, vec![ (Instruction::load_list(0, 0), Span(0, 2)), (Instruction::r#return(true), Span(2, 2)), ], vec![], vec![] )), ); assert_eq!(run(source), Ok(Some(ConcreteValue::list([])))); } #[test] fn list() { let source = "[1, 2, 3]"; assert_eq!( compile(source), Ok(Chunk::with_data( None, FunctionType { type_parameters: None, value_parameters: None, return_type: Type::List(Box::new(Type::Integer)), }, vec![ (Instruction::load_constant(0, 0, false), Span(1, 2)), (Instruction::load_constant(1, 1, false), Span(4, 5)), (Instruction::load_constant(2, 2, false), Span(7, 8)), (Instruction::load_list(3, 0), Span(0, 9)), (Instruction::r#return(true), Span(9, 9)), ], vec![ ConcreteValue::Integer(1), ConcreteValue::Integer(2), ConcreteValue::Integer(3) ], vec![] )), ); assert_eq!( run(source), Ok(Some(ConcreteValue::list([ ConcreteValue::Integer(1), ConcreteValue::Integer(2), ConcreteValue::Integer(3) ]))) ); } #[test] fn list_with_complex_expression() { let source = "[1, 2 + 3 - 4 * 5]"; assert_eq!( compile(source), Ok(Chunk::with_data( None, FunctionType { type_parameters: None, value_parameters: None, return_type: Type::List(Box::new(Type::Integer)), }, vec![ (Instruction::load_constant(0, 0, false), Span(1, 2)), ( Instruction::add(1, Operand::Constant(1), Operand::Constant(2)), Span(6, 7) ), ( Instruction::multiply(2, Operand::Constant(3), Operand::Constant(4)), Span(14, 15) ), ( Instruction::subtract(3, Operand::Register(1), Operand::Register(2)), Span(10, 11) ), (Instruction::close(1, 3), Span(17, 18)), (Instruction::load_list(4, 0), Span(0, 18)), (Instruction::r#return(true), Span(18, 18)), ], vec![ ConcreteValue::Integer(1), ConcreteValue::Integer(2), ConcreteValue::Integer(3), ConcreteValue::Integer(4), ConcreteValue::Integer(5) ], vec![] )), ); assert_eq!( run(source), Ok(Some(ConcreteValue::list([ ConcreteValue::Integer(1), ConcreteValue::Integer(-15) ]))) ); } #[test] fn list_with_simple_expression() { let source = "[1, 2 + 3, 4]"; assert_eq!( compile(source), Ok(Chunk::with_data( None, FunctionType { type_parameters: None, value_parameters: None, return_type: Type::List(Box::new(Type::Integer)), }, vec![ (Instruction::load_constant(0, 0, false), Span(1, 2)), ( Instruction::add(1, Operand::Constant(1), Operand::Constant(2)), Span(6, 7) ), (Instruction::load_constant(2, 3, false), Span(11, 12)), (Instruction::load_list(3, 0), Span(0, 13)), (Instruction::r#return(true), Span(13, 13)), ], vec![ ConcreteValue::Integer(1), ConcreteValue::Integer(2), ConcreteValue::Integer(3), ConcreteValue::Integer(4), ], vec![] )), ); assert_eq!( run(source), Ok(Some(ConcreteValue::list([ ConcreteValue::Integer(1), ConcreteValue::Integer(5), ConcreteValue::Integer(4), ]))) ); }