Thanks to visit codestin.com
Credit goes to github.com

Skip to content

NodeppOfficial/nodepp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

6 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Nodepp

Nodepp is a groundbreaking open-source project that simplifies C++ application development by bridging the gap between the language's raw power and the developer-friendly abstractions of Node.js. By providing a high-level API, Nodepp empowers developers to write C++ code in a familiar, Node.js-inspired style.

One of the standout features of Nodepp is its 100% asynchronous architecture, powered by an internal Event Loop. This design efficiently manages Nodepp’s tasks, enabling you to develop scalable and concurrent applications with minimal code. Experience the power and flexibility of Nodepp as you streamline your development process and create robust applications effortlessly!

Dependencies

# Openssl
    πŸͺŸ: pacman -S mingw-w64-ucrt-x86_64-openssl
    🐧: sudo apt install libssl-dev

# Zlib
    πŸͺŸ: pacman -S mingw-w64-ucrt-x86_64-zlib
    🐧: sudo apt install zlib1g-dev

Features

  • πŸ“Œ: Node.js-like API: Write C++ code in a syntax and structure similar to Node.js, making it easier to learn and use.
  • πŸ“Œ: High-performance: Leverage the speed and efficiency of C++ for demanding applications.
  • πŸ“Œ: Scalability: Build applications that can handle large workloads and grow with your needs.
  • πŸ“Œ: Open-source: Contribute to the project's development and customize it to your specific requirements.

Bateries Included

  • πŸ“Œ: Include a build-in JSON parser / stringify system.
  • πŸ“Œ: Include a build-in RegExp engine for processing text strings.
  • πŸ“Œ: Include Support for UTF manipulation | UTF8 - UTF16 - UTF32
  • πŸ“Œ: Include a build-in System that make every object Async Task safety.
  • πŸ“Œ: Include a Smart Pointer base Garbage Collector to avoid Memory Leaks.
  • πŸ“Œ: Include support for Reactive Programming based on Events and Observers.
  • πŸ“Œ: Include an Event Loop that can handle multiple events and tasks on a single thread.
  • πŸ“Œ: Include support for TCP | TLS | UDP | HTTP | WS making it easy to create networked applications.
  • πŸ“Œ: Include Support for Poll | Epoll | Kqueue | WSAPoll making it easy to handle multiple file descriptors.

Build & Run

🐧: g++ -o main main.cpp -O3 -I ./include ; ./main
πŸͺŸ: g++ -o main main.cpp -O3 -I ./include -lws2_32 ; ./main

Test Unit

🐧: ( cd ./test; g++ -o main main.cpp -I../include -lssl -lcrypto -lpthread ; ./main )
πŸͺŸ: ( cd ./test; g++ -o main main.cpp -I../include -lssl -lcrypto -lws2_32  ; ./main )

Examples

Reading JSON

#include <nodepp/nodepp.h>
#include <nodepp/json.h>

using namespace nodepp;

void onMain() {

    auto data = json::parse( R"({
        "var1": 10,
        "var2": false,
        "var3": "hello world",
        "var4": { "var5": "nested object" },
        "var5": [ 10, 20, 30, 40, 50, 60, 70 ]
    })" );

    console::log( "var1:", data["var1"].as<uint>() );
    console::log( "var2:", data["var2"].as<bool>() );
    console::log( "var3:", data["var3"].as<string_t>() );
    console::log( "var4:", data["var4"]["var5"].as<string_t>() );

    console::log( "\n --- \n" );

    for( auto x: data["var5"].as<array_t<object_t>>() ){
         console::log( "var5", x.as<uint>() );
    }

}

HTTP Client

//#pragma comment(lib, "Ws2_32.lib") msvc compiler

#include <nodepp/nodepp.h>
#include <nodepp/http.h>

using namespace nodepp;

void onMain(){

    fetch_t args;
            args.method = "GET";
            args.url = "http://www.google.com/";
            args.headers = header_t({
                { "Host", url::host(args.url) }
            });

    http::fetch( args )

    .then([]( http_t cli ){
        console::log( stream::await( cli ) );
    })

    .fail([]( except_t err ){
        console::error( err );
    });

}

HTTP Server

//#pragma comment(lib, "Ws2_32.lib") msvc compiler

#include <nodepp/nodepp.h>
#include <nodepp/http.h>
#include <nodepp/date.h>

using namespace nodepp;

void onMain(){

    auto server = http::server([=]( http_t cli ){

        console::log( cli.path, cli.get_fd() );

        cli.write_header( 200, header_t({
            { "content-type", "text/html" }
        }));

        cli.write( date::fulltime() );
        cli.close(); // optional

    });

    server.listen( "localhost", 8000, [=]( socket_t server ){
        console::log("server started at http://localhost:8000");
    });

}

More Examples here

Installing Nodepp

Clone The Repository

#!/usr/bin/env bash
git clone https://github.com/NodeppOfficial/nodepp ; cd nodepp

Create a main.cpp File

#!/usr/bin/env bash
touch main.cpp
#include <nodepp/nodepp.h>

using namespace nodepp;

void onMain() {
    console::log("Hello World!");
}

Build Your Code

#!/usr/bin/env bash
🐧: g++ -o main main.cpp -O3 -I ./include          ; ./main #(Linux)
πŸͺŸ: g++ -o main main.cpp -O3 -I ./include -lws2_32 ; ./main #(Windows)

Nodepp Supports Other Platforms Too

Projects made with NodePP

Check out some articles on Medium

Official Libraries for Nodepp

  • πŸ”—: ExpressPP -> Express equivalent for Nodepp
  • πŸ”—: ApifyPP -> Socket.io equivalent for Nodepp
  • πŸ”—: Bluetooth -> Bluetooth Port for Nodepp
  • πŸ”—: SerialPP -> Serial Port for Nodepp
  • πŸ”—: Argon2 -> Argon2 for Nodepp
  • πŸ”—: Torify -> HTTP|Ws over Tor
  • πŸ”—: NginxPP -> Reverse Proxy
  • πŸ”—: InputPP -> Fake Inputs
  • πŸ”—: XML -> XML for Nodepp
  • πŸ”—: JWT -> JSON Web Token
  • πŸ”—: NmapPP -> Scan IPs and Ports
  • πŸ”—: Redis -> Redis Client for Nodepp
  • πŸ”—: Sqlite -> Sqlite Client for Nodepp
  • πŸ”—: MariaDB -> MariaDB Client for Nodepp
  • πŸ”—: Postgres -> Postgres Client for Nodepp

Contribution

If you want to contribute to Nodepp, you are welcome to do so! You can contribute in several ways:

  • β˜• Buying me a Coffee
  • πŸ“’ Reporting bugs and issues
  • πŸ“ Improving the documentation
  • πŸ“Œ Adding new features or improving existing ones
  • πŸ§ͺ Writing tests and ensuring compatibility with different platforms
  • πŸ” Before submitting a pull request, make sure to read the contribution guidelines.

ko-fi

License

Nodepp is distributed under the MIT License. See the LICENSE file for more details.

About

A runtime for writing reliable asynchronous applications with C++. Provides I/O, networking, scheduling, timers, ...

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •