Book Image

Learn Bosque Programming

By : Sebastian Kaczmarek, Joel Ibaceta
Book Image

Learn Bosque Programming

By: Sebastian Kaczmarek, Joel Ibaceta

Overview of this book

Bosque is a new high-level programming language inspired by the impact of structured programming in the 1970s. It adopts the TypeScript syntax and ML semantics and is designed for writing code that is easy to reason about for humans and machines. With this book, you'll understand how Bosque supports high productivity and cloud-first development by removing sources of accidental complexity and introducing novel features. This short book covers all the language features that you need to know to work with Bosque programming. You'll learn about basic data types, variables, functions, operators, statements, and expressions in Bosque and become familiar with advanced features such as typed strings, bulk algebraic data operations, namespace declarations, and concept and entity declarations. This Bosque book provides a complete language reference for learning to program with Bosque and understanding the regularized programming paradigm. You'll also explore real-world examples that will help you to reinforce the knowledge you've acquired. Additionally, you'll discover more advanced topics such as the Bosque project structure and contributing to the project. By the end of this book, you'll have learned how to configure the Bosque environment and build better and reliable software with this exciting new open-source language.
Table of Contents (22 chapters)
1
Section 1: Introduction
5
Section 2: The Bosque Language Overview
10
Section 3: Practicing Bosque
15
Section 4: Exploring Advanced Features

Working with sanity checks in Bosque

We have already partially covered this topic in Chapter 3, Bosque Key Features. We talked about the invariant keyword, and the requires, requires release, and ensures conditions. We also mentioned the assertions and checks. Let's see how we can use them in practice along with the SymTest tool.

Before we get started let’s consider an example program. It’s not going to be rocket science. For the sake of this chapter we will build a simple Bin2Dec converter. It will take the provided binary number and return its decimal representation. We will limit the binary representation to four bits and will require every bit to be passed as a separate argument. It may look a bit inconvenient and it’s true but it will make you understand the SymTest tool better.

At this point you already know the Bosque syntax and most of the rules so I won’t dive deep into the implementation. Have a look at the following code:

namespace...