On the Revival of Dynamic Languages

  • Oscar Nierstrasz
  • Alexandre Bergel
  • Marcus Denker
  • Stéphane Ducasse
  • Markus Gälli
  • Roel Wuyts
Part of the Lecture Notes in Computer Science book series (LNCS, volume 3628)

Abstract

The programming languages of today are stuck in a deep rut that has developed over the past 50 years. Although we are faced with new challenges posed by enormous advances in hardware and internet technology, we continue to struggle with old-fashioned languages based on rigid, static, closed-world file-based views of programming. We argue the need for a new class of dynamic languages that support a view of programming as constant evolution of living and open software models. Such languages would require features such as dynamic first-class namespaces, explicit meta-models, optional, pluggable type systems, and incremental compilation of running software systems.

Preview

Unable to display preview. Download preview PDF.

Unable to display preview. Download preview PDF.

References

  1. [AB87]
    Atkinson, M.P., Buneman, O.P.: Types and persistence in database programming languages. ACM Comput. Surv. 19(2), 105–170 (1987)CrossRefGoogle Scholar
  2. [ALSN01]
    Achermann, F., Lumpe, M., Schneider, J.-G., Nierstrasz, O.: Piccola — a small composition language. In: Bowman, H., Derrick, J. (eds.) Formal Methods for Distributed Processing — A Survey of Object-Oriented Approaches, pp. 403–426. Cambridge University Press, Cambridge (2001)Google Scholar
  3. [AN00]
    Achermann, F., Nierstrasz, O.: Explicit Namespaces. In: Gutknecht, J., Weck, W. (eds.) Modular Programming Languages, Zürich, Switzerland, September 2000. LNCS, vol. 1897, pp. 77–89. Springer, Heidelberg (2000)CrossRefGoogle Scholar
  4. [AN05]
    Achermann, F., Nierstrasz, O.: A calculus for reasoning about software components. Theoretical Computer Science 331(2-3), 367–396 (2005)MathSciNetCrossRefMATHGoogle Scholar
  5. [BDNW05]
    Bergel, A., Ducasse, S., Nierstrasz, O., Wuyts, R.: Classboxes: Controlling visibility of class extensions. Computer Languages, Systems and Structures (September 2005) (to appear)Google Scholar
  6. [BG93]
    Bracha, G., Griswold, D.: Strongtalk: Typechecking Smalltalk in a production environment. In: Proceedings OOPSLA 1993, ACM SIGPLAN Notices, October 1993, vol. 28, pp. 215–230 (1993)Google Scholar
  7. [BKKK87]
    Banerjee, J., Kim, W., Kim, H.-J., Korth, H.F.: Semantics and implementation of schema evolution in object-oriented databases. In: Proceedings ACM SIGMOD 1987, December 1987, vol. 16, pp. 311–322 (1987)Google Scholar
  8. [Bra04]
    Brach, G.: Pluggable type systems. In: OOPSLA Workshop on Revival of Dynamic Languages (October 2004)Google Scholar
  9. [BU04]
    Bracha, G., Ungar, D.: Mirrors: design principles for meta-level facilities of object-oriented programming languages. In: Proceedings of OOPSLA 2004, ACM SIGPLAN Notices, New York, NY, USA, pp. 331–344. ACM Press, New York (2004)Google Scholar
  10. [BZ87]
    Bloom, T., Zdonik, S.B.: Issues in the design of object-oriented database programming languages. In: Proceedings OOPSLA 1987, ACM SIGPLAN Notices, December 1987, vol. 22, pp. 441–451 (1987)Google Scholar
  11. [Chi95]
    Chiba, S.: A metaobject protocol for C++. In: Proceedings of OOPSLA 1995, October 1995. ACM SIGPLAN Notices, vol. 30, pp. 285–299 (1995)Google Scholar
  12. [Deu01]
    van Deursen, A.: Program comprehension risks and opportunities in extreme programming. In: Working Conference on Reverse Engineering, p. 176 (2001)Google Scholar
  13. [DMBK01]
    van Deursen, A., Moonen, L., van den Bergh, A., Kok, G.: Refactoring test code. In: Marchesi, M. (ed.) Proceedings of the 2nd International Conference on Extreme Programming and Flexible Processes (XP 2001), University of Cagliari, pp. 92–95 (2001)Google Scholar
  14. [Dyb03]
    Dybvig, K.: The Scheme Programming Language. MIT Press, Cambridge (2003)MATHGoogle Scholar
  15. [Edw04]
    Edwards, J.: Example centric programming. In: OOPSLA 2004: Companion to the 19th annual ACM SIGPLAN conference on Object-oriented programming systems, languages, and applications, p. 124. ACM Press, New York (2004)CrossRefGoogle Scholar
  16. [FJ89]
    Foote, B., Johnson, R.E.: Reflective facilities in Smalltalk-80. In: Proceedings OOPSLA 1989, ACM SIGPLAN Notices, October 1989, vol. 24, pp. 327–336 (1989)Google Scholar
  17. [Fos02]
    Foster, J.S.: Type Qualifiers: Lightweight Specifications to Improve Software Quality. Ph.D. thesis, University of California, Berkeley (December 2002)Google Scholar
  18. [FTA02]
    Foster, J.S., Terauchi, T., Aiken, A.: Flow-sensitive type qualifiers. In: Proceedings of PLDI 2002 Conference on Programming Language Design and Implementation, pp. 1–12. ACM Press, New York (2002)CrossRefGoogle Scholar
  19. [Gol84]
    Goldberg, A.: Smalltalk 80: the Interactive Programming Environment. Addison Wesley, Reading (1984)MATHGoogle Scholar
  20. [GPV01]
    Grothoff, C., Palsberg, J., Vitek, J.: Encapsulating objects with confined types. In: OOPSLA 2001: Proceedings of the 16th ACM SIGPLAN conference on Object oriented programming, systems, languages, and applications, pp. 241–255. ACM Press, New York (2001)CrossRefGoogle Scholar
  21. [GR89]
    Goldberg, A., Robson, D.: Smalltalk-80: The Language. Addison Wesley, Reading (1989)MATHGoogle Scholar
  22. [HBW02]
    Hu, E.Y.-S., Bernat, G., Wellings, A.: A Static Timing Analysis Environment Using Java Architecture for Safety Critical Real-Time Systems. In: Proceedings of 7th IEEE International Workshop on Object-Oriented Real-Time Dependable Systems (WORDS 2002), January 2002, pp. 64–71 (2002)Google Scholar
  23. [IKM+97]
    Ingalls, D., Kaehler, T., Maloney, J., Wallace, S., Kay, A.: Back to the future: The story of Squeak, A practical Smalltalk written in itself. In: Proceedings OOPSLA 1997, November 1997. ACM SIGPLAN Notices, pp. 318–326. ACM Press, New York (1997)Google Scholar
  24. [Jon97]
    Jones, M.P.: First-class polymorphism with type inference. In: POPL 1997: Proceedings of the 24th ACM SIGPLAN-SIGACT symposium on Principles of programming languages, pp. 483–496. ACM Press, New York (1997)Google Scholar
  25. [KdRB91]
    Kiczales, G., des Rivières, J., Bobrow, D.G.: The Art of the Metaobject Protocol. MIT Press, Cambridge (1991)Google Scholar
  26. [Kee89]
    Keene, S.E.: Object-Oriented Programming in Common-Lisp. Addison Wesley, Reading (1989)MATHGoogle Scholar
  27. [KS04]
    Kennedy, A., Syme, D.: Transposing f to c#: Expressivity of polymorphism in an object-oriented language. Concurrency and Computation: Practice and Experience 16(7) (2004)Google Scholar
  28. [LB85]
    Lehman, M.M., Belady, L.: Program Evolution – Processes of Software Change. London Academic Press, London (1985)MATHGoogle Scholar
  29. [Mac93]
    MacQueen, D.B.: Reflections on standard ml. In: Lauer, P.E. (ed.) Functional Programming, Concurrency, Simulation and Automated Reasoning. LNCS, vol. 693. Springer, Heidelberg (1993)Google Scholar
  30. [MLW05]
    Miranda, E., Leibs, D., Wuyts, R.: Parcels: a fast and feature-rich binary deployment technology. Computer Languages, Systems and Structures (September 2005) (to appear)Google Scholar
  31. [MOP85]
    Maier, D., Otis, A., Purdy, A.: Object-oriented database development at servio logic. IEEE Database Engineering 8(4), 58–65 (1985)Google Scholar
  32. [NA00]
    Nierstrasz, O., Achermann, F.: Supporting Compositional Styles for Software Evolution. In: Proceedings International Symposium on Principles of Software Evolution (ISPSE 2000), Kanazawa, Japan, November 2000, pp. 11–19. IEEE, Los Alamitos (2000)Google Scholar
  33. [NA05]
    Nierstrasz, O., Achermann, F.: Separating concerns with first-class namespaces. In: Filman, R.E., Elrad, T., Clarke, S., Aksit, M. (eds.) Aspect-Oriented Software Development, pp. 243–259. Addison-Wesley, Reading (2005)Google Scholar
  34. [Nie04]
    Nierstrasz, O.: Software evolution as the key to productivity. In: Wirsing, M., Knapp, A., Balsamo, S. (eds.) RISSEF 2002. LNCS, vol. 2941, pp. 274–282. Springer, Heidelberg (2004)CrossRefGoogle Scholar
  35. [PS87]
    Penney, D.J., Stein, J.: Class modification in the gemstone object-oriented DBMS. In: Proceedings OOPSLA 1987, December 1987. ACM SIGPLAN Notices, vol. 22, pp. 111–117 (1987)Google Scholar
  36. [PSH04]
    Pratikakis, P., Spacco, J., Hicks, M.: Transparent proxies for java futures. In: OOPSLA 2004: Proceedings of the 19th annual ACM SIGPLAN Conference on Object-oriented programming, systems, languages, and applications, pp. 206–223. ACM Press, New York (2004)CrossRefGoogle Scholar
  37. [Rus00]
    Russo, C.V.: First-class structures for standard ml. Nordic J. of Computing 7(4), 348–374 (2000)MathSciNetMATHGoogle Scholar
  38. [SB02]
    Smaragdakis, Y., Batory, D.: Mixin layers: an object-oriented implementation technique for refinements and collaboration-based designs. ACM TOSEM 11(2), 215–255 (2002)CrossRefGoogle Scholar
  39. [Soa01]
    Soanes, C. (ed.): Oxford Dictionary of Current English. Oxford University Press, Oxford (2001)Google Scholar
  40. [SS04]
    Spoon, S.A., Shivers, O.: Demand-driven type inference with subgoal pruning: Trading precision for scalability. In: Odersky, M. (ed.) ECOOP 2004. LNCS, vol. 3086, pp. 51–74. Springer, Heidelberg (2004)CrossRefGoogle Scholar
  41. [Str]
    The strongtalk type system for smalltalk, http://bracha.org/nwst.html
  42. [SWM00]
    Smith, F., Walker, D., Morrisett, J.G.: Alias types. In: Smolka, G. (ed.) ESOP 2000. LNCS, vol. 1782, pp. 366–381. Springer, Heidelberg (2000)CrossRefGoogle Scholar
  43. [Tah03]
    Taha, W.: A gentle introduction to multi-stage programming. In: Domain-Specific Program Generation, pp. 30–50 (2003)Google Scholar
  44. [Tai97]
    Taivalsaari, A.: Classes versus prototypes: Some philosophical and historical observations. Journal of Object-Oriented Programming (JOOP) 10(7), 44–50 (1997)Google Scholar
  45. [TBN01]
    Tanter, É., Bouraqadi, N., Noyé, J.: Reflex - towards an open reflective extension of java. In: Yonezawa, A., Matsuoka, S. (eds.) Reflection 2001. LNCS, vol. 2192, pp. 25–43. Springer, Heidelberg (2001)CrossRefGoogle Scholar
  46. [TN88]
    Tsichritzis, D., Nierstrasz, O.: Fitting round objects into square databases. In: Gjessing, S., Nygaard, K. (eds.) ECOOP 1988. LNCS, vol. 322, pp. 283–299. Springer, Heidelberg (1988)CrossRefGoogle Scholar
  47. [TNCC03]
    Tanter, É., Noyé, J., Caromel, D., Cointe, P.: Partial behavioral reflection: Spatial and temporal selection of reification. In: Proceedings of OOPSLA 2003, November 2003. ACM SIGPLAN Notices, pp. 27–46 (2003)Google Scholar
  48. [US87]
    Ungar, D., Smith, R.B.: Self: The power of simplicity. In: Proceedings OOPSLA 1987, December 1987. ACM SIGPLAN Notices, vol. 22, pp. 227–242 (1987)Google Scholar
  49. [WDN05]
    Wuyts, R., Ducasse, S., Nierstrasz, O.: A data-centric approach to composing embedded, real-time software components. Journal of Systems and Software — Special Issue on Automated Component-Based Software Engineering 74(1), 25–34 (2005)Google Scholar
  50. [Wuy01]
    Wuyts, R.: A Logic Meta-Programming Approach to Support the Co-Evolution of Object-Oriented Design and Implementation. PhD thesis, Vrije Universiteit Brussel (2001)Google Scholar
  51. [ZNV04]
    Zhao, T., Noble, J., Vitek, J.: Scoped types for real-time java. In: RTSS 2004: Proceedings of the 25th IEEE International Real-Time Systems Symposium (RTSS 2004), Washington, DC, USA, pp. 241–251. IEEE Computer Society, Los Alamitos (2004)Google Scholar
  52. [ZPV03]
    Zhao, T., Palsber, J., Vite, J.: Lightweight confinement for featherweight java. In: OOPSLA 2003: Proceedings of the 18th annual ACM SIGPLAN conference on Object-oriented programing, systems, languages, and applications, pp. 135–148. ACM Press, New York (2003)CrossRefGoogle Scholar

Copyright information

© IFIP International Federation for Information Processing 2005

Authors and Affiliations

  • Oscar Nierstrasz
    • 1
  • Alexandre Bergel
    • 1
  • Marcus Denker
    • 1
  • Stéphane Ducasse
    • 1
  • Markus Gälli
    • 1
  • Roel Wuyts
    • 1
  1. 1.Software Composition GroupUniversity of BernSwitzerland

Personalised recommendations