Class: Foobara::TypeDeclarations::Handlers::RegisteredTypeDeclaration::StrictDesugarizer

Inherits:
Desugarizer show all
Defined in:
foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_desugarizer.rb

Overview

type_symbol is basically just a flag that lets us know that type is fully qualified. rather hacky but other potential workarounds seemed gnarlier

Instance Attribute Summary

Attributes inherited from Value::Processor

#created_in_namespace, #declaration_data, #parent_declaration_data

Instance Method Summary collapse

Methods inherited from Desugarizer

foobara_manifest, requires_declaration_data?, #transform

Methods included from Concern

foobara_class_methods_module_for, foobara_concern?, included

Methods inherited from Value::Transformer

create, error_classes, foobara_manifest, #process_value, subclass, #transform

Methods inherited from Value::Processor

#always_applicable?, #attribute_name, #build_error, default_declaration_data, #dup_processor, error_class, error_classes, #error_context, #error_message, #error_path, foobara_manifest, #foobara_manifest, #initialize, #inspect, instance, #method_missing, #name, new_with_agnostic_args, #possible_errors, #process_outcome, #process_outcome!, #process_value, #process_value!, processor_name, requires_declaration_data?, requires_parent_declaration_data?, #respond_to_missing?, #runner, symbol

Methods included from IsManifestable

#foobara_domain, #foobara_manifest, #foobara_organization, #scoped_clear_caches

Constructor Details

This class inherits a constructor from Foobara::Value::Processor

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class Foobara::Value::Processor

Instance Method Details

#applicable?(strict_type_declaration) ⇒ Boolean

Returns:

  • (Boolean)


10
11
12
13
14
15
16
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_desugarizer.rb', line 10

def applicable?(strict_type_declaration)
  # TODO: we shouldn't have to check if this is a hash. This means some other desugarizer is unnecessarily
  # processing a type declaration as if it were sugary. Find and fix that to speed this up a tiny bit.
  return false unless strict_type_declaration.is_a?(::Hash) && TypeDeclarations.strict?

  !strict_type_declaration.dig(:_desugarized, :type_absolutified)
end

#desugarize(strict_type_declaration) ⇒ Object



18
19
20
21
22
23
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_desugarizer.rb', line 18

def desugarize(strict_type_declaration)
  strict_type_declaration = Util.symbolize_keys(strict_type_declaration)
  desugarized = strict_type_declaration[:_desugarized] || {}
  desugarized[:type_absolutified] = true
  strict_type_declaration.merge(_desugarized: desugarized)
end

#priorityObject



25
26
27
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_desugarizer.rb', line 25

def priority
  Priority::FIRST
end