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

@subjektifylabs/subjektify-codegen

v0.0.41

Published

A core tool designed to facilitate the code generation process the Subjekt model.

Downloads

433

Readme

@subjektifylabs/subjektify-codegen

NPM Version

subjektify-codegen is a core package of the Subjektify toolkit, designed to facilitate code generation from the Subjekt model. This package provides tools and utilities to generate client, server, and smart contract code from Subjekt model files, ensuring a seamless and efficient development workflow.

Features

  • Code Generation: Generate client, server, and smart contract code from Subjekt model files (.subjekt or JSON).
  • Customizable Output: Support for various output formats and customization options to fit your project's needs.
  • Integration with Build Tools: Easily integrates with common build tools and CI/CD pipelines to automate the code generation process.

Installation

subjektify-codegen is already included in the subjektify package.

Tasks

npx subjektify codegen

Environment Extensions

The plugin adds a model object to the Subjektify Runtime Environment, containing both the AST model and the semantic model for the Subjekt files configured.

Usage

subjektify-codegen is configurable from the subjektify.config.(js|ts). Here’s a basic example of how to use subjektify-codegen to generate code from a Subjekt model:

import { SubjektifyConfig, CodeGenTarget, CodeGenLanguage } from "subjektify";

const config: SubjektifyConfig = {
  namespace: "my.namespace",
  version: "0.1.0",
  license: "MIT",
  codegen: [
    {
      target: CodeGenTarget.Client,
      language: CodeGenLanguage.TypeScript,
      outputDirectory: "generated/client",
    },
    {
      target: CodeGenTarget.Server,
      language: CodeGenLanguage.TypeScript,
      outputDirectory: "generated/server",
    },
    {
      target: CodeGenTarget.Contract,
      language: CodeGenLanguage.Solidity,
      outputDirectory: "generated/contracts",
    },
  ],
};

export default config;

How it Works

  1. Configuration Parsing: The code generation process begins by reading the subjektify.config.(js|ts) file to determine the specified code generation targets and settings.
  2. Model Loading: The Subjekt model is loaded and parsed from the configured sources.
  3. Code Generation: Based on the target and language specified in the configuration, the appropriate code generation strategy is applied:
    • Client Code: Generates client-side code (e.g., TypeScript or JavaScript).
    • Server Code: Generates server-side code (e.g., TypeScript or JavaScript with frameworks like Express).
    • Smart Contract Code: Generates smart contract code (e.g., Solidity).
  4. Output: The generated code is written to the specified outputDirectory, organized by target and language.