Class: Dhall::LetBlock

Inherits:
Expression show all
Defined in:
lib/dhall/ast.rb,
lib/dhall/binary.rb,
lib/dhall/normalize.rb

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Expression

#&, #*, #+, #<<, #as_dhall, #cache_key, #call, #concat, #deep_merge, #deep_merge_type, #dhall_eq, #digest, #fetch, #fusion, #merge, #resolve, #slice, #substitute, #to_cbor, #to_proc, #|

Class Method Details

.decode(*parts) ⇒ Object



206
207
208
209
210
211
212
213
214
215
216
217
# File 'lib/dhall/binary.rb', line 206

def self.decode(*parts)
	body = Dhall.decode(parts.pop)
	lets = parts.each_slice(3).map do |(var, type, assign)|
		Let.new(
			var:    var,
			assign: Dhall.decode(assign),
			type:   type.nil? ? nil : Dhall.decode(type)
		)
	end

	self.for(lets: lets, body: body)
end

.for(lets:, body:) ⇒ Object



1525
1526
1527
1528
1529
1530
1531
# File 'lib/dhall/ast.rb', line 1525

def self.for(lets:, body:)
	if lets.length == 1
		LetIn.new(let: lets.first, body: body)
	else
		new(lets: lets, body: body)
	end
end

Instance Method Details

#as_jsonObject



1544
1545
1546
# File 'lib/dhall/ast.rb', line 1544

def as_json
	[25, *lets.flat_map(&:as_json), body.as_json]
end

#desugarObject



1540
1541
1542
# File 'lib/dhall/ast.rb', line 1540

def desugar
	unflatten(&:desugar)
end

#normalizeObject



406
407
408
# File 'lib/dhall/normalize.rb', line 406

def normalize
	desugar.normalize
end

#shift(amount, name, min_index) ⇒ Object



410
411
412
# File 'lib/dhall/normalize.rb', line 410

def shift(amount, name, min_index)
	unflatten.shift(amount, name, min_index)
end

#unflattenObject



1533
1534
1535
1536
1537
1538
# File 'lib/dhall/ast.rb', line 1533

def unflatten
	lets.reverse.reduce(body) do |inside, let|
		letin = LetIn.new(let: let, body: inside)
		block_given? ? (yield letin) : letin
	end
end