OAC:Project: Difference between revisions

From Bohemia Interactive Community
(→‎# VII. How to improve the compatibility addon: added details on Follow SVN changes with trac timeline)
m (Added image icons for links to images.)
Line 267: Line 267:
'''3.''' Create a new MF (modfolder) named @OAC in your ArmA installation, like .\ArmA\@OAC\addons.
'''3.''' Create a new MF (modfolder) named @OAC in your ArmA installation, like .\ArmA\@OAC\addons.


'''4.''' RMB (Right mouse button) click on the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_checkout_dialog.jpg addons folder and select 'SVN Checkout'].
'''4.''' RMB (Right mouse button) click on the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_checkout_dialog.jpg addons folder and select 'SVN Checkout'] [[Image:Image icon.png|20 px]].


'''5.''' In the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_checkout_details.jpg checkout dialog] copy the following URL in the dialog as 'URL to repository (server)':<br>
'''5.''' In the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_checkout_details.jpg checkout dialog] [[Image:Image icon.png|20 px]] copy the following URL in the dialog as 'URL to repository (server)':<br>


  http://svn.assembla.com/svn/project-oac/addons/ofp_compatibility_addon
  http://svn.assembla.com/svn/project-oac/addons/ofp_compatibility_addon
Line 288: Line 288:
'''7.''' Select YES to create new folder. Click the OK button in the initial download (checkout) overview.
'''7.''' Select YES to create new folder. Click the OK button in the initial download (checkout) overview.


