Skip to content

Dpdl (Dynamic Packet Definition Language) is a rapid development programming language and constrained device framework with built-in database technology. Dpdl enables access to java platform API's and Native libraries and allows the embedding and execution of multiple programming languages (C, C++, Python, etc...) directly within Dpdl code

Notifications You must be signed in to change notification settings

Dpdl-io/DpdlEngine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Dynamic Packet Definition Language

			  www.dpdl.io

developed by SEE Solutions © 2003

Dpdl - rapid development programming language and constrained device framework

Dpdl is a rapid development programming language and constrained device framework with built-in database technology.

Dpdl enables access to java platform API's, Native shared libraries, Wasm modules and GPU compute and allows to embed and execute on-the-fly of multiple programming languages like ANSI C, C++, Python & MicroPython, Julia, JavaScript, Lua, Ruby, Java, PHP, Wgsl, Groovy and Clojure directly embedded within Dpdl code. Everything comes already included with the DpdlEngine, No additional installations needed.

The Dpdl language constructs and syntax is kept simple and follows an object oriented paradigm interoperable with the java platform JRE API and external java libraries and provides a simple access also to native libraries.

The core Dpdl engine can also be run on very small memory footprint devices via a dedicated kilobyte range virtual machine.

Dpdl is Self contained, Portable and Highly customizable via an extensible interface.

