-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
77 lines (77 loc) · 3.63 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>Stardust Programming Language</title>
<base href="https://StardustPL.GitHub.IO/" target="_self" />
<link rel="canonical" href="https://StardustPL.GitHub.IO/" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<link rel="stylesheet" href="style.css" />
</head>
<body>
<header>
<h1>The Stardust Programming Language</h1>
</header>
<div id="content">
<main>
<h2>Types as First Class Citizens</h2>
<p>
C++'s template metaprogramming is incredibly powerful, but the syntax is awful.
In Stardust, types are objects and can be passed to and returned from functions like any other objects.
Where C++ has template classes, Stardust has functions that accept types and return local classes that operate on those types.
</p>
<h2>Compile-Time Code Execution</h2>
<p>
Another aspect of metaprogramming is running code at compile time.
Stardust syntax makes it clear whether code will run at runtime, compile time, or either time.
Exceptions thrown at compile time are reported during compilation and can be debugged on the spot - no messy template instantiation errors that are hard to read and confusing to debug.
</p>
<h2>No Garbage Collection</h2>
<p>
A disturbingly large number of languages have forced or default garbage collectors, even though garbage collection isn't always the best way to handle memory and memory isn't the only resource that can be leaked.
Stardust borrows C++'s RAII - that is, object lifetime is bound to scope, and destructors are deterministic (and therefore useful for more things than just memory).
Object lifetime is simple to understand and hard to get wrong.
</p>
<h2>Dynamic Module Loading</h2>
<p>
Load pre-compiled code modules at compile-time and runtime without worrying about incompatible statically linked libraries or other such nonsense.
Loading a module is as simple as passing in parameters to the module's compile-time code and being given a namespace in return which contains the module's public interface.
You can even load the same module multiple times with different parameters, or even the same parameters.
</p>
<p>
This is inscredibly useful for games which want to support modding/plugins - each mod/plugin is just a Stardust module that gets loaded.
Pass your public API namespace as a parameter to the module and get its public API namespace in return, no fuss.
</p>
<h2>How do I get started?</h2>
<p>
If you're just passing by, come back in a few years.
There's currently no compiler and no formal specification, and it's going to be a while before any of that happens.
Any help and feedback is appreciated, though - language design isn't easy, and early mistakes can be permanent.
</p>
</main>
<nav>
<figure>
<figcaption>Stardust</figcaption>
<ul>
<li><mark><a href=".">Home</a></mark></li>
<li><a href="https://github.com/StardustPL">GitHub</a></li>
<li><a href="https://github.com/StardustPL/Stardust/wiki">Wiki</a></li>
<li><a href="https://gitter.im/orgs/StardustPL/rooms">Chat</a></li>
</ul>
</figure>
</nav>
<aside>
<figure>
<figcaption>News</figcaption>
<ul>
<li>Someday. Maybe.</li>
</ul>
</figure>
</aside>
</div>
<footer>
<p>This content is in the <a href="http://unlicense.org/">public domain</a> and is not eligible for copyright protection.</p>
<p>View <a href="https://github.com/StardustPL/StardustPL.GitHub.IO/">source code</a> on GitHub.</p>
</footer>
</body>
</html>