Code Monkey home page Code Monkey logo

imodeljs's Introduction

The iModel.js Library

Copyright © 2018 Bentley Systems, Incorporated. All rights reserved.

The iModel.js library is an open source library for creating and accessing iModels.

If you have questions, or want to contribute to iModel.js, see our Contributing guide.

About this Repository

This repository is a monorepo that holds the source code to several iModel.js npm packages. It is built using Rush.

See rush.json for the list of packages. These packages are described below:

  • package.json
    • Private, not published
    • Provides the npm scripts to work with this repository
  • core/bentley/package.json
    • Controls the version number and package dependencies for @bentley/bentleyjs-core
  • core/geometry/package.json
    • Controls the version number and package dependencies for @bentley/geometry-core
  • core/common/package.json
    • Controls the version number for @bentley/imodeljs-common
    • Controls the package dependencies for the source code in common to both the backend and frontend
  • core/backend/package.json
    • Controls the version number and package dependencies for @bentley/imodeljs-backend
  • core/clients/package.json
    • Controls the version number and package dependencies for @bentley/imodeljs-clients
  • core/frontend/package.json
    • Controls the version number and package dependencies for @bentley/imodeljs-frontend
  • core/i18n/package.json
    • Controls the version number and package dependencies for @bentley/imodeljs-i18n
  • core/ecschema-metadata
    • Comprehensive ECSchema library
  • example-code
    • Example code snippets are extracted from these packages
  • test-apps/simpleviewtest/package.json
    • Private, not published
    • Test application for graphics visualization
  • test-apps/testbed/package.json
    • Private, not published
    • Test application for frontend/backend interaction

Each package will have its own node_modules directory which will contain symbolic links to common dependencies managed by Rush.

Prerequisites

  • Git
  • Node: an installation of the latest security patch of Node 8.11.x. The Node installation also includes the npm package manager.
  • Rush: to install npm install -g @microsoft/rush
  • TypeScript: this is listed as a devDependency, so if you're building it from source, you will get it with rush install. Currently we're using version 3.0 of TypeScript.
  • Visual Studio Code: an optional dependency, but the repository structure is optimized for its use

Linux

You must install the following on a Linux computer before attempting to run imodeljs-backend:

  • libc++abi1

Build Instructions

  1. Clone repository (first time) with git clone or pull updates to the repository (subsequent times) with git pull
  2. Install dependencies: rush install
  3. Clean: rush clean
  4. Rebuild source: rush rebuild
  5. Run tests:
    • All tests: rush test
    • Core tests: npm test -s
    • UI tests: npm run test:ui -s
    • Presentation tests: npm run test:presentation -s

The -s option for npm is short for --silent which results in a less verbose command. That part of the command is optional depending on the desired verbosity level.

Note that all build instructions are designed to run from the imodeljs-core root directory. The above commands iterate and perform their action against each package in the monorepo.

For incremental builds, the rush build command can be used to only build packages that have changes versus rush rebuild which always rebuilds all packages.

Note that it is a good idea to rush install after each git pull as dependencies may have changed.

Source Code Edit Workflow

  1. Make source code changes
  2. Ensure unit tests pass when run locally: npm test -s
  3. Locally commit changes: git commit (or use the Visual Studio Code user interface)
  4. Repeat steps 1-3 until ready to push changes
  5. Add changelog entry (which could potentially cover several commits): rush change
  6. Follow prompts to enter a change description or press ENTER if the change does not warrant a changelog entry. If multiple packages have changed, multiple sets of prompts will be presented. If the changes are only to non-published packages (like testbed), then rush change will indicate that a changelog entry is not needed.
  7. Completing the rush change prompts will cause new changelog entry JSON files to be created.
  8. To keep the Git history clean, amend the prior commit using the Commit Staged (Amend) menu item in Visual Studio Code or use the command line: git commit --amend --no-edit
  9. Push changes

If using the command line, steps 5 through 9 above can be completed in one step by running rushchange.bat from the imodeljs-core root directory.

Note: The CI build will break if changes are pushed without running rush change. The fix will be to run rush change (as above) and push those changes as a separate commit.

Here is a sample changelog to demonstrate the level of detail expected.

Updating dependencies/devDependencies on packages within the monorepo

The version numbers of internal dependencies should not be manually edited. These will be automatically updated by the overall version bump workflow. Note that the packages are published by CI builds only.

Updating dependencies/devDependencies on packages external to monorepo

Use these instructions to update dependencies and devDependencies on external packages (ones that live outside of this monorepo).

  1. Edit the appropriate package.json file to update the semantic version range
  2. Run rush check to make sure that you are specifying consistent versions across the repository
  3. Run rush update to make sure the newer version of the module specified in #1 is installed

Other NPM Scripts

  1. Build TypeDoc documentation for all packages: rush docs
  2. Build TypeDoc documentation for a single package: cd core\backend and then npm run docs

The full list of npm scripts can be found in the root package.json file.

imodeljs's People

Contributors

williamkbentley avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.