npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@cparra/apex-reflection

v2.16.1

Published

Provides basic reflection for the Apex programming language.

Downloads

12,220

Readme

Apex Reflection

Provides basic reflection for the Apex programming language.

Installation

npm i @cparra/apex-reflection

Usage

This library exposes a single function that handles parsing the body of an Apex top level type (class, interface, or enum) and returns the result.

import {reflect} from '@cparra/apex-reflection';

const classBody = 'public with sharing class ExampleClass {}';
const response = reflect(classBody);

If you wish to parse an Apex type that comes from a file, you can read the file contents and use that as the source to reflect

import * as fs from 'fs';
import {reflect} from '@cparra/apex-reflection';

const path = './MyClass.cls';
const rawFile = fs.readFileSync(path);
const response = reflect(rawFile.toString());

The reflect function returns a ReflectionResult which contains either the results of the parsed Type (which will either be a ClassMirror, an InterfaceMirror or an EnumMirror) or a ParsingError if the passed in body was not parsed successfully, with a message indicating where the error occurred.

Contributing

Even though this library is exposed as a Node.js library, the project's source code is written in Dart. The source can be found in the lib/src directory.

The Dart source code is transpiled to JS by dart2js through the default grinder workflow within tool/grind.dart.

To generate the JS files first set up grinder locally by following that package's instructions through its pub.dev listing, and then you can simply run grind. That build takes care of combining the output with preamble/preamble.js to achieve compatibility with Node.js. The resulting file is js/apex-reflection-node/out.js.

Tests

Both the Dart source code and the JS output must be tested.

The Dart tests live in the test directory. The Dart source code must have unit tests testing each individual Dart file as well as end-to-end tests that verify the overall parsing functionality.

The JS tests live in js/apex-reflection-node/__tests__. These are end-to-end tests that ensure that the transpiled JS code is working as intended.

JSON serialization

The reflection operation outputs a JSON representation of the Apex type, which is then deserialized on the JS side to return typed objects.

Serialization is handled through the json_serializable package, which helps automatically create the round-trip code for serialization and de-serialization.

When changing any of the model classes with serialization support, to re-build the serialization code run

pub run build_runner build

Parsing

The parsing algorithm relies on using ANTLR4 and its Dart target. Currently dart2js is not able to transpile the source from the antrl4 library hosted in pub.dev, so we rely on a local copy that fixes the transpilation issues, which lives in lib/antrl4-4.9.2.

To generate the Antlr4 Apex output run:

antlr4 -Dlanguage=Dart lib/src/antlr/grammars/apex/ApexLexer.g4 lib/src/antlr/grammars/apex/ApexParser.g4 -o lib/src/antlr/lib/apex/

To generate the Antlr4 Apexdoc output run:

antlr4 -Dlanguage=Dart lib/src/antlr/grammars/apexdoc/ApexdocLexer.g4 lib/src/antlr/grammars/apexdoc/ApexdocParser.g4 -o lib/src/antlr/lib/apexdoc/

Typescript

This library provides its own TS type definition.