class Tapioca::Dsl::Compilers::ActionMailer

~~~
end
def self.notify_customer(customer_id); end
sig { params(customer_id: T.untyped).returns(::ActionMailer::MessageDelivery) }
class NotifierMailer
# typed: true
# notifier_mailer.rbi
~~~rbi
this compiler will produce the RBI file ‘notifier_mailer.rbi` with the following content:
~~~
end
end
# …
def notify_customer(customer_id)
class NotifierMailer < ActionMailer::Base
~~~rb
For example, with the following `ActionMailer` subclass:<br><br>(api.rubyonrails.org/classes/ActionMailer/Base.html).
`Tapioca::Dsl::Compilers::ActionMailer` generates RBI files for subclasses of

def action_methods_for_constant

def action_methods_for_constant
  constant.action_methods.to_a
end

def decorate

def decorate
  root.create_path(constant) do |mailer|
    action_methods_for_constant.each do |mailer_method|
      method_def = constant.instance_method(mailer_method)
      parameters = compile_method_parameters_to_rbi(method_def)
      mailer.create_method(
        mailer_method,
        parameters: parameters,
        return_type: "::ActionMailer::MessageDelivery",
        class_method: true,
      )
    end
  end
end

def gather_constants

def gather_constants
  descendants_of(::ActionMailer::Base).reject(&:abstract?)
end