This is the main repository for the source code of the Universal Algebra Calculator (UACalc).
For the GUI version of the program, please visit the UACalc webpage (uacalc.org).
Contents
In this section, we describe the quickest way to import and make use of UACalc Java libraries in your own programs. (The might be programs that you write in Java, or Scala, or any other language that runs on the JVM or otherwise allows importing of .jar files.)
Later sections will explain how to import the entire UACalc source code repository in an IDE like Eclipse or IntelliJ IDEA, which can be useful, but it is not necessary if your goal is to simply make use of some Java classes and methods defined in the UACalc library.
It's possible to write programs in Scala or Jython (and probably other languages that runs on the jvm) that import and make use of java packages that make up the UACalc. Here we show how to obtain the UACalc jar files and then give an example demonstrating how to use the jars and import UACalc packages into a Scala project using the IntelliJ Idea IDE. Something similar should work for other languages (e.g., Jython) in other IDEs (e.g., Eclipse).
-
Getting the jar files. There are two ways to do this. (You only need to do one of these---A or B, not both.)
-
A. Download precompiled jars.
If you just want pre-compiled (and possibly a bit out-of-date) versions of uacalc.jar and other jars, you can try invoking the following at the command line:wget http://uacalc.org/uacalc.jar
(If you don't have the
wget
program, then you could try pasting http://uacalc.org/uacalc.jar into the address field of your web browser; your browser should ask you where you want to save theuacalc.jar
file.)You can download other supporting jar files you might need from the links on this page, or copy and paste the following into a terminal on a computer that has the
wget
program installed:wget http://uacalc.org/download/designgridlayout-1.1p1.jar wget http://uacalc.org/download/groovy-all-1.0.jar wget http://uacalc.org/download/groovy-engine.jar wget http://uacalc.org/download/miglayout-3.7-swing.jar wget http://uacalc.org/download/swing-layout-1.0.2.jar
-
B. Roll your own.
Clone the uacalcsrc repository, e.g.,git clone git@github.com:UACalc/uacalcsrc.git
Compile the code (see these instructions for more info)
cd uacalcsrc ant dist
(You must install the
ant
program if you don't have it already; on an Ubuntu Linux box, dosudo apt install ant
)If the
ant dist
command above succeeds then all of the jar files should now be in the../dist/lib
directory.
-
TODO: insert example of importing and using the uacalc.jar file
The page is meant to provide some hints and advice about downloading, importing, browsing, and modifying the source code in the uacalcsrc repository. Much of it concerns the use of git and GitHub, and there are plenty of better sources for this information, such as the GitHub help pages.
The instructions below will require entering commands in a terminal
window with some sort of Unix style shell, like bash.
If you will be copying the repository to your local machine, these steps
assume the repository lives in a directory called ~/git/uacalcsrc
, so
this first command creates a ~/git
directory, if it doesn't already exists
(and does nothing if it does exist):
$ mkdir -p ~/git
If you merely want to browse the UACalc source code, you can do so using the GitHub webpages, or you can clone the repository to your local drive with a command like:
$ git clone git@github.com:UACalc/uacalcsrc.git ~/git/uacalcsrc
or
$ git clone https://github.com/UACalc/uacalcsrc.git ~/git/uacalcsrc
If you expect to contribute improvements to the source code, instead of cloning directly it is advisable to first fork the repository to your own GitHub account, and then clone your own fork. To do so, login to your GitHub account, navigate to the UACalc/uacalcsrc repository, then click the Fork link on the upper right. Once the fork is created, clone the forked repository to your local drive with a command like
$ git clone git@github.com:your-user-name/uacalcsrc.git ~/git/uacalcsrc
or
$ git clone https://github.com/your-user-name/uacalcsrc.git ~/git/uacalcsrc
Now you can modify the source code as you wish and then, if you want to recommend that your changes be incorporated into the main UACalc/uacalcsrc repository, you should follow these steps:
-
Commit your changes to your local repository (with an informative commit message!).
$ git commit -m "fixed a bug in the bar method of the Foo class"
-
Push the changes to your remote repository (i.e., to the fork you created above).
$ git push origin master
-
Create a pull request by navigating to your fork's GitHub page and clicking the
Pull Request
link (which appears next to a message like, "This branch is 1 commit ahead of UACalc:master").Be sure to include an informative comment justifying the recommendation to merge your changes into the main respository.
To keep your fork current with the main UACalc/uacalcsrc repository, see the section Updating your fork below.
There are a number of ways to import this repository into the Eclipse IDE or IntelliJ IDEA. One such method is described in this section.
If you plan to make improvements to the code and expect them to be considered for adoption in the main UACalc/uacalcsrc repository, please create your own fork of the repository, as explained in the section on contributing using fork.
Steps to import into Eclipse
-
First, clone the repository to your local drive. If you forked the repo as suggested above, then use a command like
git clone git@github.com:your-user-name/uacalcsrc.git ~/git/uacalcsrc
or
git clone https://github.com/your-user-name/uacalcsrc.git ~/git/uacalcsrc
If you didn't create your own fork, you can clone with the command
git clone https://github.com/UACalc/uacalcsrc.git ~/git/uacalcsrc
-
Launch Eclipse and use the File menu to import the source code:
File --> Import --> Git --> Projects from Git
then click Next.
-
Select
Local
, click Next, then click Add and browse to the directory where you clone the repository in Step 1 above (e.g., ~/git/uacalcsrc). -
Select the uacalcsrc repository and click Next.
-
Select the
Import existing project
radio button, click Next, and then select the algebra project and click finish.
Steps to import into IntelliJ IDEA
(This section is for users of the IntelliJ IDEA software. If you are using Eclipse, you can skip this section.)
-
Clone the
uacalcsrc
repository to your local drive as described above. -
Launch the IntelliJ IDEA program. At the main project browser/welcome window (with all other projects closed), select Import Project and locate the
uacalcsrc
directory that contains the repository you cloned in step 1. Select OK. -
In the "Import Project" dialog box, select "Import project from external model" and make sure Eclipse is highlighted in the list of external models.
-
Select Next two more times and, with "algebra" checkbox checked, click "Finish."
When improvements are made to the "upstream" UACalc/uacalcsrc repository, you will probably want to update your fork to incorporate these changes. Below is a list of the commands that accomplish this, but see this page and this page for more details.
-
Change to the working directory of your local copy of the repository and specify the upstream repository.
$ cd ~/git/uacalcsrc $ git remote add upstream git@github.com:UACalc/uacalcsrc.git
-
Verify that it worked.
$ git remote -v
The output should look something like this:
origin git@github.com:your-user-name/uacalcsrc.git (fetch) origin git@github.com:your-user-name/uacalcsrc.git (push) upstream git@github.com:UACalc/uacalcsrc.git (fetch) upstream git@github.com:UACalc/uacalcsrc.git (push)
If the foregoing fails, try
git remote add upstream https://github.com/UACalc/uacalcsrc.git
-
In the working directory of your local project, fetch the branches and their commits from the upstream repository and merge upstream/master into your local master branch.
git fetch upstream git checkout master git merge upstream/master
This brings your fork's master branch into sync with the upstream repository, without losing your local changes.
-
Finally, commit the changes and push to your remote fork.
git commit -m "merged changes from upstream" git push origin master
If you now visit the GitHub page for your fork's repo, it should show the message, "This branch is even with UACalc:master."
-
If there are other branches besides
master
that you want to update, repeat steps 4--6, replacingmaster
with another branch name.
If you think you found a bug in the calculator, if you encounter a problem with the instructions on this page, or if you have any other issue that you'd like to call attention to, please create a new issue.
This git repository was initially created on 2014 Nov 25 by importing Ralph Freese's uacalcsrc cvs repository from sourceforge using the following command:
git cvsimport -C ~/git/uacalcsrc -r cvs -k -v -d :pserver:anonymous@uacalc.cvs.sourceforge.net:/cvsroot/uacalc -A authorfile.txt uacalcsrc
Before issuing the above git cvsimport
command the git-cvs package must be
installed (e.g., sudo apt-get install git-cvs
)
General Notes
The authorfile.txt contains names and email addresses of authors who contributed to the cvs source tree. This is needed in order to preserve the contribution in the resulting git repo.
If you are using BibTeX, you can use the following BibTeX entry to cite UACalc:
@misc{UACalc,
author = {Ralph Freese and Emil Kiss and Matthew Valeriote},
title = {Universal {A}lgebra {C}alculator},
note = {Available at: {\verb+www.uacalc.org+}},
year = {2011},
}