Class: RBS::Types::Function

Inherits:
Object
  • Object
show all
Defined in:
lib/rbs/types.rb

Defined Under Namespace

Classes: Param

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(required_positionals:, optional_positionals:, rest_positionals:, trailing_positionals:, required_keywords:, optional_keywords:, rest_keywords:, return_type:) ⇒ Function

Returns a new instance of Function.



934
935
936
937
938
939
940
941
942
943
# File 'lib/rbs/types.rb', line 934

def initialize(required_positionals:, optional_positionals:, rest_positionals:, trailing_positionals:, required_keywords:, optional_keywords:, rest_keywords:, return_type:)
  @return_type = return_type
  @required_positionals = required_positionals
  @optional_positionals = optional_positionals
  @rest_positionals = rest_positionals
  @trailing_positionals = trailing_positionals
  @required_keywords = required_keywords
  @optional_keywords = optional_keywords
  @rest_keywords = rest_keywords
end

Instance Attribute Details

#optional_keywordsObject (readonly)

Returns the value of attribute optional_keywords.



930
931
932
# File 'lib/rbs/types.rb', line 930

def optional_keywords
  @optional_keywords
end

#optional_positionalsObject (readonly)

Returns the value of attribute optional_positionals.



926
927
928
# File 'lib/rbs/types.rb', line 926

def optional_positionals
  @optional_positionals
end

#required_keywordsObject (readonly)

Returns the value of attribute required_keywords.



929
930
931
# File 'lib/rbs/types.rb', line 929

def required_keywords
  @required_keywords
end

#required_positionalsObject (readonly)

Returns the value of attribute required_positionals.



925
926
927
# File 'lib/rbs/types.rb', line 925

def required_positionals
  @required_positionals
end

#rest_keywordsObject (readonly)

Returns the value of attribute rest_keywords.



931
932
933
# File 'lib/rbs/types.rb', line 931

def rest_keywords
  @rest_keywords
end

#rest_positionalsObject (readonly)

Returns the value of attribute rest_positionals.



927
928
929
# File 'lib/rbs/types.rb', line 927

def rest_positionals
  @rest_positionals
end

#return_typeObject (readonly)

Returns the value of attribute return_type.



932
933
934
# File 'lib/rbs/types.rb', line 932

def return_type
  @return_type
end

#trailing_positionalsObject (readonly)

Returns the value of attribute trailing_positionals.



928
929
930
# File 'lib/rbs/types.rb', line 928

def trailing_positionals
  @trailing_positionals
end

Class Method Details

.empty(return_type) ⇒ Object



1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
# File 'lib/rbs/types.rb', line 1084

def self.empty(return_type)
  Function.new(
    required_positionals: [],
    optional_positionals: [],
    rest_positionals: nil,
    trailing_positionals: [],
    required_keywords: {},
    optional_keywords: {},
    rest_keywords: nil,
    return_type: return_type
  )
end

Instance Method Details

#==(other) ⇒ Object Also known as: eql?



945
946
947
948
949
950
951
952
953
954
955
# File 'lib/rbs/types.rb', line 945

def ==(other)
  other.is_a?(Function) &&
    other.required_positionals == required_positionals &&
    other.optional_positionals == optional_positionals &&
    other.rest_positionals == rest_positionals &&
    other.trailing_positionals == trailing_positionals &&
    other.required_keywords == required_keywords &&
    other.optional_keywords == optional_keywords &&
    other.rest_keywords == rest_keywords &&
    other.return_type == return_type
end

#amap(array, &block) ⇒ Object



1016
1017
1018
1019
1020
1021
1022
# File 'lib/rbs/types.rb', line 1016

def amap(array, &block)
  if array.empty?
    _ = array
  else
    array.map(&block)
  end
end

#drop_headObject



1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
# File 'lib/rbs/types.rb', line 1153

def drop_head
  case
  when !required_positionals.empty?
    [
      required_positionals[0],
      update(required_positionals: required_positionals.drop(1))
    ]
  when !optional_positionals.empty?
    [
      optional_positionals[0],
      update(optional_positionals: optional_positionals.drop(1))
    ]
  else
    raise "Cannot #drop_head"
  end
end

#drop_tailObject



