tova 0.2.5 → 0.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/bin/tova.js CHANGED
@@ -500,6 +500,28 @@ async function devServer(args) {
500
500
 
501
501
  const reloadPort = basePort + 100;
502
502
 
503
+ // Start live-reload SSE server early so actualReloadPort is available for HTML generation
504
+ const reloadClients = new Set();
505
+ let reloadServer;
506
+ let actualReloadPort = reloadPort;
507
+ for (let attempt = 0; attempt < 10; attempt++) {
508
+ try {
509
+ reloadServer = Bun.serve({
510
+ port: actualReloadPort,
511
+ fetch(req) {
512
+ return handleReloadFetch(req);
513
+ },
514
+ });
515
+ break;
516
+ } catch {
517
+ actualReloadPort++;
518
+ }
519
+ }
520
+ if (!reloadServer) {
521
+ console.log(' ⚠ Could not start live-reload server (ports in use)');
522
+ actualReloadPort = 0;
523
+ }
524
+
503
525
  console.log(`\n Tova dev server starting...\n`);
504
526
 
505
527
  // Compile all files
@@ -624,27 +646,6 @@ async function devServer(args) {
624
646
  console.log(` ✓ Client: ${relative('.', outDir)}/index.html`);
625
647
  }
626
648
 
627
- // Start live-reload SSE server — find an available port
628
- const reloadClients = new Set();
629
- let reloadServer;
630
- let actualReloadPort = reloadPort;
631
- for (let attempt = 0; attempt < 10; attempt++) {
632
- try {
633
- reloadServer = Bun.serve({
634
- port: actualReloadPort,
635
- fetch(req) {
636
- return handleReloadFetch(req);
637
- },
638
- });
639
- break;
640
- } catch {
641
- actualReloadPort++;
642
- }
643
- }
644
- if (!reloadServer) {
645
- console.log(' ⚠ Could not start live-reload server (ports in use)');
646
- }
647
-
648
649
  function handleReloadFetch(req) {
649
650
  const url = new URL(req.url);
650
651
  if (url.pathname === '/__tova_reload') {
@@ -958,7 +959,7 @@ client {
958
959
 
959
960
  component App {
960
961
  <div class="app">
961
- <h1>"Welcome to {message}"</h1>
962
+ <h1>"{message}"</h1>
962
963
  <p>"Edit src/app.tova to get started."</p>
963
964
  </div>
964
965
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "tova",
3
- "version": "0.2.5",
3
+ "version": "0.2.7",
4
4
  "description": "Tova — a modern programming language that transpiles to JavaScript, unifying frontend and backend",
5
5
  "type": "module",
6
6
  "main": "src/index.js",
@@ -703,7 +703,8 @@ export class Analyzer {
703
703
 
704
704
  visitSharedBlock(node) {
705
705
  const prevScope = this.currentScope;
706
- this.currentScope = this.currentScope.child('shared');
706
+ const sharedScope = this.currentScope.child('shared');
707
+ this.currentScope = sharedScope;
707
708
  try {
708
709
  for (const stmt of node.body) {
709
710
  this.visitNode(stmt);
@@ -711,6 +712,13 @@ export class Analyzer {
711
712
  } finally {
712
713
  this.currentScope = prevScope;
713
714
  }
715
+ // Promote shared symbols (types, functions) to parent scope
716
+ // so server/client blocks can reference them
717
+ for (const [name, sym] of sharedScope.symbols) {
718
+ if (!prevScope.symbols.has(name)) {
719
+ prevScope.symbols.set(name, sym);
720
+ }
721
+ }
714
722
  }
715
723
 
716
724
  // ─── Declaration visitors ─────────────────────────────────
@@ -1982,6 +1990,8 @@ export class Analyzer {
1982
1990
  }
1983
1991
  case 'ExpressionStatement':
1984
1992
  return this._definitelyReturns(node.expression);
1993
+ case 'CallExpression':
1994
+ return true;
1985
1995
  default:
1986
1996
  return false;
1987
1997
  }
package/src/version.js CHANGED
@@ -1,2 +1,2 @@
1
1
  // Auto-generated by scripts/embed-runtime.js — do not edit
2
- export const VERSION = "0.2.5";
2
+ export const VERSION = "0.2.7";