@@ -217,6 +217,8 @@ macro_rules! convertable_type_def {
217
217
)
218
218
}
219
219
220
+ convertable_type_def ! ( Complex <f64 >) ;
221
+ convertable_type_def ! ( Complex <f32 >) ;
220
222
convertable_type_def ! ( u64 ) ;
221
223
convertable_type_def ! ( i64 ) ;
222
224
convertable_type_def ! ( f64 ) ;
@@ -355,29 +357,17 @@ macro_rules! arith_scalar_func {
355
357
type Output = Array ;
356
358
357
359
fn $fn_name( self , rhs: $rust_type) -> Array {
358
- let cnst_arr = constant( rhs, self . dims( ) ) ;
359
- unsafe {
360
- let mut temp: i64 = 0 ;
361
- let err_val = $ffi_fn( & mut temp as MutAfArray , self . get( ) as AfArray ,
362
- cnst_arr. get( ) as AfArray , 0 ) ;
363
- HANDLE_ERROR ( AfError :: from( err_val) ) ;
364
- Array :: from( temp)
365
- }
360
+ let temp = rhs. clone( ) ;
361
+ add( self , & temp, false )
366
362
}
367
363
}
368
364
369
365
impl $op_name<$rust_type> for Array {
370
366
type Output = Array ;
371
367
372
368
fn $fn_name( self , rhs: $rust_type) -> Array {
373
- let cnst_arr = constant( rhs, self . dims( ) ) ;
374
- unsafe {
375
- let mut temp: i64 = 0 ;
376
- let err_val = $ffi_fn( & mut temp as MutAfArray , self . get( ) as AfArray ,
377
- cnst_arr. get( ) as AfArray , 0 ) ;
378
- HANDLE_ERROR ( AfError :: from( err_val) ) ;
379
- Array :: from( temp)
380
- }
369
+ let temp = rhs. clone( ) ;
370
+ add( & self , & temp, false )
381
371
}
382
372
}
383
373
)
0 commit comments