1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
# File 'lib/rbs/types.rb', line 1170

def drop_tail
  case
  when !trailing_positionals.empty?
    last = trailing_positionals.last or raise
    [
      last,
      update(trailing_positionals: trailing_positionals.take(trailing_positionals.size - 1))
    ]
  else
    raise "Cannot #drop_tail"
  end
end

#each_param(&block) ⇒ Object



1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
# File 'lib/rbs/types.rb', line 1053

def each_param(&block)
  if block
    required_positionals.each(&block)
    optional_positionals.each(&block)
    rest_positionals&.yield_self(&block)
    trailing_positionals.each(&block)
    required_keywords.each_value(&block)
    optional_keywords.each_value(&block)
    rest_keywords&.yield_self(&block)
  else
    enum_for :each_param
  end
end

#each_typeObject



1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
# File 'lib/rbs/types.rb', line 1038

def each_type
  if block_given?
    required_positionals.each {|param| yield param.type }
    optional_positionals.each {|param| yield param.type }
    rest_positionals&.yield_self {|param| yield param.type }
    trailing_positionals.each {|param| yield param.type }
    required_keywords.each_value {|param| yield param.type }
    optional_keywords.each_value {|param| yield param.type }
    rest_keywords&.yield_self {|param| yield param.type }
    yield(return_type)
  else
    enum_for :each_type
  end
end

#empty?Boolean

Returns:

  • (Boolean)


1124
1125
1126
1127
1128
1129
1130
1131
1132
# File 'lib/rbs/types.rb', line 1124

def empty?
  required_positionals.empty? &&
    optional_positionals.empty? &&
    !rest_positionals &&
    trailing_positionals.empty? &&
    required_keywords.empty? &&
    optional_keywords.empty? &&
    !rest_keywords
end

#free_variables(set = Set.new) ⇒ Object



971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
# File 'lib/rbs/types.rb', line 971

def free_variables(set = Set.new)
  set.tap do
    required_positionals.each do |param|
      param.type.free_variables(set)
    end
    optional_positionals.each do |param|
      param.type.free_variables(set)
    end
    rest_positionals&.yield_self do |param|
      param.type.free_variables(set)
    end
    trailing_positionals.each do |param|
      param.type.free_variables(set)
    end
    required_keywords.each_value do |param|
      param.type.free_variables(set)
    end
    optional_keywords.each_value do |param|
      param.type.free_variables(set)
    end
    rest_keywords&.yield_self do |param|
      param.type.free_variables(set)
    end

    return_type.free_variables(set)
  end
end

#has_classish_type?Boolean

Returns:

  • (Boolean)


1195
1196
1197
# File 'lib/rbs/types.rb', line 1195

def has_classish_type?
  each_type.any? {|type| type.has_classish_type? }
end

#has_keyword?Boolean

Returns:

  • (Boolean)


1183
1184
1185
1186
1187
1188
1189
# File 'lib/rbs/types.rb', line 1183

def has_keyword?
  if !required_keywords.empty? || !optional_keywords.empty? || rest_keywords
    true
  else
    false
  end
end

#has_self_type?Boolean

Returns:

  • (Boolean)


1191
1192
1193
# File 'lib/rbs/types.rb', line 1191

def has_self_type?
  each_type.any? {|type| type.has_self_type? }
end

#hashObject



959
960
961
962
963
964
965
966
967
968
969
# File 'lib/rbs/types.rb', line 959

def hash
  self.class.hash ^
    required_positionals.hash ^
    optional_positionals.hash ^
    rest_positionals.hash ^
    trailing_positionals.hash ^
    required_keywords.hash ^
    optional_keywords.hash ^
    rest_keywords.hash ^
    return_type.hash
end

#hmapv(hash, &block) ⇒ Object



1024
1025
1026
1027
1028
1029
1030
# File 'lib/rbs/types.rb', line 1024

def hmapv(hash, &block)
  if hash.empty?
    _ = hash
  else
    hash.transform_values(&block)
  end
end

#map_type(&block) ⇒ Object



999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
# File 'lib/rbs/types.rb', line 999

