Skip to content
/ Orca Public
forked from unc-enap/Orca

Object-oriented Real-time Control and Acquisition

Notifications You must be signed in to change notification settings

varnerrl/Orca

 
 

Repository files navigation

Orca

I. Prerequisites

  • Orca relies heavily on the Cocoa frameworks, and will only compile and run on MacOS
  • You must install any needed drivers before hardware accesses will work
  • Openly available drivers are at svn://orca.physics.unc.edu/Drivers

II. Notes

III. Getting Started

  1. Obtaining the source code
  • If you do not plan to make changes to the source code, you can obtain a local copy of the code from a terminal with:
git clone https://github.com/unc-enap/Orca
  • Alternatively, you can launch a zip file download from the browser by selecting "Clone or download" from the URL.
  1. Building the source code

To launch the Xcode project builder and compile the code:

  • Point the finder to the base directory of the code
  • Double-click on Orca.xcodeproj
  • Alternatively, from a terminal: "open Orca.xcodeproj"
  • In the "Product" menu, select "Build"
  1. Running Orca
  • In the Xcode "Project" menu, select "Run"
  • By default, this will be in debug mode
  • To leave debug mode, select "Detach from Orca" in the "Debug" menu of Xcode
  • At this point Xcode can be closed
  • Once Orca is running, Ctrl-click on the Orca icon in the dock and select "Options->Keep in Dock"
  • To later launch the version of Orca just compiled, select the icon in the dock
  1. Updating Orca
  • To update Orca from a terminal, go to the base directory of the source code, then:
git pull
  • Then rebuild Orca from Xcode as above.
  • Alternatively, the "Source Control" menu in Xcode has a "Pull" option which will update the code from the selected source. The code must then be rebuilt in Xcode as above. The icon in the dock will launch the most recently compiled version.
  1. Orca notifications

To receive notifications when there are updates or other conversations related to the Orca code:

IV. Orca Development

  1. Creating a fork

If you plan to make changes to the source code, instead of obtaining the source directly from the main branch as above:

  • In a browser, log into your GitHub account
  • Then go to: https://github.com/unc-enap/Orca
  • Select the "Fork" icon in the top right
  • Now follow the directions as above except when cloning the code use
git clone https://github.com/YOUR_USERNAME/Orca
  1. Updating your fork

To update your local fork from the base directory of the source code in a terminal (the first step only has to be done once):

git remote add upstream https://gitbhub.com/unc-enap/Orca
git pull upstream master
  1. Committing changes

As you edit your local copy of the code, make commits early and often as they are ready and tested with:

git commit [...]

where the last part of the command is the path to a single file or a space separated list of files. For larger numbers of changed files, the -a flag can be used in place of the file list to commit all changes to tracked files.

This will automatically launch a text editor for you to enter a commit message. The code will not be committed until the message in the editor is saved and closed. To globally set the git editor of your choice, for say emacs: git config --global core.editor "emacs"

For short commit messages, you can add them to the command line:

git commit -m "Your message here." [...]
  1. Pushing changes

After you have made one or a series of commits, push the changes to your forked repository:

git push

Alternatively, you can conveniently pull, review, commit, and push changes using the Xcode "Source Control" menu.

  1. Creating a pull request

Now if you visit the URL for your repository in a browser, you will see your latest changes in the commit history. If your changes are tested and ready to be incorporated into the master branch of Orca, then you can submit a pull request. Before submitting a pull request, it is a good idea to update your fork and deal with any conflicts. Then, from the URL of your fork of Orca:

  • click on "New Pull Request"
  • set base repository to unc-enap/Orca
  • set the head repository to YOUR_USERNAME/Orca
  • compare the changes on the base branch you want to merge to against the branch you want to pull changes from
  • submit the pull request if the changes look good and there are no unresolved conflicts
  • to see the status of your pull request, choose the "Pull requests" tab at unc-enap/Orca
  • once your code is reviewed, the pull request may be accepted or changes will be suggested in the comments

V. Running the 32 bit Version

Beginning with Xcode 10 on MacOS 10.14, 32 bit applications are no longer supported. However, the older 32 bit version of Orca can be run prior to 10.15 by compiling with Xcode 9. The 32 bit version of Orca is available at https://github.com/unc-enap/Orca32.

Running the 32 bit version is no longer recommended unless required by your system. In general, only bug fixes will be implemented in the 32 bit version.

VI. Obsolete SVN Instructions

As mentioned above, the repository on the old svn server will no longer be updated, and the repository is read-only. Although it is not recommended, the out-of-date code can be obtained from the svn server.

To obtain the entire code base, drivers, etc from the svn server:

svn co svn://orca.physics.unc.edu

Note that on the svn server, Orca refers to the old 32 bit version while the git repository named Orca is the 64 bit version. If you only need the 32 bit version of Orca:

svn co svn://orca.physics.unc.edu/Orca

If you only need the 64 bit version of Orca:

svn co svn://orca.physics.unc.edu/Orca64

For the obsolete plugin:

svn co svn://orca.physics.unc.edu/OrcaPlugin

OrcaRoot is also available on GitHub. The version here will no longer be updated:

svn co svn://orca.physics.unc.edu/OrcaRoot

About

Object-oriented Real-time Control and Acquisition

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Objective-C 90.4%
  • C 4.7%
  • C++ 4.4%
  • Java 0.1%
  • Shell 0.1%
  • Makefile 0.1%
  • Other 0.2%