Hiccdown Development Notes

Discussion started by Dennis Hackethal

  Log in or sign up to participate in this discussion.
With an account, you can revise, criticize, and comment on ideas, and submit new ideas.

Notes about developing the Ruby gem Hiccdown.


Discussions can branch out indefinitely. Zoom out for the bird’s-eye view.

Hiccdown methods should live in Rails helpers as instance methods.

#302 · · Dennis HackethalOP revised 8 months ago · 2nd of 2 versions · Criticized1 criticim(s)

That isn’t a good idea because Hiccdown methods often share the same conventional names (index, show, etc), which can and does lead to conflict.

#301 · · Dennis HackethalOP, 8 months ago · Criticism of #302
#301 · expand
#302 · expand

Hiccdown methods should live in Rails helpers as class methods. That way, the problem described in #302 is solved – methods can be referenced unambiguously:

ProductsHelper.index
StoresHelper.index
#303 · · Dennis HackethalOP, 8 months ago · Criticized2 criticim(s)

Does that mean they wouldn’t have access to the view_context? If so, calling helper methods from inside these class methods wouldn’t be possible.

#305 · · Dennis HackethalOP revised 8 months ago · 2nd of 2 versions · Criticism of #303Criticized1 criticim(s)

If so, there might be a way to bind them to the view_context. Or I could definitely pass the view_context explicitly as the first parameter:

So instead of

@helper_module.instance_method(@action_name).bind_call(view_context)

I would do

@helper_module.send(@action_name, view_context)

And the parameter list of each Hiccdown method would start accordingly:

module ProductsHelper
  def self.index vc #, …
    vc.some_helper_method
  end

  def some_helper_method
    # …
  end
end
#310 · · Dennis HackethalOP revised 8 months ago · 3rd of 3 versions · Criticism of #305
#310 · expand
#305 · expand

That would be mixing class methods an instance methods in Rails helper modules, which typically only contain instance methods. Not idiomatic Rails usage.

#312 · · Dennis HackethalOP, 8 months ago · Criticism of #303
#312 · expand

#327 applies here, too: no access to instance variables inside helper class methods.

#332 · · Dennis HackethalOP, 8 months ago · Criticism of #303
#332 · expand
#303 · expand

Hiccdown methods should live in their own, separate modules. How about they are called ‘displays’?

module ProductsDisplay
  def self.index vc, # …
    vc.some_helper_method
  end
end

A benefit of this approach is that, when people start a new Rails app, they may end up putting whatever they’d otherwise put in a helper in a display, since displays have the benefit of having unambiguously resolvable method names.

#325 · clear highlight · Dennis HackethalOP revised 8 months ago · 3rd of 4 versions · Criticized2 criticim(s)

Then how would you call index from a helper method?

#317 · · Dennis HackethalOP revised 8 months ago · 2nd of 2 versions · Criticism of #325Criticized1 criticim(s)

I don’t think that’s something people would do a lot, but they still easily could: ProductsRenderer.index(self)

#315 · · Dennis HackethalOP, 8 months ago · Criticism of #317

Test this!

#321 · · Dennis HackethalOP, 8 months ago · Criticism of #315Criticized1 criticim(s)

Tested, it works. self does indeed point to the view_context in the helper. Verified by printing object_ids.

#323 · · Dennis HackethalOP revised 8 months ago · 2nd of 2 versions · Criticism of #321
#323 · expand
#321 · expand

Not as of #330, they couldn’t.

#331 · · Dennis HackethalOP, 8 months ago · Criticism of #315Criticized1 criticim(s)

It doesn’t really matter. This would be like calling a controller action from a helper method. Not something people do.

#341 · · Dennis HackethalOP, 8 months ago · Criticism of #331
#341 · expand
#331 · expand
#315 · expand
#317 · expand

I’m trying this now. Having to prepend every invocation of a helper method with vc. is getting really old really fast.

#326 · · Dennis HackethalOP, 8 months ago · Criticism of #325
#326 · expand

Instance variables are not available inside the methods.

#327 · · Dennis HackethalOP, 8 months ago · Criticism of #325

They are: vc.instance_variable_get(:@foo)

#328 · · Dennis HackethalOP, 8 months ago · Criticism of #327Criticized1 criticim(s)

That’s way too verbose.

#329 · · Dennis HackethalOP, 8 months ago · Criticism of #328
#329 · expand
#328 · expand
#327 · expand
#325 · expand

Having explored three different ideas, I believe #302 – having regular helper methods to render Hiccdown structures – is the best.

The idea is not without its flaws, but having to qualify a method name by, say, calling it idea_form instead of form is still better than manually having to pass the view context around all the time and not being able to trivially access instance variables.

So I’ll stick with #302 for now, which is the status quo already.

#333 · · Dennis HackethalOP, 8 months ago

I think the thing I’m really fighting here is Rails being object-oriented. Which I can’t do anything about.

Not sure the Rails team realizes how much OOP reduces the extensibility of Rails.

#334 · · Dennis HackethalOP, 8 months ago · 1st of 2 versions · Criticism of #333Criticized1 criticim(s)

Superseded by #335. This comment was generated automatically.

#336 · · Dennis HackethalOP, 8 months ago · Criticism of #334
#336 · expand
#334 · expand
#333 · expand

Could the errors around layouts be related to this?

#859 · · Dennis HackethalOP, 5 months ago · Criticism
#859 · expand