Class: Foobara::TypeDeclarations::Handlers::RegisteredTypeDeclaration::StrictStringifiedDesugarizer
- Inherits:
-
Desugarizer
- Object
- Value::Processor
- Value::Transformer
- Desugarizer
- Foobara::TypeDeclarations::Handlers::RegisteredTypeDeclaration::StrictStringifiedDesugarizer
- Defined in:
- foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_stringified_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
- #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 |
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_stringified_desugarizer.rb', line 10 def applicable?(sugary_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 sugary_type_declaration.is_a?(::Hash) && TypeDeclarations.strict_stringified? !sugary_type_declaration.dig(:_desugarized, :type_absolutified) end |
#desugarize(sugary_type_declaration) ⇒ Object
18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'foobara-0.0.110/projects/type_declarations/src/handlers/registered_type_declaration/strict_stringified_desugarizer.rb', line 18 def desugarize(sugary_type_declaration) sugary_type_declaration = Util.symbolize_keys(sugary_type_declaration) type_symbol = sugary_type_declaration[:type] type = Foobara..(type_symbol, mode: Namespace::LookupMode::ABSOLUTE) type_symbol = type.full_type_symbol desugarized = sugary_type_declaration[:_desugarized] || {} desugarized[:type_absolutified] = true sugary_type_declaration.merge(_desugarized: desugarized, type: type_symbol) end |