Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fbarresi/twincat.jsonextension

TwinCAT variables to and from json
https://github.com/fbarresi/twincat.jsonextension

beckhoff json twincat twincat-ads

Last synced: 3 months ago
JSON representation

TwinCAT variables to and from json

Awesome Lists containing this project

README

        

# TwinCAT.JsonExtension
TwinCAT variables to and from json

[![Build status](https://ci.appveyor.com/api/projects/status/4ggo35buwmno05u2/branch/master?svg=true)](https://ci.appveyor.com/project/fbarresi/twincat-jsonextension/branch/master)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/6286aa6bb6f2402fa4f7553d749a5a8a)](https://www.codacy.com/manual/fbarresi/TwinCAT.JsonExtension?utm_source=github.com&utm_medium=referral&utm_content=fbarresi/TwinCAT.JsonExtension&utm_campaign=Badge_Grade)
[![codecov](https://codecov.io/gh/fbarresi/TwinCAT.JsonExtension/branch/master/graph/badge.svg)](https://codecov.io/gh/fbarresi/TwinCAT.JsonExtension)
![Licence](https://img.shields.io/github/license/fbarresi/twincat.jsonextension.svg)
[![Nuget Version](https://img.shields.io/nuget/v/TwinCAT.JsonExtension.svg)](https://www.nuget.org/packages/TwinCAT.JsonExtension/)

Bring the power of Json.Net to TwinCAT

Tranform DUTs decorated with the _custom_ **Json-Attribute** like this:

```reStructuredText
TYPE JsonDUT :
STRUCT
{attribute 'json' := 'message'}
sMessage : STRING := 'test';
iResponse : INT;
{attribute 'json' := 'status'}
sStatus : STRING := 'success';
{attribute 'json' := 'numbers'}
daNumbers : ARRAY[1..3] OF DINT := [1,2,3];
END_STRUCT
END_TYPE
```

into this (and back) **recursively** and absolutely **type-independent**:

```javascript
{
"message": "test",
"status" : "success",
"numbers" : [1,2,3]
}
```

only calling this two extension methods on your connected `AdsClient`:
```csharp
var json = await client.ReadJson("GVL.JsonDutVariable")
```

```csharp
await client.WriteJson("GVL.JsonDutVariable", json);
```

### Options
#### Progress indication
For lengthy operations, a progress indiciator can be used to give some feedback about the current progress. By passing a `Progress` object as parameter to `ReadJson` or `WriteJson` it is possible to count the total number of primitive types (INT, DINT, REAL, ...) that were read or written to the PLC, respectively.

```csharp
int objects = 0;
var progress = new Progress();
progress.ProgressChanged += (sender, args) => { objects++; Console.CursorLeft = 0; Console.Write(objects); };

Console.WriteLine("Primitives read from PLC");
await client.ReadJson("GVL.JsonDutVariable", progress: progress);

Console.WriteLine("\nPrimitives written to PLC");
await client.WriteJson("GVL.JsonDutVariable", json, progress: progress);
```

#### Enumeration stringify
Values of enumerations are by default started as integer values. However, sometimes it is beneficial to store said values as strings. This can be achieved by the `stringify` parameter.

```csharp
await client.ReadJson("GVL.JsonDutVariable", force: true, stringifyEnums: true);
```

#### Read/Write without json attribute
The attributes mentioned above are optional when using this library. The following example achieves a similar result. The only difference
is the instance names in the generated json file.

```reStructuredText
TYPE JsonDUT :
STRUCT
sMessage : STRING := 'test';
iResponse : INT;
sStatus : STRING := 'success';
daNumbers : ARRAY[1..3] OF DINT := [1,2,3];
END_STRUCT
END_TYPE
```
yields

```javascript
{
"sMessage": "test",
"iResponse" : 0,
"sStatus": "success",
"daNumbers" : [1,2,3]
}
```

by calling the ReadJsonAsync method on your connected `AdsClient`
```csharp
var json = await client.ReadJson("GVL.JsonDutVariable", force: true);
```

Have fun using this simple package and don't forget to **star this project**!

## Referenced projects

Would you like to see the power of **TwinCAT.JsonExtension** in action?

Then checkout [BeckhoffHttpClient](https://github.com/fbarresi/BeckhoffHttpClient), an _unofficial_ TwinCAT function for HTTP requests

or

[TwincatAdsTool](https://github.com/fbarresi/TwincatAdsTool) your swiss knife for twincat development.

## Credits

Special thanks to [JetBrains](https://www.jetbrains.com/?from=TwinCAT.JsonExtension) for supporting this open source project.