Class: Foobara::TypeDeclarations::Handlers::RegisteredTypeDeclaration::ShortTypeNameDesugarizer
- Inherits:
-
Desugarizer
- Object
- Value::Processor
- Value::Transformer
- Desugarizer
- Foobara::TypeDeclarations::Handlers::RegisteredTypeDeclaration::ShortTypeNameDesugarizer
- Defined in:
- foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/short_type_name_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
- #applicable?(sugary_type_declaration) ⇒ Boolean
- #desugarize(sugary_type_declaration) ⇒ Object
-
#normalize_type(sugary_type_declaration) ⇒ Object
TODO: clean this up in a different desugarizer so we don’t have to think about it here.
- #priority ⇒ Object
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?(sugary_type_declaration) ⇒ Boolean
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/short_type_name_desugarizer.rb', line 10 def applicable?(sugary_type_declaration) return false if TypeDeclarations.strict_stringified? || TypeDeclarations.strict? sugary_type_declaration = sugary_type_declaration.dup return false unless sugary_type_declaration.is_a?(::Hash) sugary_type_declaration = normalize_type(sugary_type_declaration) if sugary_type_declaration.key?(:type) && !sugary_type_declaration.dig(:_desugarized, :type_absolutified) type_symbol = sugary_type_declaration[:type] (type_symbol.is_a?(::Symbol) || type_symbol.is_a?(::String)) && type_registered?(type_symbol) end end |
#desugarize(sugary_type_declaration) ⇒ Object
27 28 29 30 31 32 33 34 35 36 37 38 |
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/short_type_name_desugarizer.rb', line 27 def desugarize(sugary_type_declaration) sugary_type_declaration = normalize_type(sugary_type_declaration) type_symbol = sugary_type_declaration[:type] type = lookup_type!(type_symbol) desugarized = sugary_type_declaration[:_desugarized] || {} desugarized[:type_absolutified] = true # TODO: just use the symbol and nothing else?? # maybe confusing in languages with no distinction between symbol and string? sugary_type_declaration.merge(type: type.full_type_symbol, _desugarized: desugarized) end |
#normalize_type(sugary_type_declaration) ⇒ Object
TODO: clean this up in a different desugarizer so we don’t have to think about it here
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/short_type_name_desugarizer.rb', line 41 def normalize_type(sugary_type_declaration) if sugary_type_declaration.key?("type") && !sugary_type_declaration.key?(:type) if Util.all_symbolizable_keys?(sugary_type_declaration) sugary_type_declaration = Util.symbolize_keys(sugary_type_declaration) type_symbol = sugary_type_declaration[:type] if type_symbol.is_a?(::String) sugary_type_declaration[:type] = type_symbol.to_sym end end else sugary_type_declaration = sugary_type_declaration.dup end sugary_type_declaration end |