GithubHelp home page GithubHelp logo

ebrevdo / nirjas Goto Github PK

View Code? Open in Web Editor NEW

This project forked from fossology/nirjas

0.0 0.0 0.0 232 KB

A Python library to extract comments and source code out of your file(s).

License: GNU Lesser General Public License v2.1

Python 99.18% Dockerfile 0.82%

nirjas's Introduction

Nirjas ~ নির্যাস

A Python library for Comments and Source Code Extraction

✨ 🍰 ✨

python version Unit Tests status License LGPL-2.1 release Slack Channel stars

Description

A source code file usually contains various vital information such as license text, function/class documentation, code/logic explanation, etc in the form of comments (block & line).

Nirjas is a fully dedicated python library to extract the comments and source code out of your file(s). The extracted comments can be processed in various ways to detect licenses, generate documentation, process info, etc.

Apart from that the library serves you with all the required metadata about your Code, Comments and File(s)

Requirements

  • Python 3

Installing Python on Linux machines:

$ sudo apt-get install python3 python3-pip

For macOS and Windows, packages are available at Python.org

Supported Languages

We Support almost all the major programming languages. If you want any other language to be added, feel free to raise an issue.

The Languages we support till now:

  • C
  • C#
  • C++
  • CSS
  • Dart
  • Go
  • Haskell
  • HTML
  • Java
  • JavaScript
  • Julia
  • JSX
  • Kotlin
  • MATLAB
  • Perl
  • PHP
  • Python
  • R
  • Ruby
  • Rust
  • Scala
  • Scss
  • Shell
  • Swift
  • Sql
  • TypeScript
  • TSX

Installation

Install using pip

You’ll need to make sure you have pip available. You can check this by running:

pip --version

If you installed Python from source, with an installer from python.org, you should already have pip. If you’re on Linux and installed using your OS package manager, you may have to install pip separately.

Haven’t installed pip? Visit: https://pip.pypa.io/en/stable/installing/

Install the latest official release via pip. This is the best approach for most users. It will provide a stable version and are available for most platforms.

  • Update pip to the latest stable version
pip3 install --upgrade pip
  • Install Nirjas
pip3 install nirjas
  • Upgrading Nirjas

Upgrade already installed Nirjas library to the latest version from PyPI.

pip3 install --upgrade Nirjas

Install using source

If you are interested in contributing to Nirjas development, running the latest source code, or just like to build everything yourself, it is not difficult to install & build Nirjas from the source.

  • Fork the repo

  • Clone on your local system

git clone https://github.com/fossology/Nirjas.git
  • Change directory
cd Nirjas/
  • Install the package
pip3 install .

This will install Nirjas on your system.

  • Check if Nirjas is installed correctly or get help, Run:

    nirjas -h or nirjas --help

Docker image

Nirjas also hosts Docker images on Docker hub. They can be pulled using

docker pull fossology/nirjas:latest

To scan with Docker image, just mount the directory you want to analyze and pass the path as argument.

docker run --rm -v $(pwd):/opt/ fossology/nirjas:latest /opt/<file_to_analyze>

Example Usage

  • For help
nirjas -h
  • To extract comments from a single file
nirjas <path to file>
  • To extract strings which assigned to variables from a source code file (Not yet implemented)
nirjas <path to source code file>
  • To extract comments from all the files in directory/sub-directory
nirjas <path to directory>
  • To extract only source code (excludes commented part) out of a file
nirjas -i <target file> <new file name including extension>

or for default file generation (default file: source.txt)

nirjas -i <target file>

Tests

To run a test for Nirjas, execute the following script:

python3 testScript.py

This will download all the test files into nirjas/languages/tests/TestFiles folder and will run the tests as well.

Documentation

We maintain our entire documentation at GitHub wiki. Feel free to switch from code to wiki or just click here - Nirjas Documentation

Contributing

All contributions, bug reports, bug fixes, documentation improvements, enhancements, and ideas are welcome.

A detailed overview on how to contribute can be found in the contributing guide.

Feel free to ask questions or discuss suggestions on Slack

License

This repository is licensed under the terms of LGPL-2.1. Check the LICENSE file for more details.

nirjas's People

Contributors

hastagab avatar gmishx avatar kaushl2208 avatar soham4abc avatar aman-codes avatar ag4ums avatar its-sushant avatar aswinmurali-io avatar pombredanne avatar shub-garg avatar yoda-canada avatar aman1971 avatar ha36d 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.