@labzdjee/agc-util v1.6.6
AGC-UTIL
Agnostic utility to handle Protect-DC AGC configuration files
Anyone not aware of what a Protect-DC system is, should not be interested in using this
This library essentially builds an ECMAScript array composed of objects and structures made of pointers (line numbers, starting from one) to the AGC file contents and offers a means to query sub-parts of this array
Structure of an AGC File
This text file is composed of (key, value) pairs of this structure: {key} = "{value}"
Note: in this document, braces {} should not be taken literally, they denotes an entity inside which then should not be taken literally as well
Each such pair occupies one line (preferably cr/lf terminated, though this library doesn't care as it takes an array made of strings)
Also when reading this file is encoding should preferably be latin1
Any line which is blank (empty or only made of spaces and tabs) or starting with a pound sign # is ignored in the structure of the file
Types of (key, value) Pairs
Meta data: ${key} = "{value}"
Object/attribute: {object}.{attribute} = "{value}" or {object}.!{attribute} = "{value}" for read-only attributes
All other simple {key} = "{value}" pairs are considered plain data
Sections
An AGC file is made of a number of sections which have markers, except the first one which in considered the file header
Sections are framed by an opening line: ${sectionName} = "Start" and a closing line ${section} = "End"
First section comes before any other, has no opening and closing line
The following table enumerates those sections and what entities they support (no entity is compulsory and there is no limit in the number of instances of those entities)
| Section name | Section is optional | Allowed entities | 
|---|---|---|
| (header) | No | meta data | 
| GCAUConfigurationData | No | meta data, object-attribute | 
| GCAUCalibrationData | No | meta data, object-attribute | 
| BOM | Yes | meta data, data | 
| TestAdditionalTests | No | meta data, data | 
| SPReTPReOptions | No | meta data, data | 
| EquationAdditionals | Yes | meta data, data | 
| TestOperatorInterfaceResult | Yes | meta data, data | 
To be specific, BOM and EquationAdditionals have only been introduced later in the product lifetime and were absent in first versions. And TestOperatorInterfaceResult  is only present is archive AGC files (where test results in addition to configuration data have been inserted). it is also worth noting TestOperatorInterfaceResult section has issues and rule stating every value has to be surrounded with double-quotes is not always valid and parsing of this section is very lax regarding this
API
analyzeAgcFile(lines)
Analyze lines array of an AGC file and return an array of objects with the following structure:
- name: string, name of section
- startLine: number, line number of section start (inclusive)
- endLine: number, line number of section end (inclusive)
- metaTags: array of meta tags (tags starting with a- $sign) made of objects with the following structure:- name: string, name of meta tag (without initial \$ sign)
- value: string, value of meta tag
- line: number, line number where meta tag is located
 
- objects: array of objects with the following struct:- name: string, object name
- attributes: array of- attributeobjects with the following struct:- name: string, attribute name
- value: string, attribute value
- readOnly: boolean, true if attribute is read-only
- line: number, line number where attribute is located
 
 
- data: array of (key, value) pairs with the following struct:- name: string, the key
- value: string
 
If analyzed data are inconsistent this method will throw with the following error object:
- line: number, the line which triggered the error
- explicit: a message explaining the error
- category: a digram categorizing the error:- CS: unexpected closing section
- DA: duplicate attribute
- DS: duplicate section
- MC: missing closing section
- MS: missing section
- OS: unexpected opening section
- UK: unexpected key
- UL: unexpected line syntax
- UM: unexpected meta tag
- UO: unexpected object
 
Notes:
- first unnamed section is given special name "{Header}"
- line numbers are one-based (counting from 1)
- first unnamed section can only have metaTags
- only sections GCAUConfigurationDataandGCAUCalibrationDatacan have objects, but no data
- all other sections can have data but no objects
- in any case, metaTags, objects, and data are all optional and will be undefined if not found in section
- arraylinescan be easily be build bydata.split(/\r?\n/)provided byreadFilefunction for example (with alatin1encoding)
- from version 1.2, to address a legacy case, where a single metaTag $Notescan span over multiple lines,linesarray is preprocessed and if such a case is detected, this array undergoes a side effect (alteration):$Notesis expanded on as many lines as it is encountered, for example$Notes = "abc\ndef\ghi"(note the\nmeaning this expression occupies 3 lines) will be expanded as$Notes = "abc",$Notes = "def", and$Notes = "ghi"
- from version 1.4, some legacy peculiarities are also addressed: section $EquationAdditionalsoptional and metaTag$VLowLimitis unfortunately not properly closed with a double-quote for some obscure reason. When this unclosed case is metlinesarray is also altered: a closing double-quote is added
- from version 1.6, section $BOMbecomes optional as well to address primitive versions of this file
findInAgcFileStruct(searchHint, agcFileStruct)
Search a sub-object in agcFileStruct (as returned by function analyzeAgcFile), matching certain properties given in searchHint which is an object with the following properties:
- section: string, section (defauts to:- "GCAUConfigurationData")
- metaTag: string, return the array of metaTag objects defined by (- sectionand- metaTag)
- dataKey: string, return the array of data objects defined by (- sectionand- dataKey)
- object: string, if alone, return the object object defined by (- sectionand- object)
- object,- attribute: strings, return the attribute object defined by (- section,- object, and- attribute)
Notes:
- if metaTagis givenobjectandattributeare ignored
- if neither metaTagnorobjectare provided section object is returned
- when not found, nullis returned
- metaTagand- dataKeyare returned as an array because it is allowed to have multiple values for each entry key
Install and Use
Install:
npm install @labzdjee/agc-util --save
Use:
const { analyzeAgcFile, findInAgcFileStruct } = require("@labzdjee/agc-util");