def map_type(&block)
  if block
    Function.new(
      required_positionals: amap(required_positionals) {|param| param.map_type(&block) },
      optional_positionals: amap(optional_positionals) {|param| param.map_type(&block) },
      rest_positionals: rest_positionals&.yield_self {|param| param.map_type(&block) },
      trailing_positionals: amap(trailing_positionals) {|param| param.map_type(&block) },
      required_keywords: hmapv(required_keywords) {|param| param.map_type(&block) },
      optional_keywords: hmapv(optional_keywords) {|param| param.map_type(&block) },
      rest_keywords: rest_keywords&.yield_self {|param| param.map_type(&block) },
      return_type: yield(return_type)
    )
  else
    enum_for :map_type
  end
end

#map_type_name(&block) ⇒ Object



1032
1033
1034
1035
1036
# File 'lib/rbs/types.rb', line 1032

def map_type_name(&block)
  map_type do |type|
    type.map_type_name(&block)
  end
end

#param_to_sObject



1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
# File 'lib/rbs/types.rb', line 1134

def param_to_s
  # @type var params: Array[String]
  params = []

  params.push(*required_positionals.map(&:to_s))
  params.push(*optional_positionals.map {|p| "?#{p}"})
  params.push("*#{rest_positionals}") if rest_positionals
  params.push(*trailing_positionals.map(&:to_s))
  params.push(*required_keywords.map {|name, param| "#{name}: #{param}" })
  params.push(*optional_keywords.map {|name, param| "?#{name}: #{param}" })
  params.push("**#{rest_keywords}") if rest_keywords

  params.join(", ")
end

#return_to_sObject



1149
1150
1151
# File 'lib/rbs/types.rb', line 1149

def return_to_s
  return_type.to_s(1)
end

#sub(s) ⇒ Object



1080
1081
1082
# File 'lib/rbs/types.rb', line 1080

def sub(s)
  map_type {|ty| ty.sub(s) }
end

#to_json(state = _ = nil) ⇒ Object



1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
# File 'lib/rbs/types.rb', line 1067

def to_json(state = _ = nil)
  {
    required_positionals: required_positionals,
    optional_positionals: optional_positionals,
    rest_positionals: rest_positionals,
    trailing_positionals: trailing_positionals,
    required_keywords: required_keywords,
    optional_keywords: optional_keywords,
    rest_keywords: rest_keywords,
    return_type: return_type
  }.to_json(state)
end

#update(required_positionals: self.required_positionals, optional_positionals: self.optional_positionals, rest_positionals: self.rest_positionals, trailing_positionals: self.trailing_positionals, required_keywords: self.required_keywords, optional_keywords: self.optional_keywords, rest_keywords: self.rest_keywords, return_type: self.return_type) ⇒ Object



1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
# File 'lib/rbs/types.rb', line 1110

def update(required_positionals: self.required_positionals, optional_positionals: self.optional_positionals, rest_positionals: self.rest_positionals, trailing_positionals: self.trailing_positionals,
           required_keywords: self.required_keywords, optional_keywords: self.optional_keywords, rest_keywords: self.rest_keywords, return_type: self.return_type)
  Function.new(
    required_positionals: required_positionals,
    optional_positionals: optional_positionals,
    rest_positionals: rest_positionals,
    trailing_positionals: trailing_positionals,
    required_keywords: required_keywords,
    optional_keywords: optional_keywords,
    rest_keywords: rest_keywords,
    return_type: return_type
  )
end

#with_nonreturn_void?Boolean

Returns:

  • (Boolean)


1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
# File 'lib/rbs/types.rb', line 1199

def with_nonreturn_void?
  if each_param.any? {|param| param.type.with_nonreturn_void? }
    true
  else
    if return_type.is_a?(Bases::Void)
      false
    else
      return_type.with_nonreturn_void?
    end
  end
end

#with_return_type(type) ⇒ Object



1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
# File 'lib/rbs/types.rb', line 1097

def with_return_type(type)
  Function.new(
    required_positionals: required_positionals,
    optional_positionals: optional_positionals,
    rest_positionals: rest_positionals,
    trailing_positionals: trailing_positionals,
    required_keywords: required_keywords,
    optional_keywords: optional_keywords,
    rest_keywords: rest_keywords,
    return_type: type
  )
end