home.social

#racketlanguage — Public Fediverse posts

Live and recent posts from across the Fediverse tagged #racketlanguage, aggregated by home.social.

  1. Racket - the Language-Oriented Programming Language - version 8.15 is now available from download.racket-lang.org

    See blog.racket-lang.org/2024/11/r for the release announcement and highlights. #DrRacket #Racket #RacketLanguage

  2. Data Integrity via Smart Structs

    by David Storrs

    Structs in Racket should be more than dumb data storage. They should be data models in the sense of MVC programming; they should ensure that their contents are valid according to your project’s business rules and they should make it easy to do common operations such as storing to a database or generating a struct from data of another type such as a database row or user input field.

    The struct-plus-plus module makes this easy. It allows you to place contracts on individual fields, specify business rules that ensure integrity between fields, easily create converter functions, and much more, with all of these things being part of the struct definition and therefore in one easily-referenced location. Come see how it all works and how you can simplify your code with struct-plus-plus!

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  3. Data Integrity via Smart Structs

    by David Storrs

    Structs in Racket should be more than dumb data storage. They should be data models in the sense of MVC programming; they should ensure that their contents are valid according to your project’s business rules and they should make it easy to do common operations such as storing to a database or generating a struct from data of another type such as a database row or user input field.

    The struct-plus-plus module makes this easy. It allows you to place contracts on individual fields, specify business rules that ensure integrity between fields, easily create converter functions, and much more, with all of these things being part of the struct definition and therefore in one easily-referenced location. Come see how it all works and how you can simplify your code with struct-plus-plus!

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  4. Data Integrity via Smart Structs

    by David Storrs

    Structs in Racket should be more than dumb data storage. They should be data models in the sense of MVC programming; they should ensure that their contents are valid according to your project’s business rules and they should make it easy to do common operations such as storing to a database or generating a struct from data of another type such as a database row or user input field.

    The struct-plus-plus module makes this easy. It allows you to place contracts on individual fields, specify business rules that ensure integrity between fields, easily create converter functions, and much more, with all of these things being part of the struct definition and therefore in one easily-referenced location. Come see how it all works and how you can simplify your code with struct-plus-plus!

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  5. Data Integrity via Smart Structs

    by David Storrs

    Structs in Racket should be more than dumb data storage. They should be data models in the sense of MVC programming; they should ensure that their contents are valid according to your project’s business rules and they should make it easy to do common operations such as storing to a database or generating a struct from data of another type such as a database row or user input field.

    The struct-plus-plus module makes this easy. It allows you to place contracts on individual fields, specify business rules that ensure integrity between fields, easily create converter functions, and much more, with all of these things being part of the struct definition and therefore in one easily-referenced location. Come see how it all works and how you can simplify your code with struct-plus-plus!

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  6. Data Integrity via Smart Structs

    by David Storrs

    Structs in Racket should be more than dumb data storage. They should be data models in the sense of MVC programming; they should ensure that their contents are valid according to your project’s business rules and they should make it easy to do common operations such as storing to a database or generating a struct from data of another type such as a database row or user input field.

    The struct-plus-plus module makes this easy. It allows you to place contracts on individual fields, specify business rules that ensure integrity between fields, easily create converter functions, and much more, with all of these things being part of the struct definition and therefore in one easily-referenced location. Come see how it all works and how you can simplify your code with struct-plus-plus!

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  7. keyring: Uniformly Access Secrets

    by Sam Phillips

    Hardcoding passwords in your programs is bad. Using secure password stores are good. Keyring is a Racket library that allows programs to access different password stores using a simple interface.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  8. keyring: Uniformly Access Secrets

    by Sam Phillips

    Hardcoding passwords in your programs is bad. Using secure password stores are good. Keyring is a Racket library that allows programs to access different password stores using a simple interface.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  9. keyring: Uniformly Access Secrets

    by Sam Phillips

    Hardcoding passwords in your programs is bad. Using secure password stores are good. Keyring is a Racket library that allows programs to access different password stores using a simple interface.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  10. keyring: Uniformly Access Secrets

    by Sam Phillips

    Hardcoding passwords in your programs is bad. Using secure password stores are good. Keyring is a Racket library that allows programs to access different password stores using a simple interface.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  11. keyring: Uniformly Access Secrets

    by Sam Phillips

    Hardcoding passwords in your programs is bad. Using secure password stores are good. Keyring is a Racket library that allows programs to access different password stores using a simple interface.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  12. Incrementally Developing Support for Racket->Wasm Compilation

    by Adam Perlin

    Wasm is an attractive compiler target for a variety of reasons: it has support in all major browsers, its isolation guarantees are beneficial for security reasons, and it has potential as a general-purpose platform-independent execution environment. However, adding Wasm support to Racket has proven a challenging problem due to differences in the execution model each language uses at runtime. Chez Scheme, the backend of Racket CS, utilizes code generation conventions which are difficult to adapt to Wasm.

    This talk will present an alternative approach to Racket-to-Wasm compilation which is compatible with Racket CS. The approach is accomplished by using an existing bytecode format and interpreter which are already supported under Chez Scheme, and performing an ahead-of-time translation of portions of bytecode programs into Wasm. This sets up an incremental approach to the development of a Racket-to-Wasm compilation system.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  13. Incrementally Developing Support for Racket->Wasm Compilation

    by Adam Perlin

    Wasm is an attractive compiler target for a variety of reasons: it has support in all major browsers, its isolation guarantees are beneficial for security reasons, and it has potential as a general-purpose platform-independent execution environment. However, adding Wasm support to Racket has proven a challenging problem due to differences in the execution model each language uses at runtime. Chez Scheme, the backend of Racket CS, utilizes code generation conventions which are difficult to adapt to Wasm.

    This talk will present an alternative approach to Racket-to-Wasm compilation which is compatible with Racket CS. The approach is accomplished by using an existing bytecode format and interpreter which are already supported under Chez Scheme, and performing an ahead-of-time translation of portions of bytecode programs into Wasm. This sets up an incremental approach to the development of a Racket-to-Wasm compilation system.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  14. Incrementally Developing Support for Racket->Wasm Compilation

    by Adam Perlin

    Wasm is an attractive compiler target for a variety of reasons: it has support in all major browsers, its isolation guarantees are beneficial for security reasons, and it has potential as a general-purpose platform-independent execution environment. However, adding Wasm support to Racket has proven a challenging problem due to differences in the execution model each language uses at runtime. Chez Scheme, the backend of Racket CS, utilizes code generation conventions which are difficult to adapt to Wasm.

    This talk will present an alternative approach to Racket-to-Wasm compilation which is compatible with Racket CS. The approach is accomplished by using an existing bytecode format and interpreter which are already supported under Chez Scheme, and performing an ahead-of-time translation of portions of bytecode programs into Wasm. This sets up an incremental approach to the development of a Racket-to-Wasm compilation system.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  15. Incrementally Developing Support for Racket->Wasm Compilation

    by Adam Perlin

    Wasm is an attractive compiler target for a variety of reasons: it has support in all major browsers, its isolation guarantees are beneficial for security reasons, and it has potential as a general-purpose platform-independent execution environment. However, adding Wasm support to Racket has proven a challenging problem due to differences in the execution model each language uses at runtime. Chez Scheme, the backend of Racket CS, utilizes code generation conventions which are difficult to adapt to Wasm.

    This talk will present an alternative approach to Racket-to-Wasm compilation which is compatible with Racket CS. The approach is accomplished by using an existing bytecode format and interpreter which are already supported under Chez Scheme, and performing an ahead-of-time translation of portions of bytecode programs into Wasm. This sets up an incremental approach to the development of a Racket-to-Wasm compilation system.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  16. Incrementally Developing Support for Racket->Wasm Compilation

    by Adam Perlin

    Wasm is an attractive compiler target for a variety of reasons: it has support in all major browsers, its isolation guarantees are beneficial for security reasons, and it has potential as a general-purpose platform-independent execution environment. However, adding Wasm support to Racket has proven a challenging problem due to differences in the execution model each language uses at runtime. Chez Scheme, the backend of Racket CS, utilizes code generation conventions which are difficult to adapt to Wasm.

    This talk will present an alternative approach to Racket-to-Wasm compilation which is compatible with Racket CS. The approach is accomplished by using an existing bytecode format and interpreter which are already supported under Chez Scheme, and performing an ahead-of-time translation of portions of bytecode programs into Wasm. This sets up an incremental approach to the development of a Racket-to-Wasm compilation system.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  17. Mutate: Inject Bugs into Your Programs!

    by Lukas Lazarek

    Lukas Lazarek introduces mutate, a library for mutating programs, i.e. injecting possible bugs by making small syntactic changes to the program syntax. Lucas discusses what mutation is, why one might want it, and provides a demo of how to use the library.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  18. Mutate: Inject Bugs into Your Programs!

    by Lukas Lazarek

    Lukas Lazarek introduces mutate, a library for mutating programs, i.e. injecting possible bugs by making small syntactic changes to the program syntax. Lucas discusses what mutation is, why one might want it, and provides a demo of how to use the library.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  19. Mutate: Inject Bugs into Your Programs!

    by Lukas Lazarek

    Lukas Lazarek introduces mutate, a library for mutating programs, i.e. injecting possible bugs by making small syntactic changes to the program syntax. Lucas discusses what mutation is, why one might want it, and provides a demo of how to use the library.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  20. Mutate: Inject Bugs into Your Programs!

    by Lukas Lazarek

    Lukas Lazarek introduces mutate, a library for mutating programs, i.e. injecting possible bugs by making small syntactic changes to the program syntax. Lucas discusses what mutation is, why one might want it, and provides a demo of how to use the library.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  21. Mutate: Inject Bugs into Your Programs!

    by Lukas Lazarek

    Lukas Lazarek introduces mutate, a library for mutating programs, i.e. injecting possible bugs by making small syntactic changes to the program syntax. Lucas discusses what mutation is, why one might want it, and provides a demo of how to use the library.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  22. #lang Karp: Formulating and Random Testing NP Reductions

    by Chenhao Zhang

    Reduction, a pervasive idea in computer science, is often taught in algorithm courses with NP problems. The traditional pen-and-paper approach is notoriously ineffective both for students and instructors: Subtle mistakes in reductions are often hard to detect by merely inspecting the purported solutions. Constructing a counterexample by hand to expose the mistake is even more onerous. Based on the observation that reductions are actually programs, we designed #lang Karp, a DSL for formulating and random testing NP reductions.

    In this presentation, Chenhao Zhang discusses the implementation of Karp on top of Racket and solver-aided host language Rosette.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  23. #lang Karp: Formulating and Random Testing NP Reductions

    by Chenhao Zhang

    Reduction, a pervasive idea in computer science, is often taught in algorithm courses with NP problems. The traditional pen-and-paper approach is notoriously ineffective both for students and instructors: Subtle mistakes in reductions are often hard to detect by merely inspecting the purported solutions. Constructing a counterexample by hand to expose the mistake is even more onerous. Based on the observation that reductions are actually programs, we designed #lang Karp, a DSL for formulating and random testing NP reductions.

    In this presentation, Chenhao Zhang discusses the implementation of Karp on top of Racket and solver-aided host language Rosette.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  24. #lang Karp: Formulating and Random Testing NP Reductions

    by Chenhao Zhang

    Reduction, a pervasive idea in computer science, is often taught in algorithm courses with NP problems. The traditional pen-and-paper approach is notoriously ineffective both for students and instructors: Subtle mistakes in reductions are often hard to detect by merely inspecting the purported solutions. Constructing a counterexample by hand to expose the mistake is even more onerous. Based on the observation that reductions are actually programs, we designed #lang Karp, a DSL for formulating and random testing NP reductions.

    In this presentation, Chenhao Zhang discusses the implementation of Karp on top of Racket and solver-aided host language Rosette.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  25. #lang Karp: Formulating and Random Testing NP Reductions

    by Chenhao Zhang

    Reduction, a pervasive idea in computer science, is often taught in algorithm courses with NP problems. The traditional pen-and-paper approach is notoriously ineffective both for students and instructors: Subtle mistakes in reductions are often hard to detect by merely inspecting the purported solutions. Constructing a counterexample by hand to expose the mistake is even more onerous. Based on the observation that reductions are actually programs, we designed #lang Karp, a DSL for formulating and random testing NP reductions.

    In this presentation, Chenhao Zhang discusses the implementation of Karp on top of Racket and solver-aided host language Rosette.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  26. #lang Karp: Formulating and Random Testing NP Reductions

    by Chenhao Zhang

    Reduction, a pervasive idea in computer science, is often taught in algorithm courses with NP problems. The traditional pen-and-paper approach is notoriously ineffective both for students and instructors: Subtle mistakes in reductions are often hard to detect by merely inspecting the purported solutions. Constructing a counterexample by hand to expose the mistake is even more onerous. Based on the observation that reductions are actually programs, we designed #lang Karp, a DSL for formulating and random testing NP reductions.

    In this presentation, Chenhao Zhang discusses the implementation of Karp on top of Racket and solver-aided host language Rosette.

    Watch now: presentation

    #Racket #RacketLang #RacketLanguage #RacketCon

  27. Introducing Rackith

    by Sage Gerard

    Rackith is a language-oriented programming language based on Racket. Use Rackith to define many languages with one syntax object.

    Watch the presentation now: talk video

    #Racket #RacketLang #RacketLanguage #RacketCon

  28. Introducing Rackith

    by Sage Gerard

    Rackith is a language-oriented programming language based on Racket. Use Rackith to define many languages with one syntax object.

    Watch the presentation now: talk video

    #Racket #RacketLang #RacketLanguage #RacketCon

  29. Introducing Rackith

    by Sage Gerard

    Rackith is a language-oriented programming language based on Racket. Use Rackith to define many languages with one syntax object.

    Watch the presentation now: talk video

    #Racket #RacketLang #RacketLanguage #RacketCon

  30. Introducing Rackith

    by Sage Gerard

    Rackith is a language-oriented programming language based on Racket. Use Rackith to define many languages with one syntax object.

    Watch the presentation now: talk video

    #Racket #RacketLang #RacketLanguage #RacketCon

  31. Introducing Rackith

    by Sage Gerard

    Rackith is a language-oriented programming language based on Racket. Use Rackith to define many languages with one syntax object.

    Watch the presentation now: talk video

    #Racket #RacketLang #RacketLanguage #RacketCon

  32. Redeeming Open Source with Attribution Based Economics

    By Sid Kasivajhula, feat. Michael Ballantyne

    Attribution Based Economics (ABE) is a new paradigm for economics that revises several foundational assumptions governing today’s systems, including the nature of economic value and the origin of money. In this new paradigm, open source software becomes economically viable and, indeed, even financially favored over proprietary models. This talk describes our experiences implementing an early prototype for the Qi project, and also how Racket will be an essential part of the solution as ABE scales past the pilot stage.

    Watch now: presentation

    #ABE #QiProject #Racketlang #Racket #RacketLanguage #OpenSource

  33. RacketCon presentation “Sawzall: A grammar for chopping up data”

    by @hazel

    Sawzall, inspired heavily by dplyr and the relational algebra. Sawzall builds on top of Alex Harsanyi’s data-frame package, but provides a set of operations that are designed to compose and avoid mutating the original data-set, leading to a natural style of data manipulation following the idea of "do this, then that".

    Find more great presentations and details of RacketCon 2023 at con.racket-lang.org/

    Sawzall: A grammar for chopping up data

    youtu.be/zza0fb36c-U
    docs.racket-lang.org/sawzall/i

    #RacketCon #Racket #RacketLang #RacketLanguage #dplyr #sawzall

  34. RacketCon presentation “Sawzall: A grammar for chopping up data”

    by @hazel

    Sawzall, inspired heavily by dplyr and the relational algebra. Sawzall builds on top of Alex Harsanyi’s data-frame package, but provides a set of operations that are designed to compose and avoid mutating the original data-set, leading to a natural style of data manipulation following the idea of "do this, then that".

    Find more great presentations and details of RacketCon 2023 at con.racket-lang.org/

    Sawzall: A grammar for chopping up data

    youtu.be/zza0fb36c-U
    docs.racket-lang.org/sawzall/i

    #RacketCon #Racket #RacketLang #RacketLanguage #dplyr #sawzall

  35. RacketCon presentation “Sawzall: A grammar for chopping up data”

    by @hazel

    Sawzall, inspired heavily by dplyr and the relational algebra. Sawzall builds on top of Alex Harsanyi’s data-frame package, but provides a set of operations that are designed to compose and avoid mutating the original data-set, leading to a natural style of data manipulation following the idea of "do this, then that".

    Find more great presentations and details of RacketCon 2023 at con.racket-lang.org/

    Sawzall: A grammar for chopping up data

    youtu.be/zza0fb36c-U
    docs.racket-lang.org/sawzall/i

    #RacketCon #Racket #RacketLang #RacketLanguage #dplyr #sawzall

  36. RacketCon presentation “Sawzall: A grammar for chopping up data”

    by @hazel

    Sawzall, inspired heavily by dplyr and the relational algebra. Sawzall builds on top of Alex Harsanyi’s data-frame package, but provides a set of operations that are designed to compose and avoid mutating the original data-set, leading to a natural style of data manipulation following the idea of "do this, then that".

    Find more great presentations and details of RacketCon 2023 at con.racket-lang.org/

    Sawzall: A grammar for chopping up data

    youtu.be/zza0fb36c-U
    docs.racket-lang.org/sawzall/i

    #RacketCon #Racket #RacketLang #RacketLanguage #dplyr #sawzall

  37. RacketCon presentation “Sawzall: A grammar for chopping up data”

    by @hazel

    Sawzall, inspired heavily by dplyr and the relational algebra. Sawzall builds on top of Alex Harsanyi’s data-frame package, but provides a set of operations that are designed to compose and avoid mutating the original data-set, leading to a natural style of data manipulation following the idea of "do this, then that".

    Find more great presentations and details of RacketCon 2023 at con.racket-lang.org/

    Sawzall: A grammar for chopping up data

    youtu.be/zza0fb36c-U
    docs.racket-lang.org/sawzall/i

    #RacketCon #Racket #RacketLang #RacketLanguage #dplyr #sawzall

  38. Zuo: A Tiny Racket for Scripting

    You should use Racket to write scripts. But what if you need something much smaller than Racket for some reason?

    Zuo is a tiny Racket with primitives for dealing with files and running processes, and it comes with a make-like embedded DSL.

    github.com/racket/zuo

    Documentation: docs.racket-lang.org/zuo/index

    Zuo is also available as a guix package!: packages.guix.gnu.org/packages

    #Zuo #ZuoLang #Racket #guix #RacketLang #RacketLanguage

  39. Zuo: A Tiny Racket for Scripting

    You should use Racket to write scripts. But what if you need something much smaller than Racket for some reason?

    Zuo is a tiny Racket with primitives for dealing with files and running processes, and it comes with a make-like embedded DSL.

    github.com/racket/zuo

    Documentation: docs.racket-lang.org/zuo/index

    Zuo is also available as a guix package!: packages.guix.gnu.org/packages

    #Zuo #ZuoLang #Racket #guix #RacketLang #RacketLanguage

  40. Zuo: A Tiny Racket for Scripting

    You should use Racket to write scripts. But what if you need something much smaller than Racket for some reason?

    Zuo is a tiny Racket with primitives for dealing with files and running processes, and it comes with a make-like embedded DSL.

    github.com/racket/zuo

    Documentation: docs.racket-lang.org/zuo/index

    Zuo is also available as a guix package!: packages.guix.gnu.org/packages

    #Zuo #ZuoLang #Racket #guix #RacketLang #RacketLanguage

  41. Zuo: A Tiny Racket for Scripting

    You should use Racket to write scripts. But what if you need something much smaller than Racket for some reason?

    Zuo is a tiny Racket with primitives for dealing with files and running processes, and it comes with a make-like embedded DSL.

    github.com/racket/zuo

    Documentation: docs.racket-lang.org/zuo/index

    Zuo is also available as a guix package!: packages.guix.gnu.org/packages

    #Zuo #ZuoLang #Racket #guix #RacketLang #RacketLanguage

  42. Zuo: A Tiny Racket for Scripting

    You should use Racket to write scripts. But what if you need something much smaller than Racket for some reason?

    Zuo is a tiny Racket with primitives for dealing with files and running processes, and it comes with a make-like embedded DSL.

    github.com/racket/zuo

    Documentation: docs.racket-lang.org/zuo/index

    Zuo is also available as a guix package!: packages.guix.gnu.org/packages

    #Zuo #ZuoLang #Racket #guix #RacketLang #RacketLanguage

  43. (thirteenth RacketCon)

    October 28-29, 2023
    Northwestern University
    Evanston, IL, USA

    con.racket-lang.org/

    Introducing Rackith

    Sage Gerard sagegerard.com/

    Rackith is a language-oriented programming language based on Racket. Use Rackith to define many languages with one syntax object. Discussion covers project design and implications for the personal computer.

    Reductions on top of Rosette

    Chenhao Zhang eecs.northwestern.edu/~czu2221

    Rhombus: Status update

    Matthew Flatt (Utah) users.cs.utah.edu/~mflatt/

    The State of Racket

    Sam Tobin-Hochstadt (Indiana) samth.github.io/

    Racket Town Hall

    Racket Management

    Please come with your big questions and discussion topics.

    Registration

    Check back soon! We currently do not have a registration form.’

    Friendly Environment Policy

    The proceedings of RacketCon will take place under the Racket Friendly Environment Policy racket-lang.org/friendly.html

    Accommodation

    We are currently exploring the possibility of getting a block of rooms at a nearby hotel.

    #Racket #RacketLang #RacketLanguage
    #LanguageOrientedProgramming #lop #Rosette #RosetteLanguage