'''8.''' The result should look like on [http://www.proper.armaholic.eu/download/oac/images/oac_svn_checkout_done.jpg this image] with some files in the '''ofp_compatibility_addon''' folder and <br>little green icons.
'''8.''' The result should look like on [http://www.proper.armaholic.eu/download/oac/images/oac_svn_checkout_done.jpg this image] [[Image:Image icon.png|20 px]] with some files in the '''ofp_compatibility_addon''' folder and <br>little green icons.




Line 298: Line 298:
from the SVN server first.
from the SVN server first.


'''1.''' RMB click on the '''ofp_compatibility_addon folder''' and select [http://www.proper.armaholic.eu/download/oac/images/oac_svn_update_dialog.jpg SVN Update].
'''1.''' RMB click on the '''ofp_compatibility_addon folder''' and select [http://www.proper.armaholic.eu/download/oac/images/oac_svn_update_dialog.jpg SVN Update] [[Image:Image icon.png|20 px]].


'''2.''' The software will contact the SVN server and download updates if available. In case there were<br>
'''2.''' The software will contact the SVN server and download updates if available. In case there were<br>
updates by other people, you can see the list of changed files in the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_update_completed.jpg update dialog].
updates by other people, you can see the list of changed files in the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_update_completed.jpg update dialog] [[Image:Image icon.png|20 px]].


'''3.''' You can click on the '''Show log''' button to find out about the details to what has been changed.
'''3.''' You can click on the '''Show log''' button to find out about the details to what has been changed.


'''4.''' In the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_log.jpg Log messages] dialog, you can see the different updates.<br>
'''4.''' In the [http://www.proper.armaholic.eu/download/oac/images/oac_svn_log.jpg Log messages] [[Image:Image icon.png|20 px]] dialog, you can see the different updates.<br>
Each upload of any user, increments the 'revision number'. The revision number is global for the<br>
Each upload of any user, increments the 'revision number'. The revision number is global for the<br>
whole repository. So there is NO revision number for each file like in CVS.
whole repository. So there is NO revision number for each file like in CVS.
Line 315: Line 315:
summarize the changes of a revision for all the other people involved!
summarize the changes of a revision for all the other people involved!


If you RMB click on a file at the bottom, you can select '''Show changes''' to get a [http://www.proper.armaholic.eu/download/oac/images/oac_svn_diff.jpg new dialog] that<br>
If you RMB click on a file at the bottom, you can select '''Show changes''' to get a [http://www.proper.armaholic.eu/download/oac/images/oac_svn_diff.jpg new dialog] [[Image:Image icon.png|20 px]] that<br>
shows you the code changes from this one revision in detail.
shows you the code changes from this one revision in detail.


Line 332: Line 332:
====Upload changes to the server====
====Upload changes to the server====


[http://www.proper.armaholic.eu/download/oac/images/oac_svn_commit_option.jpg 1]
[http://www.proper.armaholic.eu/download/oac/images/oac_svn_commit_option.jpg 1] [[Image:Image icon.png|20 px]]


[http://www.proper.armaholic.eu/download/oac/images/oac_svn_commit_dialog.jpg 2]
[http://www.proper.armaholic.eu/download/oac/images/oac_svn_commit_dialog.jpg 2] [[Image:Image icon.png|20 px]]


[http://www.proper.armaholic.eu/download/oac/images/oac_svn_diff.jpg 3]
[http://www.proper.armaholic.eu/download/oac/images/oac_svn_diff.jpg 3] [[Image:Image icon.png|20 px]]





Revision as of 12:36, 18 July 2008

File:MISSING Banner

by the OAC Project Team


Project info

Welcome to the OAC project - OFP ArmA Conversion.


Hosted by

Our earnest thanks to the armaholic team for hosting our page and projects!

Our earnest thanks to russin for hosting the OAC FTP server!

Our earnest thanks to Sickboy and the 6thSense community for hosting the OAC mantis!

  • Build scripts hosted by MISSING

Our earnest thanks to russin for hosting the OAC YomaTools server!

Purpose of this project

  • Playable content. Now. Much. Enjoyable. Good quality.
  • In the form of: Get any OFP missions or campaigns playable in ArmA with little or no
    modification of the mission file.
  • Possibility to use community made addons alongside to improve the visual aspects,
    sounds or gameplay.
  • Easy access to the content.
  • Automated update and delivery system.
  • Open system, focus on compatibility with community addons and MODs.
  • Open source project - every can contribute very easily.

NOT the purpose

  • Make custom models, textures, sounds.
  • Change the gameplay itself.

Relation to CWR

The goal from CWR is to recreate the whole OFP CWC experience.

The OAC project will be compatible to CWR and if it makes it possible to run any OFP mission with CWR.
So OAC can act as an supplement to CWR.
Project OAC uses plain ArmA as a base for models, sounds and graphics.

CWR and OAC will share their development progress of the CWC single player campaign.
In addition to that both will work closely together on the config part to ensure full compatibility.

Up until today the major difference between both is that OAC is aiming for open development, easy
contribution and iterative development with as many releases as possible whereas CWR relies on few
releases to ensure top quality from the start.

How does it work

You cannot run OFP missions or campaigns in ArmA for a few technical reasons.
Actually it is quite simple to solve these.

Foremost it is about the missing units (classes).
The other problem is that the script syntax change a bit from OFP to ArmA
(strict string-code requirement).


The solution.

For the first problem only a simple compatibility addon is needed the maps the missing classes
to existing ArmA classes.
With a few simple config tricks it also auto embeds models missing in plain ArmA like the
Bradley if the community addon is loaded alongside.

For the CWC and Res campaign and mission a few additional content addons come
along that contain the music, speech files and similar content.

Now this approach is not limited to BI content, yet the starting version also
allows to load WGL5 missions or campaign conversions and it is easily expandable
to virtually any other OFP addon or MOD.


Most missions that do not involve much scripting can already be loaded with only the
compatibility addon.

For missions that do not work out of the box there is an almost completely
automated process to convert any mission to ArmA scripting standards in a few seconds.
The process already works very well, yet it is easily expandable if necessary.

Last very rare and 'complicated' problems can easily be fixed by hand by any fair scripter.

More technical details below.

Open source project

The basic idea is that everything is easily accessible for anyone.

In extension to that anyone interested can contribute in different ways to the project.

For example by

  • improving this wiki page
  • reporting bugs on the missions or the addons
  • try new missions and see if they mission file needs to be updated
  • convert missions themselves and add them to the public hub
  • improve the compatibility addon yourself by adding new class mappings of yet missing
    OFP addons or MODs.

To support this process the project heavily relies on tools that support collaboration.

The wiki, SVN, automated build scripts and YomaTools for project and mission delivery.

Only a very loose organization will keep the project on track and ensure the
quality and success of the project.


So overall it will be an easy access and easy to contribute focus to deliver
content as easily and as much as possible!

The seven roads to OAC

# I. Consumer

Not meant in a negative way. Simply plays the missions and campaigns provided.
Silent epicure.

Details: Download and play.


# II. Promoter

Tells his mates or other people about the project. Given he likes it of course. :)

Details: Tells us about promotions.


# III. Feedback

Shares his opinion about the project.
Makes suggestions how to improve any aspect of the project.
Suggests missions or campaigns for conversion.
Suggests OFP addons or MODs to be included in the compatibility addon.

Details: Where to post feedback.


# IV. Bugreporting

Reports bugs in converted missions or campaigns or bugs in the compatibility
addon itself at the bugtracker in a decent way (steps to reproduce, arma.rpt
error, screenshots/videos of the problem).

Details: Where to post bugs.

# V. Contributer

Helps to improve the wiki page.
Makes screenshots or videos to promote the project.
Helps maintaining the infrastructure of the project (SVN, build process,
YomaTools, bug-tracker).
Supports the project with infrastructure (SVN server host, YomaTools server host,
bug-tracker host, hosts a mailing list, hosts the project page).

Details: How to contribute.


# VI. Missions converter

Either you help to improve already converted missions or campaigns by fixing bugs
or improving the gameplay by altering the mission file itself to a limited degree.
Or you convert new missions or campaigns yourself and add them to the public sharing system.

Details: How to convert missions and share.


# VII. Core developer

You are already into config editing or want to learn something about it.
If so, this one is for you.
You can either improve the existing compatibility addon by improving the class
mapping in different ways or add new mappings for yet missing OFP addons or MODs.


Details: How to improve the compatibility addon.


The seven roads to OAC - details

# I. Download and play

Not yet available. Soon available via a YomaTools server.

# II. Tells us about promotions

Best point your friends and other community member to the OAC BIKI page.
Good supplements are the OAC page and the OAC thread in the BI forum.

Please always add these three sources to threads and news posts.

A request to news writers:
Please add news about OAC at your page to his section for us to know so that
we can help with questions and gather feedback from the comments.

Thank you!

News and threads about OAC:
LINK MISSING

# III. Where to post feedback

The OAC BI forum thread is the the best place to share your thoughts and suggestions about the project itself.


For bugreporting or suggesting new content to be made compatible the OAC bugtracker it the best place:

  • Suggestion for mission conversions will be gathered ONLY on this ticket.
  • Suggestion for campaign conversions will be gathered ONLY on this ticket.
  • Suggestion about addons or MODs to be included in the compatibility addons will
    be gathered ONLY on this ticket.

# IV. Where to post bugs

Please post bugs related to OAC project only at the OAC bugtracker.

The problems can be:

  • Non working missions or campaigns
  • Problems with the installation
  • Problems with the updating

Please keep your bug reports as specific and as precise as possible.
Adding screenshots, videos or the errors from the arma.RPT help to visualize the problem.

A rough description of the steps to reproduce or the mission and its savegame
are another good addition to track the problem down.

Recommended tools for recording:

# V. How to contribute

# VI. How to convert missions and share

# VII. How to improve the compatibility addon

Setup the development

Project OAC uses subversion (SVN) as sort of file sharing tool for the development.

You can download the compatibility addon in source format with SVN, improve the existing code
or add new class mappings in there and upload (commit) your changes again for everyone to use
and improve.

1. You are recommended to download TortoiseSVN as windows SVN client with an excellent GUI:

2. Install TortoiseSVN and restart windows.

3. Create a new MF (modfolder) named @OAC in your ArmA installation, like .\ArmA\@OAC\addons.

4. RMB (Right mouse button) click on the addons folder and select 'SVN Checkout' Image icon.png.

5. In the checkout dialog Image icon.png copy the following URL in the dialog as 'URL to repository (server)':

http://svn.assembla.com/svn/project-oac/addons/ofp_compatibility_addon

Make sure to have the same folder structure inside your ArmA folder, like

.\ArmA\@OAC\addons\ofp_compatibility_addon

You can name the MF (modfolder) different to @OAC though.

Hit OK once you are done.

6. Use the following account data to get access to the SVN 'repository' (server):

User:     oac_read_only
Password: oac_read_only

7. Select YES to create new folder. Click the OK button in the initial download (checkout) overview.

8. The result should look like on this image Image icon.png with some files in the ofp_compatibility_addon folder and
little green icons.


Download latest version from the server

Now every time you want to work on the compatibility addon, make sure to get the latest version
from the SVN server first.

1. RMB click on the ofp_compatibility_addon folder and select SVN Update Image icon.png.

2. The software will contact the SVN server and download updates if available. In case there were
updates by other people, you can see the list of changed files in the update dialog Image icon.png.

3. You can click on the Show log button to find out about the details to what has been changed.

4. In the Log messages Image icon.png dialog, you can see the different updates.
Each upload of any user, increments the 'revision number'. The revision number is global for the
whole repository. So there is NO revision number for each file like in CVS.

Now you can select the different revisions and see the according commit comment in the
middle and the list of changed files in the given revision at the bottom.

Commit comments is done by an author for each commit. They are very important to
summarize the changes of a revision for all the other people involved!

If you RMB click on a file at the bottom, you can select Show changes to get a new dialog Image icon.png that
shows you the code changes from this one revision in detail.


Follow SVN changes with trac timeline

Using SVN log doesn't work that seamless unfortunately.
Instead you are very much recommended to use the OAC trac timline.

The timeline is a viewer on the SVN revision history. The main page lists all the updates on the
SVN server. A trac changeset is the same entity as a SVN revision.
The trac changeset (better example needed) is similar to the SVN 'diff' and shows your the
changes in the code very well by the nice code coloring.


Upload changes to the server

1 Image icon.png

2 Image icon.png

3 Image icon.png


Coding standards

  • Do not mess up the code:
    • Preceding tabs - NO spaces! - before the code.
    • Correct number of preceding tabs.
    • NO tabs or spaces at the end of the line.
    • Spaces around an equal sign are standard.
    • Do not forget a semicolon to end definitions.
    • Use quotes for strings.
    • Correct placement of brackets.
  • Use comments where they are meaningful.
  • Use empty lines to separate code.
  • Order lists alphabetically - use editor functions!


Config structure and tricks of the compatibility addon

Support need here

  • Nice banner for the project.
  • Promotion screenshots.
  • Promotion trailers.
  • Look for MISSING tag on this page.


Project team

Add yourself if you want to contribute.

  • Members:
    • kju (project manager)
    • The-F (island conversion)
  • Contact:
    • MISSING E-Mail
    • Skype group chat room: OAC Project: Skype group
      Send Q in the BI forum a PM with your skype account to get access

Project links