PMC websites shut down November 13th 2025 unless web hosting fees are paid. See up to date status from PMC Website Hosting and Domain Registration Fee Status forum topic. Please Support PMC to help keep these websites online.

Enjoyed or found this pages content useful, please Support PMC to help me keep this web page online beyond November 13th 2025 when web hosting fees are due.

User Tools

Site Tools


ofp:file_formats:rap

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
ofp:file_formats:rap [2007/07/10 09:52] – external edit 127.0.0.1ofp:file_formats:rap [2024/07/31 12:52] (current) – links added. snakeman
Line 1: Line 1:
-====== raP File Format ======+====== OFP raP File Format ====== 
 + 
 +[[https://www.pmctactical.org/forum/viewforum.php?f=43|OFP Forum]], [[:ofp|OFP Home]], [[ofp:file_formats|OFP File Formats]], [[ofp:tools|OFP Tools]], [[ofp:missions|OFP Missions]], [[ofp:modeling|OFP 3D Modeling]], [[ofp:terrain|OFP Terrain]] 
 + 
 +**Operation Flashpoint (OFP)** aka ArmA: Cold War Assault (CWA)
  
  
Line 31: Line 35:
 Importantly, **the filename extension is immaterial**. Importantly, **the filename extension is immaterial**.
  
-The engine will work with config.**cpp** as a raP encoded entity, just as it would work with config.**bin**. +The engine will work with config.**cpp** as a raP encoded entity, just as it would work with config.**bin**.
  
 ====== Tools ====== ====== Tools ======
  
-Various utilities exist which refer to binary <> cpp compression and extraction (or encoding and decoding). Again, these terms are misleading because the file concerned is not executable binary data, just tokenised strings and values. +Various utilities exist which refer to binary <> cpp compression and extraction (or encoding and decoding). Again, these terms are misleading because the file concerned is not executable binary data, just tokenised strings and values.
  
 ====== Basics ====== ====== Basics ======
  
-There is no need here to elaborately define what a mission.sqm file is. But, it is worth understanding the basics of these (types of) files to understand the __very small__ requirements needed to raPify them. +There is no need here to elaborately define what a mission.sqm file is. But, it is worth understanding the basics of these (types of) files to understand the __very small__ requirements needed to raPify them.
  
 class files only contain 3 types of construct class files only contain 3 types of construct
Line 49: Line 53:
 </code> </code>
  
-[:inherit] is optional and simply refers to another classname. +[:inherit] is optional and simply refers to another classname.
  
 (For your interest the [] are known as bacchus naur format and mean //optional//. Whatever is within the [...] is optional. The [] do **not** appear in the text file). (For your interest the [] are known as bacchus naur format and mean //optional//. Whatever is within the [...] is optional. The [] do **not** appear in the text file).
Line 59: Line 63:
 <code> <code>
  aString="A string";  aString="A string";
- anInteger=77; + anInteger=77;
  aFloat 1.855;  aFloat 1.855;
 </code> </code>
Line 68: Line 72:
  
 <code> <code>
- anArray[]={......}; + anArray[]={......};
 </code> </code>
  
Line 86: Line 90:
 <code> <code>
  class filename  class filename
- + {
     class FirstEmbeddedClass     class FirstEmbeddedClass
     {     {
Line 181: Line 185:
  
 <code> <code>
- struct VarTypString + struct VarTypString
  {  {
   byte PacketType; // = 1   byte PacketType; // = 1
Line 220: Line 224:
 **PacketType2: Arrays** **PacketType2: Arrays**
  
-Arrays[] contain four possible element types. They are the traditional variables mentioned above with an added tweak of an embedded array type. +Arrays[] contain four possible element types. They are the traditional variables mentioned above with an added tweak of an embedded array type.
  
 thus thus
Line 243: Line 247:
  
 <code> <code>
- struct ArrayString + struct ArrayString
  {  {
   byte VarType; // = 0   byte VarType; // = 0
Line 282: Line 286:
  {  {
   byte VarType; // = 3   byte VarType; // = 3
-  [[#CompressedInteger]] nElements; // iterate thru  +  [[#CompressedInteger]] nElements; // iterate thru 
- ... series of array elememts in '''this''' embedded array + ... series of array elememts in '''this''' embedded array
  };  };
 </code> </code>
Line 349: Line 353:
   {   {
   int extra;   int extra;
- +
    if ((extra = GetByte())==EOF) return EOF;    if ((extra = GetByte())==EOF) return EOF;
    val += (extra - 1) * 0x80;    val += (extra - 1) * 0x80;
Line 367: Line 371:
 </code> </code>
  
-A table of strings is accumalated according to it's index number when that specific index number is first encountered. +A table of strings is accumalated according to it's index number when that specific index number is first encountered.
  
 Although the values appear to be ordinal (0,1,2,3,4,5) you should not assume so. Although the values appear to be ordinal (0,1,2,3,4,5) you should not assume so.
Line 400: Line 404:
  etc  etc
 </code> </code>
 +
ofp/file_formats/rap.1184061152.txt.gz · Last modified: 2007/07/10 09:52 by 127.0.0.1