Skip to main content

Executable Shlaer-Mellor Class Model Parser

Project description

Executable Class Model Parser

Parses an *.xcm file (Executable Class Model) to yield an abstract syntax tree using python named tuples

Why you need this

You need to process an *.xcm file in preparation for populating a database or some other purpose

Installation

Create or use a python 3.11+ environment. Then

% pip install xcm-parser

At this point you can invoke the parser via the command line or from your python script.

From your python script

You need this import statement at a minimum:

from xcm-parser.parser import ClassModelParser

You can then specify a path as shown:

result = ClassModelParser.parse_file(file_input=path_to_file, debug=False)

In either case, result will be a list of parsed class model elements. You may find the header of the visitor.py file helpful in interpreting these results.

From the command line

This is not the intended usage scenario, but may be helpful for testing or exploration. Since the parser may generate some diagnostic info you may want to create a fresh working directory and cd into it first. From there...

% xcm elevator.xcm

The .xcm extension is not necessary, but the file must contain xcm text. See this repository's wiki for more about the xcm language. The grammar is defined in the class_model.peg file. (if the link breaks after I do some update to the code, just browse through the code looking for the class_model.peg file, and let me know so I can fix it)

You can also specify a debug option like this:

% xcm elevator.xcm -D

This will create a scrall-diagnostics folder in your current working directory and deposite a coupel of PDFs defining the parse of both the class model grammar: class_model_tree.pdf and your supplied text: class_model.pdf.

You should also see a file named xcm-parser.log in a diagnostics directory within your working directory

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xcm_parser-0.2.6.tar.gz (12.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xcm_parser-0.2.6-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

Details for the file xcm_parser-0.2.6.tar.gz.

File metadata

  • Download URL: xcm_parser-0.2.6.tar.gz
  • Upload date:
  • Size: 12.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for xcm_parser-0.2.6.tar.gz
Algorithm Hash digest
SHA256 735562fb7094c263896b48ec7a3be352d96db6892c4f631bbfceee5cb328f1d8
MD5 454878fdab420fec232facaf7641508e
BLAKE2b-256 d53d5515d95b66149dfa85282a7e04aad097cfd3dc4a1b9e2bc3fdfc777a9af2

See more details on using hashes here.

File details

Details for the file xcm_parser-0.2.6-py3-none-any.whl.

File metadata

  • Download URL: xcm_parser-0.2.6-py3-none-any.whl
  • Upload date:
  • Size: 13.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for xcm_parser-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 4a1b0dfb9126ba65e87d9c097ea5ff9f8a75a149f8fbb4e06f6ba8ab16de4f5c
MD5 921431ccc8e92b37a1dc13bda245e70d
BLAKE2b-256 b0184f01472aed7583f70f6ed08fb9de0ad8e9c78d4136b673bb629fae3e1a8e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page