User:Mandeeps708/gsoc proposal
Name: Mandeep Singh
IRC Nick: Mandeep_Singh
Blog: https://mandeep7.wordpress.com
GitHub Profile: https://github.com/mandeeps708
Brief Background Information
I am a final year B.Tech. student of Computer Science and Engineering at Guru Nanak Dev Engineering College, Ludhiana, India.
I have always been passionate about programming. My work on various open source projects is briefed below:
PyDrain- A project for automating drawing creation in DXF using dxfwrite library and calculating area of enclosed entities.
Civil Octave- This project is used for the Analysis of Dynamics of Structures.
Booking System: A Django based web-application for booking seminar halls.
I have experience of Image Processing using MATLAB.
Apart from this, I also have my profound interest in Web development and Shell Scripting. I did several mini projects for fun and learning.
For more details about my work, you may refer my GitHub account:
https://github.com/mandeeps708
My knowledge of various open source technologies expands over
Python
Shell scripting
Web Technologies (HTML, CSS, JS)
Frameworks: Django, meteor.js, Bootstrap
CGI (Common Gateway Interface)
Databases: MySQL and MongoDB
LaTeX, Doxygen
Git, IRC and basic development workflow etc.
Contents
Project Information
Project Title: The FreeCAD Plugin Installer
Brief Project Summary
My main idea is to implement a plugin manager for FreeCAD that will be used to install/remove/update plugins and other unofficial workbenches or modules and macros. Besides, this project will make the life of the FreeCAD developers, workbench authors as well as the end-user easier.
Detailed Project Description
Current Scenario
There are many plugins available for FreeCAD and developers are creating more. So the task for getting pull requests, managing and merging them becomes a tedious task. Quite similar is in the case of macros. And it also makes the code base of FreeCAD a bit more or like bloatware to be delivered to the end-user. Efforts have been done by the FreeCAD developers to separate the installation of plugins from the FreeCAD software itself.
One has to do manual work for getting plugins installed on their system to be able to use them. So this project considers the issue and tends to implement an universal plugin manager that will manage the plugins and it will include the following:
List all the plugins installed
Remove the installed plugins
Add new plugins locally/remotely
Plugin Compatibility Test
Update the plugins (basically git pull)
Enable/Disable the plugin
Adding Git support
Implementing Plugin details (identifier)
Package and dependencies resolver
As FreeCAD is having many workbenches/macros fully coded in Python so they can be imported, without any necessity of compilation. As the plugins authors have to go through the painful (and somewhat lengthy) process of Pull Request on GitHub to get their code reviewed and accepted. This project focuses on making the same process rather easier to get the plugins working at the user’s end, so that user can integrate designs modules into their projects as a plug-in with ease. So the main idea is to present a simple, intuitive and interactive user interface.
The problem with the existing system is that it’s currently using manual technique to get everything done i.e. it uses git submodules that have to be fetched manually every time a workbench/macro code is updated. Rather, it has to be automated.
Project Goals
Better User Interface: The main objective of the project is to helping the FreeCAD users to manage their plugins with simple user interface to make the overall user experience better. This product that will be delivered to the end user will include the UI such that he could manage the plugins with a few simple clicks.
'Implementation Process'
A menu item or a sub-item will be added to launch the plugin installer.
Then it will proceed to a new window (tabular based) which will show the plugins currently installed.
It can have a checkbox beside each plugin to select/deselect it.
There will be buttons like Enable/Disable, Remove (Uninstall) and Update etc. for plugins. After selecting a particular set of plugins, user will be able to click on a particular option (button) as specified above.
Here is a prototype for the same:
Getting list of installed workbenches and stored macros: To get the list of installed workbenches and created macros, we will first look for the specific plugin directory which will be different for different operating systems. As FreeCAD is a cross-platform application, we may use something like environment variables or as suggested by the mentors. After getting listed all the available plugins, the plugin installer will show the details of the plugin like description, purpose of the plugin and some other information.
Adding/Removing workbenches and macros: After getting the list of installed plugins, the user will be able to add new plugins according to his requirements. It will allow the user to provide a link to the Git hosted repository and install that directly. On the back-end, it will clone the repository and place it in the appropriate directory. If it’s planned to use a particular repository for hosting the plugins, then what we can have is to scan (fetch) for that repository and list down the plugins for the user to choose from and install from the installer itself. For this to be implemented, we can request the repository and can get the json response of the available plugins on the repository and which later on can be filtered with the installed plugins.
Plugin Compatibility Test: The plugin authors can be suggested to create a particular file i.e. a “plugin detail file”. This file would contain a specific version of requirements e.g. Python version needed, version of FreeCAD needed. Even if some dependency is missed in the plugin detail file, the plugin installer will be able to detect the plugin and perform some tests already laid down to check compatibility. For example, this test may include a module that will check for the Python version. One approach could be that the tester module can try executing the plugin sub-module and get to know if it’s compatible or not. If it’s found to be incompatible, then it should revert the installation or in simpler words delete the particular plugin directory.
The structure of the plugin directory may go like this. Suppose there is a main plugin directory i.e. /usr/lib/freecad/Mod/Plugins/ and it contains two plugins “Plugin1” and “Plugin2”. Then each plugin will have some sub-directories (like images) or files (python modules). The tree structure will look like following:
Plugins directory (/usr/lib/freecad/Mod/Plugins)
|
| - Plugin 1
| | - File1
| | - File2
| | - File3
| | - File 4
| | - Plugin detail file
|
| - Plugin 2
| | - Directory
| | - File1
| | - File2
| | - File 3
| | - Plugin detail file
Then the idea is to have a “Plugin detail file” that will reside in the plugin directory itself and will contain the following information:
Author Information
Plugin details like what the plugin is all about (description).
Path settings (like which file to load)
Dependencies details (like required Python and FreeCAD version) etc.
So this is the file that will be looked for by the plugin installer.
Updates: The user can set his preferences for the duration to check for updates for the already installed modules. As already described, the plugin installer will try connecting to the remote repository from where the plugins are to be fetched and check if it contains some updated code. If some update (git fetch) is detected, then the user may simply click on update and it will simply do the git pull.
Adding Git support: As discussed above, adding and updating plugins will be achieved using Git hosted repositories. So it will be essential to add Git support to make all those happen. On Linux and Mac, it’ll be pretty easier to set up git via some shell script. And for Windows, we can set up “git for Windows” (https://git-for-windows.github.io) with the standalone (or portable) installer and then create a batch (.bat) file for setting it up. As “git for Windows” includes a program named “Git BASH” that includes bash shell and later configuration can be done in it.
FreeCAD dependency tracking: It’s good to be considered that some plugins depends on other plugins to be able to work correctly. As already discussed above, the plugin author will have a “Plugin detail file” in the plugin directory. That file will include the list of dependencies that needs to be resolved first. We can incorporate something like pypi or a plugin manager like bower such that plugin’s dependencies can be manageable.
Milestones
Community Bonding Period
Having interaction on Mailing list and IRC.
Get to know the code of FreeCAD and try solving some existing issues to get better understanding of the code.
Seeing the scope where we can reuse the existing code in an efficient manner
23 May - 31 May
Understand the existing implementation of the plugin loader and Macro installer and reuse whatever is possible.
1 June - 7 June
Write prototype (Qt window with basic widgets like buttons and scroll) code to list all the plugins installed.
Discuss the implementation with Organisation and getting reviews.
8 June - 14 June
Integrating “Plugin detail list” with UI to implement “list all plugins” feature.
Get data from “Plugin detail list” and show in the UI window the information like Author detail, plugin purpose and description etc.
15 June - 20 June
Setup Git and its integration with FreeCAD.
- Making scripts for Linux and Mac (auto-detection of OS).
- Making batch file for downloading, installing on Windows and use Git Bash to set up.
Add new plugins remotely using Git remote repository link.
Setup UI to show the fetched available plugins from GitHub (or any remote Git hosted) repository.
21 June - 28 June
After getting the plugins listed on the UI, implementing the remove (Uninstall) plugins feature.
Testing and fixing found bugs
Documenting the code using Doxygen or any other recommended tool
Mid-term evaluation.
29 June - 7 July
Implementing keyboard shortcuts for launching Plugin installer.
Document the code.
Adding Macros support
8 July - 14 July
Plugin compatibility test
15 July - 21 July
Working on feature Enabling/Disabling the plugin.
Prototype code for Update the plugins (basically git pull).
22 July - 28 July
FreeCAD dependency tracking
Integrating with plugin detail file
Adding support for plugin manager
29 July - 7 August
Brush Up the UI of plugin installer.
Discuss about the security concerns if we get some extra extra time.
8 August-15 August
More testing and cleaning.
Writing user documentation for the project.
Time to make up for missed milestone (if any).
16 August - 24 August
Cleaning and Testing code.
Final Evaluation
Time Availability
I will be available 40 hours / week, if needed can spend more. No restriction of time.
Why FreeCAD?
I have always been fascinated by operating of CAD softwares. This project got my interest. It will provide me a great opportunity to work on a realistic project in collaboration with great experienced developers.
Why you?
I found myself fit for this project according to my skill set and interest. I am very passionate to explore and learn new things. I understood well the workflow of this project. I want to work for FreeCAD organisation to gain more experience and enhance my knowledge about CAD. I will also be actively contributing and maintaining the code even after GSoC.