Conversation

What's a module? I've read more than once that “language X doesn't have real modules”. Is there an academic definition? If not can you point me to the discussion? I remember I read somewhere that “only SML has real modules” 🤔
7
19
Harper and Peirce define a module informally as, “A collection of components, which may include procedure of function definitions, variable declarations, type definitions, an initialisation code – specifics will vary from one language to another.”
1
4
More information on their perspective can be found in “Design Concepts for ML-style Module Systems”, a chapter in Advanced Topics in Types and Programming Languages.
1
3
“only SML has real modules” – I think this is a pretty extreme and lazy position to take. SML has a pretty expressive module system but yeah, there's a wide diversity in different module systems, and different definitions.
1
5
One interesting case of modules in the ML sense is Scala, for instance, which merges them with the object system, while retaining lots of stuff from ML, like module functions and associated types etc.
1
4
Also might be worth looking at Modula-2 as well! Ecmascript has interesting modules too, based on JS objects? Maybe algebraic specification languages too – I think ML drew inspiration from those?
1
4
Anyway, not sure if this helps at all, I probably didn't answer your question very well. I think 's answer was better and more concise! I'm also very much not an expert, just bumbling my way through learning stuff… 🥴
1
4
Replying to
Definitely helpful! It looks like there's no formal definition or consensus, so the “language X doesn't have real modules” phrase is wrong. Real modules according to who? The last time I read it was in the Lua book, by the Lua author. I think Lua modules are perfectly fine
1
1
Yeah I think it's a bit like ‘real objects’ – there's a bunch of different perspectives and a levels of precision, and I think lots of them have value. Also probably worth chasing down some of the historical work on them, to see how the usage of the term evolved over time.
1
1
Show replies