BUN file

From Pikmin Technical Knowledge Base
Revision as of 19:01, 19 October 2019 by Patrick Anton (talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

BUN files (short for Bundle files) are a Binary Large Object (BLOB) archive format used in Pikmin. ANM files (likely short for Animation Folder) use the structure of BUN files as well. With minimal metadata, the bundle archive was likely used to reduce load time by packing several files into one. The purpose they serve is different from the Paired ARC+DIR Files, however, as all of the files within a bundle are unpacked into RAM as soon as one is loaded, as shown by the OpenGl / Dolphin System it is structurally similar.

File structure

The bundle file is very simple. There is a header, followed by a repeating struct for every file contained within the BUN. Each struct has a subheader and file contained within it.

Here is /dataDir/bosses/mizu/mizu.anm annotated for reference.

BUN and ANM file documentation.png Minty Meeo Documentation Legend.png

Header
Offset Size Purpose
0x00 4 Number of structs
File entry struct
Offset Size Purpose
0x00 4 File content indicator
0x04 4 Enclosed file size
0x08 4 Mock-directory string length
0x0c 0x08 value Mock-directory path
0x0c + 0x08 value 0x04 value Enclosed file

Mock-directory

Similar to the Paired ARC+DIR Files, the bundle archive emulates a folder path. When the file is unpacked in-game, it is assumed that whatever code is responsible treats the contents of the bundle files as if they were in the folder path described, starting from the root of the disc.

File content indicator

The file content indicator appears to be vestigial in most cases. However, in-game cutscenes use it to know what type of animation file is being loaded. The following filetypes have been observed to have these values assigned to them:

  • 0 = PCR
  • 1 = BTI
  • 2 = DCA
  • 3 = DCK
Credits: Minty_Meeo