Comments (2)
I've implemented some of it. Currently supports only namespace functions. I don't think is ready but it should be enough for testing/education. You could clone it from here. (commit)
Example:
namespace NSMain;
function incrementRecursive(n: Int, max: Int): Int {
_debug(n);
return n < max ? rec incrementRecursive(n + 1, max): n;
}
entrypoint function main(): Bool {
var test = incrementRecursive(1, 99999999);
return true;
}
from bosquelanguage.
I'm surprised to see rec, if needed at all, on the reference rather than the declaration.
Although function rec f( ... ) ... was a common idea, it seems that practice involves function recursiveness being the default with regard to static name resolution within lexical structure. That seems to be the approach with SML, and it tends to be more natural. It does require some trickery when the inner call is intended to be to an outer declaration, not the current one.
The additional case of mutual recursion has to be handled a different way.
There also needs to be something else for anonymous function definitions.
I should zip my lip until I look more closely at the Bosque definition material.
Also, I thought this notion is independent of the question of tail recursion. Am I mistaken?
from bosquelanguage.
Related Issues (20)
- Debug vs Release time checks HOT 1
- Can't get conjunction type resolution to work HOT 1
- Parser ambiguity on "("
- Concept & and provides
- SymTest does not allow a List to be mapped into another type HOT 2
- Postcondition `ensures` does not compile when ref parameter provided HOT 1
- Could the built-in test runner be used to write unit tests for user programs? HOT 7
- IR-only code-gen backend? HOT 1
- It would be very-very nice if you could cite our paper :)
- Modelling remote execution and storage within Bosque
- npm ERR! Test failed BosqueLanguage-LearnBosqueProgramming branch HOT 1
- This repo is missing important files HOT 2
- Model constraints for CADL HOT 1
- SMT Division
- BigX support
- Decimal Support
- Rational Support
- ASCIIString
- Design of arithmetic operations (static vs. dynamic)
- Enum values
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from bosquelanguage.