Dpdl = ( Java Api's + C + 'C++' + Python + Julia + JavaScript + Java + Lua + Ruby + PHP + Groovy + Clojure + Wat/Wasm + Wgsl + AI) = Powerful and Versatile

Custom code and syntax interpreters can be implemented and integrated in form of 'Dpdl language plug-ins'. In this way further code execution engines can be added as extensions and embedded via a dedicated interface and configuration.

This allows developers to easily create custom syntax and language interpreters of all sorts. For example the ROOT C++ Data Analysis framework from Cern is also available as Dpdl language plug-in.

The included 'DpdlAINerd' Dpdl language plug-in (DAN) enables also to automatically generate via AI generative code programming language code and content or data and embed it automatically directly within Dpdl code, which can than be executed right away.

The 'DpdlPacket' data container provides a convenient way to package and handle data efficiently on memory scarce devices.

Dpdl is designed to:

* Develop your ideas faster

* On multiple platforms

* Using the power of multiple programming languages and API's within single source

* Reuse code

* No need to install, compile and configure environments

* Runs on constrained devices

* Compressing, querying and handling data efficiently on constrained devices

* Self-contained, No additional dependencies required (except add-on libraries)

* Facilitate rapid prototyping for hardware programming

* Support for IoT protocols such as Bluetooth(tm) and CoAP

* Plug-in oriented

* Leverage prototyping with built-in AI generative code plug-in

DpdlEngine stack overview

Dpdl is designed to be Compact, Robust, Extensible and Portable to almost every platform

Common IoT protocol stacks such as Bluetooth(tm) and CoAP (Constrained Application Protocol) are integrated by default and other third party libraries and protocols can be added as extensions.

The included Dpdl language plug-in 'DpdlAINerd' (DAN) makes use of AI generative code to automatically generate and embed executable code and content or data by natural language descriptions contained inside Dpdl code.

Dpdl enables integration of different technologies to leverage fast prototyping and foster research and development.

Features

  • DpdlEngine is optimized to run on a wide range of platforms (JavaME, J2SE, any all VMs >= 1.4 Spec). The core engine runs also on Java 1.1 spec compliant VMs. This makes it possible to run Dpdl also on very small footprint Virtual Machines (eg. JamVM, miniJVM, and others).
  • Dpdl API provides access to the complete underlying Java JRE platform API's and to external java and Native shared libraries
  • Multiple 'Dpdl language plug-ins' available (embeddable programming languages): C, C++, Python, MicroPython, Julia, JavaScript, Lua , Ruby, Java, PHP, Groovy and Clojure programming languages can be embedded and executed directly within Dpdl code (interpreted/compiled code)
  • No additional installations required (except add-on libraries)
  • Further programming languages and syntax interpreters can be embedded via a dedicated kernel execution interface in form of plug-ins (see 'DpdlCustom' tag in DpdlEngine.ini)
  • Includes embedded C compiler: On-the-fly compilation of embedded ANSI C code in memory at runtime (for different targets: i386, x86_64, RISC-V, ARM and TMS320C67xx) -> very Fast compile time!!!
  • Wasm runtime Dpdl language plug-in included allows to access 'Wasm' module functions from Dpdl and from embedded language code. Also WAT code can be directly compiled on-the-fly and executed.
  • Built-in Dpdl scripting engine with support for custom extensions -> allows to dynamically add language features at runtime
  • Dpdl C API enables to execute Dpdl code embedded within programs written in C
  • On the fly conversion/compilation of Dpdl types 'class' and 'struct' into native java bytecode classes
  • Support for common IoT protocol stacks such as Bluetooth(tm) (JSR-82) and CoAP (Constrained Application Protocol) (IETF standard RFC 7252)
  • Packing data in a 'DpdlPacket' is a convenient way to optimize and speedup access to data. The speedup is x 25 times faster compared to a standard record store access
  • Virtual record store filesystem
  • Double precision floating point emulation
  • XML with XPath parser
  • JSON
  • Easy integration of custom libraries
  • Small footprint, Only 372 Kb for DpdlEngine -> can be stripped down to 80 Kb for minimal setup
  • Allows to automatically generate and embed generative AI programming code within Dpdl using the 'DpdlAINerd' (DAN) Dpdl language plug-in
  • Allows to scale computations on GPUs using the 'Wgsl' Dpdl language plug-in (WebGPU shading language)
  • Open Source programming language plug-ins

Dpdl comes with a very compact and portable execution engine with an extensible API interface to foster research and development of applications, and is suitable also for Hardware programming.

Dpdl enables to combine the portability and vast API availability of Java and Python, the computational power of Julia, the expressiveness of Lua and Clojure, the simplicity of Ruby and Groovy, the web-enablement of JavaScript and WebAssembly (Wasm), the power of C/C++ programming language and provides a simple access to java Api's, Native shared libraries, Wasm modules and GPU compute.

Further, Dpdl can be used to encode, store, control and query data efficiently also on small memory footprint devices via a custom data container referred to as 'DpdlPacket'. A DpdlPacket is a structured, highly compressed packet of data which can be managed and queried very efficiently on memory scarce devices. A DpdlPacket may may also include Dpdl code for custom setups.

These features make Dpdl a powerful development platform for rapid development, in particular also due to the fact that software written with Dpdl will be enabled to access thousands of existing high-quality software libraries.

Small Memory footprint:

  • DpdlEngine core (Minimal configuration) 80 Kb

  • DpdlEngine (Full configuration) 372 Kb

  • DpdlNative library (includes embedded C Interpreter and Compiler) 278 Kb

  • TOTAL SIZE of DpdlEngine (Dpdl Full configuration with embedded C compiler/interpreter) = 650 Kb

The size of the DpdlEngine core can be stripped down even further by excluding certain functionalities.

Quick Links

Documentation

Dpdl Documentation

Dpdl API Documentation

Dpdl language plug-ins

Dpdl embedded minimal C library Documentation

Dpdl compiler documentation

Dpdl Native Interface

Dpdl Wasm runtime

Dpdl Wgsl on GPU

DpdlClient

DpdlPacket

DpdlAINerd

More...

Dpdl Examples

Dpdl HowTo's

Dpdl Tutorials

Dpdl sample code

Sample Dpdl code that makes use of embedded 'Groovy' code to read a file line by line and print it to the console

println("reading a file line by line using embedded 'Groovy' code...")

dpdl_stack_push("./Test/see_solutions.html")
>>groovy

def dpdl_main(Object[] param, Object var_map){
	String myfile = (String)param[0];
	new File(myfile).eachLine { line ->
	  println line
	}
	return 1;
}

<<
int exit_code = dpdl_exit_code()

println("embedded groovy exit code: " + exit_code)

Below you can find a more complex example of how Dpdl can be used to accomplish even complex tasks:

Sample Dpdl code (GELU neural network activation function the runs on GPUs using embedded 'Wgsl' code):

import('native')

# main
println("testing Wgsl algorithm on GPU...")

println("loading native libraries 'c' and 'dpdlgpu'...")

object libc = native.loadLib("c")

object libgpu = native.loadLib("dpdlgpu")

raise(libgpu, "Error in loading 'dpdlgpu' lib")

println("getting dpdlgpu lib version...")

string ver = libgpu.DPDLNATIVE_GPU_getVersion()

println("version: " + ver)

# we allocate a data buffer with 10000 entries
long DATA_SIZE = 10000L
long byte_cnt = 4L

# indexes of the tensors & kernel created
int idx_tensor_in = 1
int idx_tensor_out = 1
int idx_kernel = 1

println("allocating input buffer...")

object input_arr = libc.malloc(DATA_SIZE * byte_cnt)
input_arr.setMemory(0L, DATA_SIZE * byte_cnt, 0x00)

object output_arr = libc.malloc(DATA_SIZE * byte_cnt)
input_arr.setMemory(0L, DATA_SIZE * byte_cnt, 0x00)

println("populating input data...")

long cnt = 0L
float f_val
int tmp
for(cnt < DATA_SIZE)
	tmp = randInt(16, 1000)
	f_val = to_float(tmp)

	input_arr.setFloat(cnt, f_val)

	cnt = cnt+1L
endfor

int status_in = libgpu.DPDLNATIVE_GPU_createTensorInputS1x1(idx_tensor_in, "f32", DATA_SIZE, input_arr)
int status_out =  libgpu.DPDLNATIVE_GPU_createTensorOutputS1x1(idx_tensor_out, "f32", DATA_SIZE)


dpdl_stack_var_put("precision", "f32")
dpdl_stack_var_put("workgroup_size", "256, 1, 1")

dpdl_stack_push("dpdl:applyvars")

>>wgsl
const SCALE_FACTOR: f32 = 0.7978845608028654; // sqrt(2.0 / Math.PI)

@group(0) @binding(0) var<storage, read_write> inp: array<{{precision}}>;
@group(0) @binding(1) var<storage, read_write> out: array<{{precision}}>;

@compute @workgroup_size({{workgroup_size}})
fn main(
    @builtin(global_invocation_id) GlobalInvocationID: vec3<u32>) {
    let i: u32 = GlobalInvocationID.x;
    if (i < arrayLength(&inp)) {
        let x: f32 = inp[i];
        out[i] = select(0.5 * x * (1.0 + tanh(SCALE_FACTOR
                 * (x + .044715 * x * x * x))), x, x > 10.0);
    }
}
<<
int exit_code = dpdl_exit_code()

println("Wgsl exit code: " + exit_code)

int status_kernel = libgpu.DPDLNATIVE_GPU_createKernelS1x1(idx_kernel, idx_tensor_in, idx_tensor_out, DATA_SIZE)

int status_dispatch = libgpu.DPDLNATIVE_GPU_dispatchKernel(idx_kernel)

int wait_copy = libgpu.DPDLNATIVE_GPU_waitCopyCPU(idx_kernel, idx_tensor_out, output_arr, DATA_SIZE)

println("OUTPUT: ")

float f_val_in, f_val_out
long c = 0L
for(c < DATA_SIZE)
	f_val_in = input_arr.getFloat(c)
	f_val_out = output_arr.getFloat(c)

	println(f_val_in + "=" + f_val_out)

	c = c+1L
endfor

println("finished")

Full featured sample Prototype Applications developed with Dpdl

In this GitHub repository you can find full featured working prototype applications written with Dpdl:

Dpdl-sample-Apps

Dpdl example to Get and decode News via http in JSON format

This is a small sample app written with Dpdl that gets the top 10 news stories via http in 'json' format:

app/getnews/dpdlGetNews.h

Dpdl implementation of SHA-1 hash algorithm

Implementation of SHA-1 hash algorithm entirely written in Dpdl

app/dpdlSHA-1/dpdlSHA-1impl.h

Dpdl example using external java libraries

This is a 3D model visualization of chemical molecules (in this case hydrogen) using the JavaFX library. The model can be rotated freely with mouse events (ported to Dpdl from javafx examples)

graphics/dpdl3DJavaFX_molecule.h

VIDEO of Dpdl sample 3D application

Simple Dpdl example that executes an embedded 'java' code and an embedded 'C' code directly within Dpdl

app/simple/dpdlSimpleJavaAndC.h

Dpdl example that uses the 'sql' Dpdl language plug-in to retrieve data from a database and handle the result set

The Dpdl script connects to the database and performs a query, retrieves and prints out the result set, encodes the result set to a json string, and than decodes the json string to an object that can be accessed as a HashMap

sql/dpdlSqlExampleJson.h

Dpdl example that uses the 'Wgsl' Dpdl language plug-in to scale computations directly on GPU's

The Dpdl script implements a high-performing neural network activation function (GELU) on GPUs using the dpdl language plug-in 'Wgsl' that allows to embed and execute WGSL code (WebGPU Shading language) directly within Dpdl.

wgsl/dpdlWgslTest.h

More Dpdl Examples

You can find more Dpdl code snippet on the following page: Dpdl_Examples.md

Or full featured Applications written with Dpdl in the following repository:

Dpdl-sample-Apps

Why Dpdl?

Dpdl is suitable for rapid application development in various domains and can be used as embedded scripting engine for various applications, in particular also for development of applications on small memory footprint devices.

The main nature of Dpdl is for enabling rapid development, fast prototyping, code reuse and allow a high degree of portability while being simple, extensible and compact. Further, developers can benefit from the possibility to use multiple programming languages due to the fact that a vaster set of APIs are available for a given platform.

Dpdl has also built-in constructs that enable dynamic code generation for generative AI code and provides a dedicated plug-in interface for developing and embedding custom language interpreter plug-ins of all sorts.

The DpdlPacket data container is a highly optimized way to store, query and access data on devices that have limited memory and storage capabilities.

The AI Dpdl language plug-in 'DpdlAINerd' (DAN) can be used to speed-up the prototyping and development process by leveraging generative AI code for embedded code and data within Dpdl.

Dpdl can be used as:

  • Rapid application development platform
  • Embedded scripting engine
  • Library module
  • Utility tool
  • Data handling on memory constrained devices
  • Development of Domain Specific Languages (DSL)
  • Generative AI code

Access to the complete Java platform JRE API's and external java libraries

The Dpdl API allows to access all classes and methods of the underlying Java Platform (JRE) and of any external java library.

Example: using a java HashMap (which interfaces to java.util.HashMap)

object map, s

map=loadObj("HashMap")
map.put(1,"Dpdl")
map.put(2,"Packet")
map.put(3,"Definition")
map.put(4,"Language")

s=map.get(1)
println(s)
s=map.get(4)
println(s)

Iterate over the obove HashMap using the same objects and methods as provided by the java API:

object es = map.entrySet()
object iter = es.iterator()
object ep
while(iter.hasNext())
	ep = iter.next()
	println("key=" + ep.getKey() + " value=" + ep.getValue())
endwhile

In this way all java libraries defined in class definition configuration file can be loaded and accessed in Dpdl.

The default configuration currently includes Java Platform API, the JavaFX API and bluecove Bluetooth JSR-82.

The default configuration can be easily extended or updated to resolve additional java APIs by editing the class definition configuration file.

Dpdl Java API's access documentation (default configuration)

The default set of classes accessible with Dpdl is defined to be the following set. Additional classes and API's can be added by means of a simple configuration.

The methods of the classes that are accessible are referred to the current JRE instance on which Dpdl is running.

Java API

JavaFX API

Bluetooth JSR-82 API

It's worth mentioning here that 'Java' code can also be embedded directly within Dpdl as described below.

Here just a quick example:

println("Dpdl can also embed native java code...")

object mystr = loadObj("String", "this is a Dpdl object mapped to java api, a str parameter")
int x = 23

dpdl_stack_push(mystr, "./Test/TestRead.txt", x)

>>java

System.out.println("Parameters: ");
System.out.println("	arg0: " + arg0);
System.out.println("	arg1: " + arg1);
System.out.println("	arg2: " + arg2);

static void myMethod1(){
	System.out.println("myMethod1: " + 1);
}

myMethod1();

for(int x = 0; x < arg2; x++){
	System.out.println("x: " + x);
}

File myfile = new File(arg1);

return 1;
<<
int exit_code = dpdl_exit_code()
println("embedded java exit code: " + exit_code)

Dpdl embeddable programming languages (Dpdl language plug-ins)

Multiple programming languages can be embedded and executed within the same Dpdl code via the keyword >>.

Further programming languages can be developed and integrated via a dedicated plug-in interface and configuration if form of Dpdl language plug-ins.

This enables basically every sort of programming language or natural language interpreter to be embedded directly in Dpdl code.

This features is very useful for rapid development and rapid prototyping and is also a key feature for generative code.

Currently the following programming languages can be embedded within Dpdl:

  • C interpreted code (minimal subset of C90 with standard C libs included)
  • C compiled code (almost full ISO C99 standard) compiled in memory and dynamically executed at runtime (see 'dpdl:compile')
  • Python
  • MicroPython (ideal for embedded systems)
  • Julia
  • JavaScript
  • Lua
  • Ruby
  • OCaml
  • Java
  • Groovy
  • Clojure
  • C++ (Root)

available Add-on 'Dpdl language plug-ins':

  • Wasm (WAT Compiler and Wasm Runtime)
  • Sql (query databases via SQL)
  • Wgsl (WebGPU shading language)
  • Ai -> see doc/DpdlAINerd.md

See this doc for more details: Dpdl_embedded_languages.md

Dpdl example with embedded 'C++' (Root) code

ROOT is a powerful Data Analysis Framework developed by CERN (https://root.cern/) .

ROOT C++ code can be embedded within Dpdl via the keyord >>root

Example Dpdl code embedding 'C++' (Root):

# main
println("test embedded ROOT C++...")

>>root
auto canvas = new TCanvas("c","Graph2D example",0,0,700,600);

double x, y, z, P = 6.;
int np = 200;
auto dt = new TGraph2D();
auto r = new TRandom();
for (int N=0; N<np; N++) {
	x = 2*P*(r->Rndm(N))-P;
	y = 2*P*(r->Rndm(N))-P;
	z = (sin(x)/x)*(sin(y)/y)+0.2;
	dt->SetPoint(N,x,y,z);
}
dt->Draw("tri1 p0");
canvas->Modified(); canvas->Update();
<<

int exit_code = dpdl_exit_code()
println("embedded ROOT exit code: " + exit_code)

Dpdl with embedded C code

Dpdl allows the embedding and on-the-fly execution of ANSI C code directly within Dpdl code with the keyword >>c

The C code can be embedded with 2 different Modes:

  1. Interpreted code (Mode 1)
  2. Compiled code (Mode 2) -> in memory at runtime

Example Dpdl code with embedded C code (Mode 1 - interpreted):

# main
# starting with Dpdl, pushing parameters on the stack and embedding C code

println("testing embedded C code in Dpdl")

int n = 6
double x = 10.0
string a = "test"

dpdl_stack_push(n, x, a)

>>c
#include <stdio.h>

int dpdl_main(int argc, char **argv){
	printf("Hello C from Dpdl!\n");
	printf("\n");
	printf("num params: %d\n", argc);
	int cnt;
    for (cnt = 0; cnt < argc; cnt++){
        printf("	param %d: %s\n", cnt, argv[cnt]);
    }
    return 0;
}
<<
int exit_code = dpdl_exit_code()

println("embedded C exit code: " + exit_code);

# again Dpdl code...

object str = loadObj("String", "Dpdl embedded C")
bool b = str.contains("C")
println("Dpdl contains C: " + b)

Embedding other programming languages

Other programming languages or natural language interpreters can be easily integrated in Dpdl via a dedicated plug-in interface and configuration. Please feel free to suggest your opinion on the 'Discussion' section on the DpdlEngine GitHub repository

AI generative code with 'DpdlAINerd' (DAN) Dpdl language plug-in

The Dpdl language plug-in 'DpdlAINerd' (DAN) allows to generate and embed code via popular AI engine (eg. OpenAI, Google Vertex AI, CodePal etc..)

see doc for more info: doc/DpdlAINerd.md

Supported Platforms

Dpdl runs on a wide range of platforms and supports also a small footprint java virtual machine (miniJVM), released as open-source, that can be compiled for almost every platform as soon as an ANSI C compiler is available for the target platform.

Dpdl itself is compatible with:

  • Java ME CLDC & GCF (JSR 360)
  • Java ME Embedded Profile (JSR 361)
  • Java versions >= 1.4 and later
  • Java 1.1 - 1.3 (without 'loadObj' and 'getObj' methods)
  • All Platforms where the Open Source virtual machines 'JamVM' and 'miniJVM' can be compiled

DpdlEngine V1.0 has been tested on:

* MacOS aarch64
* Linux x86_64
* Raspberry PI 3 (armv7l)
* Windows 64-bit
* Android
* JavaME
* J2ME (MIDP 2.0)

Note: The 'DpdlEngine lite' release needs to be re-packaged for running on Android, JavaME and J2ME

Embedded programming language plug-ins - compatibility matrix

Currently the 'DpdlEngine' release supports and provides the following Dpdl language plug-ins compliant to the corresponding language implementation version.

(X + version) Supported

(*) available soon

Platform C (ANSI C99) Python Julia Js Clojure Lua C++ Ruby Java Groovy OCaml MicroPython
Linux (x86_64) X X v3.2 X v1.9.3 X X v1.12.0 X v5.4 X v6.28 * X X v5.0 X v4.01 v1.24.0
Mac OS X (aarch64) X X v3.12 X v1.9.3 X X v1.12.0 X v5.4 X v6.28 X 3.2.2 X X v5.0 X v4.01 v1.24.0
Raspberry PI 3 (armv7) X X v3.2 X v1.9.3 X X v1.12.0 X v5.4 * * X X v5.0 X v4.01 v1.24.0
Windows64 X * * X X v1.12.0 * * * X X v5.0 X v4.01 X

Add-on Dpdl language plug-ins - compatibility matrix

Platform Wasm Sql Wsgl AI
Linux x86_64 X X X X
Mac OS X (aarch64) X X X X
Raspberry PI 3 (armv7) * X * X
Windows64 * X * *

Documentation

The Dpdl framework and API documentation is available via the following links:

Dpdl Documentation

Dpdl API Documentation

Dpdl language plug-ins

Dpdl embedded minimal C library Documentation

Dpdl compiler documentation

Dpdl Wasm Runtime

DpdlClient

DpdlPacket

DpdlAINerd (DAN)

More...

Dpdl Examples

Dpdl HowTo's

Track Changes

Dpdl Java API Documentation (available only for the registered version of DpdlEngine)

Download

See 'Download' page for more details:

Download

Roadmap

Dpdl is currently developed by SEE Solutions and the following integrations has been defined:

  • Back-end compiler that compiles Dpdl code to native machine code for most target architectures.
  • DpdlEngine port to 'MicroEJ' platform
  • Dpdl-IDE and provide also plug-ins for popular IDEs (IntelliJ, eclipse, MSVS)

Embedding of 'Python' code

Python code can be embedded within Dpdl code by using the keyword >>python. MicroPython will also be supported as option in the coming release.

Example Dpdl code with embedded 'Python' code:

println("testing embedding python code")
println("")

>>python
languages = ['Dpdl', 'C', 'Python', 'Clojure']

for language in languages:
	print(language)
<<
println("")

int exit_code = dpdl_exit_code()

println("embedded python exit code: " + exit_code);

Embedding of 'Julia' code

Julia is a powerful and performant computational programming language (https://julialang.org)

Julia code can be embedded within Dpdl via the keyord >>julia

Example Dpdl code embedding 'Julia' that generates a Plot and saves the result as PDF file:

#main
println("Testing Plot data with Julia programming language...")

>>julia
using Plots

x = range(0, 10, length=100)
y1 = sin.(x)
y2 = cos.(x)
p = plot(x, [y1 y2])

savefig(p, "./Test/myplot.pdf")

dispose_status = @ccall dpdl_julia_dispose()::Int32
return 1
<<

int exit_code = dpdl_exit_code()
println("finished with exit code: " + exit_code)

NOTE: The native Dpdl library 'dpdljulia' needs to be downloaded and deployed separately (see Download section below)

Embedding of 'JavaScript' code

JavaScript is the ideal programming language for web applications as it's supported by all popular web browsers.

JavaScript code can be embedded within Dpdl via the keyword >>js or >>qjs

Dpdl allows the embedding of javascript with 2 different Modes:

  1. Using the 'QuickJS' javascript engine from Fabrice Bellard '>>qjs' (Suggested)
  2. Using the 'Nashorn' javascript engine embedded in the Java platform '>>js'

Example:

println("testing embedded qjs...")

dpdl_stack_push("my Hello Message!!!")
>>qjs

import { fib } from "./DpdlLibs/js/fib_module.js";

var a_message = "null";

console.log(scriptArgs)
console.log('Dpdl sends a message with QuickJS');

if(scriptArgs.length > 0){
	a_message = scriptArgs[0];
}
std.printf("Message = %s %d", a_message, 23);
console.log('');
console.log("fib(10)=", fib(10));
<<

int exit_code = dpdl_exit_code()
println("Dpdl qjs exited with exit code: " + exit_code)

QuickJS provides a powerful and complete API to interact with the javascript engine at low level. Custom native functions and objects can be implemented as shared libraries and loaded in javascript. You can find examples in the folder './DpdlLibs/js/'

Embedding of 'Lua' code

Lua code can be embedded within Dpdl code by using the keyword >>lua.

Example Dpdl code with embedded 'Lua' code:

println("testing embedding Lua within Dpdl....")

string buffer_key = "dpdlbuf_result"

dpdl_stack_push(buffer_key, "name", "Alexis", "surname", "Kunst")

>>lua
function doSomeAlg()
	local home_dir = os.getenv("HOME")
	print("user home: ", home_dir)
	
	local x = os.clock()
	    local s = 0
	    for i=1,100 do 
	    	s = s + i
	    	io.write(".")
	    end
	    print("")
	    print(string.format("elapsed time: %.2f\n", os.clock() - x))
end

function paramLen(T)
  local count = 0
  for _ in pairs(T) do count = count + 1 end
  return count
end

function dpdl_main(params)
	local num_params = paramLen(params)
	io.write("dpdl_main call with number of params: ")
	io.write(num_params)
	print()
	print("executing my embedded algorithm...")
	print("")
	doSomeAlg()
	print()
	print("returning param values in 'uppercase'")
	local tab_out = {numfields=1}
	for k,v in pairs(params) do
		tab_out.numfields = tab_out.numfields + 1
		tab_out[tostring(k)] = string.upper(tostring(v))
	end
	tab_out.numfields = tostring(tab_out.numfields)
	return tab_out
end
<<

int exit_code = dpdl_exit_code()

println("embedded lua exit code: " + exit_code)

string resp_buf = dpdl_stack_buf_get(buffer_key)
println("lua response buffer: ")
println(resp_buf)

Embedding 'SQL' for querying and retrieving results from a Database (JDBC compliant)

A dedicated Dpdl language plug-in allows to directly inject SQL statements and retrieve the result sets. Connection, query and packing the results are performed directly by the plug-in

Example Dpdl code with embedded 'SQL':

println("testing 'sql' queries with Dpdl...")

dpdl_stack_var_put("db_url", "jdbc:postgresql://127.0.0.1:5432/mytestdb")
dpdl_stack_var_put("db_user", "testuser")
dpdl_stack_var_put("db_pass", "189923")

dpdl_stack_push("dpdlbuf_res")

>>sql
	SELECT id, name, surname, email from mytable
<<

object result = dpdl_stack_obj_get("dpdlbuf_res")

raise(result, "Error: dpdl stack buffer is null")

int rs_size = result.size()

object id, name, surname, email

int c = 0
object entry
for(c < rs_size)
	println("-----------------------------------")
	entry = result.get(c)
	id = entry.get(0)
	name = entry.get(1)
	surname = entry.get(2)
	email = entry.get(3)

	println("id: " + id)
	println("name: " + name)
	println("surname: " + surname)
	println("e-mail: " + email)

	println("-----------------------------------")

	c=c+1

endfor

println("finished")

Dpdl Examples

Further Dpdl examples can be found on this page:

Dpdl_Examples.md

What is a DpdlPacket?

A DpdlPacket is a compact, highly compressed executable packet of data with built-in database technology that can be created based on a defined Dpdl code definition.

A DpdlPacket can than be allocated and queried efficiently via API interfaces available for Java and for the built-in Dpdl language.

In particular Dpdl is very efficient on J2ME and JavaME platforms and has a high degree of backward compatibility.

A DpdlPacket contains 1 - n chunks of compressed data that can be allocated, queried and deallocated when data is not used anymore.

All kind of data can be packed into a DpdlPacket.

DpdlPacket

DpdlPacket

Example DpdlPacket definition source file:

dpdl_PHONEBOOK.dpdlpkt

The 'DpdlEngine lite' release package includes an encoded DpdlPacket (dpdl_PHONEBOOK.dpdl) and the corresponding Dpdl code definition file used to encode the DpdlPacket.

Refer to the Dpdl_documentation for how to allocate, execute and perform queries on a DpdlPacket.

Example of DpdlPacket code definition (dpdl_PHONEBOOK.c)

call(dpdlInterpreter)
::module dpdl_PHONEBOOK
::module_SPEC 23452
::model 836
::dpdlVersion 1.0

OPTIONS {
    TARGET = CDC & CLDC
    KVM = 1.0
    ZIP = true
    CHECKSUM = true
    SIGNATURE = true
    ENCRYPTION(RSA) = false
}

#defineDpdlEncoding UTF-8

#defineDB phone_bz | ./Test/BolzanoPhone.csv | null null

#defineSQL query_ SELECT name, phoneNR, e-mail FROM phone_bz end

#defineProtocol-cHtml phonebook_visual phone_book.html

import extern SystemData

catch DPDL_Script OnInit() {
    import("dpdllib.h") nl
    println("OnInit()") nl
}

import virtual DATA none  {
        class BolzanoPhone volatile phonebook_visual {
              DATA::string const name;
              DATA::string using phoneNR;
              DATA::string using  e-mail;
              #defineGUI Default <PhoneBook>  <Enter name and surname:>
              
              catch DPDL_Script OnDecode() {
                 import("dpdllib.h") nl
                 import("dpdlRS.h") nl
                 println("OnDecode()") nl
                 string time = getTime() nl
                 println("storing access time..." + time) nl
                 int rs_id = createRS("AccessStats", AUTHMODE_ANY, dpdlTrue, dpdlTrue) nl
                 int rec_id = addRecord(rs_id, time) nl
                 int status = closeRS(rs_id) nl
                 println("done status: " + status) nl
              }
        }
}
#defineD BolzanoPhone source phone_bz SQL query {
                CHUNK entry [6];
                struct BTree DENSE_INDEX hashing *name
                entry.content { name , phoneNR , e-mail }
                entry.name TAG(0xef) const (string) = 20;
                entry.phoneNR TAG(0xefe) (string) = 15;
                entry.e-mail TAG(0xefee) (string) = 30;
}

This is an example Dpdl sript that show how a 'DpdlPacket' can be allocated and queried:

dpdlpacket/testDpdlDB2.h

The database technology in Dpdl has been developed since year 2003 when the first applications where developed for mobile devices.

It started with a BsC thesis by A.Costa:

Advanced database techniques in Dpdl : dynamic packet definition language ; a portable data protocol for small embedded systems

What is the DpdlClient console application?

The DpdlClient console application included in the 'DpdlEngine lite' release is a small console application that exposes some functionalities of Dpdl via a simple command line console. Dpdl code can be executed and DpdlPackets handled. The same functionalities can be accessed via the java or Dpdl API.

These are the console commands available:

Usage: 
 -l  List DpdlPackets installed
 -i  Install DpdlPacket
 -d  Uninstall DpdlPacket
 -la List DpdlPackets allocated
 -a  Allocate DpdlPacket
 -da Deallocate DpdlPacket
 -qp Query DpdlPacket
 -c Create DpdlPacket
 -libs  List Dpdl libraries
 -slib  Show library
 -api   List Dpdl API functions
 -exec  Type && Execute a Dpdl script, between <script>...  </script>
 -load  Load && Execute a Dpdl script file (relative path to./DpdlLibs/ eg. arraylistExample.h)
 -bench  Run a query benchmark test (on DpdlPacket dpdl_PHONEBOOK)
 -h  Help
 -q  quit

About

Dpdl (Dynamic Packet Definition Language) is a rapid development programming language and constrained device framework with built-in database technology. Dpdl enables access to java platform API's and Native libraries and allows the embedding and execution of multiple programming languages (C, C++, Python, etc...) directly within Dpdl code

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

Packages

No packages published