Skip to content
Jeongho Nam edited this page Oct 25, 2018 · 11 revisions

TypeScript Grid Computing Framework

Build Status npm version Downloads DeepScan grade Chat on Gitter

TGrid is a tiny framework for Grid Computing in TypeScript, using such concepts.

  • ROC: Remote Object Call
  • RFC: Remote Function Call
  • OON: Object Oriented Network

Following paradigm of the TGrid, you can compose real-time network communication systems very easily. Consider that system nodes are correspondent with objects. All you have to do is just calling functions in those objects with a special symbol await.

I repeat, whether how network systems are enormous and feature are complicated, they're just objects. Just call functions, with the keyword await. It sound difficult, then look at the below Usage - Example Code, then you may understand. If you want to know more, Guide Documents are prepared for you.

Installation

NPM Module

Installing TGrid in NodeJS is very easy. Just install with the npm command.

# Install TGrid from the NPM module.
npm install --save tgrid

Usage - Example Code

example/vector/server.ts

import { Vector } from "tstl/container";
import { WebServer } from "tgrid/protocol/web";

function main(): void
{
    let server = new WebServer();
    server.open(10101, async acceptor =>
    {
        await acceptor.accept();
        await acceptor.listen(new Vector<number>());
    });
}
main();

example/vector/client.ts

import { Vector } from "tstl/container";
import { WebConnector } from "tgrid/protocol/web";

async function main(): Promise<void>
{
    let connector = new WebConnector();
    await connector.connect("ws://127.0.0.1:9999");
    await connector.wait();

    let v = connector.getController<Vector<number>>();
    for (let i: number = 0; i < 5; ++i)
        await v.push_back(i);

    console.log("size:", await v.size());
    for (let i: number = 0; i < await v.size(); ++i)
        console.log("  element:", await v.at(i));

    await connector.close();
}
main();
size: 5
  element: 0
  element: 1
  element: 2
  element: 3
  element: 4

References

Clone this wiki locally