Class: XArray

Inherits:
ValueAdd show all
Defined in:
lib/primitive_wrapper.rb

Overview

need to figure out how left and right things work …

OK this is cool,  things on the right if more than one go in one array
... or a non-array if just one item

Constant Summary collapse

LAM_ISORT =
lambda {|a,b| a.inspect <=> b.inspect }
LAM_SSORT =
lambda {|a,b| a.to_s <=> b.to_s }

Instance Method Summary collapse

Methods inherited from ValueAdd

bestow_methods, capture_base_methods

Methods inherited from Value

#!=, #==, #ensure_valid, #freeze, freeze_raise?, ignore_on_freeze, #inspect, #prim_value, raise_on_freeze, #replace, #to_s, #to_wrapper, #type, #type_of?, #unwrap, #val, #val=, #wrapped?, #~

Constructor Details

#initialize(obj = []) ⇒ XArray

Returns a new instance of XArray.



982
983
984
985
986
# File 'lib/primitive_wrapper.rb', line 982

def initialize(obj=[])
  obj = obj.prim_value
  ensure_valid(obj)
  @value = obj
end

Instance Method Details

#[](*list) ⇒ Object



1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
# File 'lib/primitive_wrapper.rb', line 1005

def [](*list)
  list = PrimitiveWrapper::get_list(list,size)
  if list.empty?
    return nil
  elsif list.count==1
    if list.first == :all
      return @value
    elsif list.first.type_of? Range  # get_list may pick this appart
      rtn = []
      list.first.to_wrapper.re_range(size).each do |idx|
        rtn.push @value[idx]
      end
      return rtn  
    else
      return @value[list.first]
    end
  end
  rtn = []
  # for now keep this here until you can justify that it is not needed
  list.each do |ii|   # I don't need to do this do I ???  get_list should untangle things
    if ii.type_of? Range
      ii.to_wrapper.re_range(size).each do |idx|
        rtn.push @value[idx]
      end
    elsif ii.type_of? Array
      ii.each do |idx|
        rtn.push @value[idx]
      end
    else
      rtn.push @value[ii]
    end
  end
  return rtn
end

#[]=(*list) ⇒ Object



1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
# File 'lib/primitive_wrapper.rb', line 1039

def []=(*list)
  data = list.pop
  list = PrimitiveWrapper::get_list(list,size)
  return nil if list.empty?
  if list.count==1
    if list.first.respond_to? :each
      list = list.first
      if list.type_of? Range
        list = list.to_xr.re_range(size)
      end
    end
  end
  if list.count==1
    if list.first == :all
      PrimitiveWrapper.copy(@value, data, :all) 
    end
    idxs = list.first
    if (idxs.respond_to? :each)
      if idxs.type_of? Range
        idxs = idxs.to_xr.re_range(size)
      end        
      idxs.each do |idx|
        @value[idx] = data
      end
    else
      @value[idxs] = data
    end 
  else
    if data.type_of? Array
      data = PrimitiveWrapper::get_list(data,size)
    end
    PrimitiveWrapper.copy(@value, data, list)
  end
end

#delete_at(*index_list) ⇒ Object



1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
# File 'lib/primitive_wrapper.rb', line 1073

def delete_at(*index_list)
  return nil if index_list.empty?
  rtn = []
  if (index_list.count==1)
    if index_list.first==:all
      rtn = @value.dup
      @value.empty!
      return rtn
    else
      ii = index_list.first
      rtn = self[ii]
      if ii.type_of? Range
        ii = ii.to_xr
        ii.re_range!(size)
        ii.reorder!
        ii.reverse_each do |idx|
          @value.delete_at(idx)
        end
        return rtn
      end
    end
  end
  rtn = self[*index_list]
  list = PrimitiveWrapper::get_list(index_list,size)
  list = list & list  # remove duplicates
  list.sort.reverse.each do |idx|
    if idx.type_of? Range
      t_idx = idx.reorder
    else
      t_idx = idx
    end
    @value.delete_at(t_idx)
  end
  return rtn
end

#include?(*list) ⇒ Boolean

replace with list of stuff

Returns:

  • (Boolean)


1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
# File 'lib/primitive_wrapper.rb', line 1108

def include?(*list)  # replace with list of stuff
  if list.count==1
    if list.first.respond_to? :each
      list = list.first
    end
  end
  list.each do |item|
    return false unless @value.include? item
  end
  true
end

#include_any?(*list) ⇒ Boolean

replace with list of stuff

Returns:

  • (Boolean)


1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
# File 'lib/primitive_wrapper.rb', line 1119

def include_any?(*list)  # replace with list of stuff
  if list.count==1
    if list.first.respond_to? :each
      list = list.first
    end
  end
  list.each do |item|
    return true if @value.include? item
  end
  false
end

#isortObject



993
994
995
# File 'lib/primitive_wrapper.rb', line 993

def isort 
  @value.sort &LAM_ISORT
end

#isort!Object



996
997
998
# File 'lib/primitive_wrapper.rb', line 996

def isort!
  @value.sort! &LAM_ISORT
end

#ssortObject



999
1000
1001
# File 'lib/primitive_wrapper.rb', line 999

def ssort
  @value.sort &LAM_SSORT
end

#ssort!Object



1002
1003
1004
# File 'lib/primitive_wrapper.rb', line 1002

def ssort!
  @value.sort! &LAM_SSORT
end

#valid_type(prm) ⇒ Object



988
989
990
991
992
# File 'lib/primitive_wrapper.rb', line 988

def valid_type(prm)
  return true if prm.kind_of? Array
  return true if prm.kind_of? XArray
  false
end