RCOXML Coding: Difference between revisions

From PS3 Developer wiki
Jump to navigation Jump to search
 
(33 intermediate revisions by the same user not shown)
Line 1: Line 1:
=Description=
=Description=
RCOXML files are the XML descriptor files implicit inside [[Resource Container (RCO)]] files (.rco)
An RCOXML file is a XML file that represents the contents of a RCO file. This RCOXML files doesnt exists inside the RCO file (are just a representation of it). In the compilation enviroment used officially by sony this RCOXML files "should" work as a "pre-build" layout, contains all the info and settings needed to build an RCO file


This RCOXML files doesnt exists inside the .rco container, tools like [[Rcomage]] extracts the info as XML as a representation of the data inside the .rco container
Tools like [[Rcomage]] generates this RCOXML files that can be used to rebuild the RCO, or to build a custom RCO from scratch, this RCOXML files generated by rcomage "should" be pretty similar to the officials because all the info is based in the TOC area of the RCO that is structured as an XML so the conversion from TOC to XML format is direct (also, rcomage adds some info for rebuilding purposes that is not part of the TOC), see [[Resource Container (RCO)]]
 
{{RCOXML contents PS3}}
Are composed by tables, some of this tables works simply as an index of the contents inside the container (texts, sounds, languages), and others tables contains "pages" that builds the XMB items, animations, effects, dialog menues, selection windows, widgets, etc...
 
Note the name "page" here in wiki is used as a generic name for all types of pages, rcomage uses specific names for some types of pages wich purpose was identifyed, this names can vary between different versions of rcomage tool
 
= RCOXML Contents (PS3) =
There are 122 .rco files in PS3 firmware 4.76
 
{| class="wikitable sortable" style="font-size:x-small;"
|-
! rowspan="2" | filename.rco !! colspan="6" | RCOXML contents !! rowspan="2" | notes
|-
! MainTree<br>Name !! [[RCOXML Images|ImageTree]] !! [[RCOXML Texts|TextTree]] !! [[RCOXML Sounds|SoundTree]] !! [[RCOXML Objects|ObjectTree]] !! [[RCOXML Animations|AnimTree]]
|-
| [[ap_plugin]].rco || ap_plugin || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[audioplayer_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[audioplayer_plugin_dummy]].rco || sample || {{no}} || {{yes}} || {{no}} || {{no}} || {{no}} ||
|-
| [[audioplayer_plugin_mini]].rco || sample || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[audioplayer_plugin_util]].rco || sample || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[auth_plugin]].rco || auth_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[autodownload_plugin]].rco || autodownload_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[autoupdateconf_plugin]].rco || autoupdateconff_plugin<!--the double "ff" is a sony typo--> || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[avc2_game_plugin]].rco || sample || {{no}} || {{yes}} || {{no}} || {{no}} || {{no}} ||
|-
| [[avc2_game_video_plugin]].rco || sample || {{yes}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[avc2_text_plugin]].rco || tcgui || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[avc_game_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[avc_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[bdp_disccheck_plugin]].rco || bdp_disccheck_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[bdp_plugin]].rco || bdp_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[bdp_storage_plugin]].rco || bdp_storage_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[campaign_plugin]].rco || campaign_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Contains images with non-gim formats (png).
|-
| [[category_setting_plugin]].rco || category_setting_plugin || {{yes}} || {{yes}} || {{no}} || {{no}} || {{no}} ||
|-
| [[checker_plugin]].rco || checker || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[closedcaption_config_plugin]].rco || closedcaption_config_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[comboplay_plugin]].rco || comboplay_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[custom_render_plugin]].rco || custom_render_plugin || {{yes}} || {{no}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[data_copy_plugin]].rco || sample || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[deviceconf_plugin]].rco || deviceconf_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[dlna_plugin]].rco || dlna || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[download_plugin]].rco || download || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[dtcpip_util]].rco || dtcpip_util || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[edy_plugin]].rco || edy_plugin || {{yes}} || {{yes}} || {{yes}} || {{yes}} || {{no}} ||
|-
| [[eula_cddb_plugin]].rco || eula_cddb_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[eula_hcopy_plugin]].rco || eula_hcopy || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[eula_net_plugin]].rco || regcam_plugin || {{yes}} || {{yes}} || {{yes}} || {{yes}} || {{no}} || Contains images with non-gim formats (png, jpg).
|-
| [[explore_category_friend]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_game]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_music]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_network]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_photo]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_psn]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_sysconf]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_tv]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_user]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_category_video]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_plugin_ft]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_plugin_full]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[explore_plugin_game]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[explore_plugin_np]].rco || explore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[filecopy_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[friendim_plugin]].rco || friendim || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[friendim_plugin_game]].rco || friendim || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} || Associated .sprx has a different name.
|-
| [[friendml_plugin]].rco || friendml_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[friendml_plugin_game]].rco || friendml_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[friendtrophy_plugin]].rco || friendtrophy_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[friendtrophy_plugin_game]].rco || friendtrophy_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[game_ext_plugin]].rco || game_ext_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Contains images with non-gim formats (png).
|-
| [[game_indicator_plugin]].rco || user_info_plugin || {{yes}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[game_plugin]].rco || game_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[gamedata_plugin]].rco || gamedata_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[gamelib_plugin]].rco || gamelib_plugin || {{yes}} || {{no}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[gameupdate_plugin]].rco || sample || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[hknw_plugin]].rco || hknw_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[idle_plugin]].rco || idle || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[impose_plugin]].rco || impose_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} || Associated .sprx has a different name.
|-
| [[ingame_manual_plugin]].rco || ingame_manual || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[kensaku_plugin]].rco || kensaku || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[msgdialog_plugin]].rco || msgdialog_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[mtpinitiator_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[musicbrowser_plugin]].rco || sample || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[nas_plugin]].rco || nas_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[netconf_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[newstore_effect]].rco || skeleton_plugin || {{no}} || {{no}} || {{no}} || {{no}} || {{no}} || Empty file.
|-
| [[newstore_plugin]].rco || newstore_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Contains images with non-gim formats (png, jpg).
|-
| [[np_eula_plugin]].rco || npeula || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[np_matching_plugin]].rco || np_matching_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || |
|-
| [[np_multisignin_plugin]].rco || np_multisignin_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[np_sns_plugin]].rco || npsns || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[np_trophy_ingame]].rco || np_achiev || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[np_trophy_plugin]].rco || np_achiev || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[npsignin_plugin]].rco || npsignin_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[osk_plugin]].rco || sample || {{yes}} || {{no}} || {{yes}} || {{yes}} || {{no}} ||
|-
| [[oskfullkeypanel_plugin]].rco || ime_osk_base_resouce || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[oskpanel_plugin]].rco || ime_osk_base_resouce || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[pesm_plugin]].rco || pesm || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[photo_network_sharing_plugin]].rco || pesm || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[photolist_plugin]].rco || sample || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[photoupload_plugin]].rco || dlna || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[photoviewer_plugin]].rco || photoviewer_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Contains images with non-gim formats (png).
|-
| [[playlist_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[podl_plugin]].rco || podl_plugin || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[poweroff_plugin]].rco || poweroff || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[premo_plugin]].rco || premo_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[print_plugin]].rco || print_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[profile_plugin]].rco || profile_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[profile_plugin_mini]].rco || profile_plugin_mini || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[ps3_savedata_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[ps3_savedata_plugin_game_mini]].rco || sample || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[rec_plugin]].rco || rec_plugin || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[regcam_plugin]].rco || regcam_plugin || {{yes}} || {{yes}} || {{yes}} || {{yes}} || {{no}} || Contains images with non-gim formats (png, jpg).
|-
| [[remotedownload_plugin]].rco || remotedownload || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[sacd_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{yes}} ||
|-
| [[scenefolder_plugin]].rco || sample || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[screenshot_plugin]].rco || screenshot_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[search_service]].rco || search_service || {{no}} || {{yes}} || {{no}} || {{no}} || {{no}} || Associated .sprx has a different name.
|-
| [[software_update_plugin]].rco || software_update_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[soundvisualizer_plugin]].rco || soundvisualizer || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[strviewer_plugin]].rco || strviewer || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[subdisplay_plugin]].rco || ap_plugin || {{no}} || {{no}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[sv_pseudoaudioplayer_plugin]].rco || sv_pseudoaudioplayer || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[sysconf_plugin]].rco || sysconf_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[system_plugin]].rco || system_plugin || {{yes}} || {{yes}} || {{yes}} || {{yes}} || {{yes}} || Associated .sprx has a different name.
|-
| [[thumthum_plugin]].rco || sample || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[upload_util]].rco || upload_util || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[user_info_plugin]].rco || user_info_plugin || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[user_plugin]].rco || user || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[videoeditor_plugin]].rco || skeleton_plugin || {{yes}} || {{yes}} || {{yes}} || {{yes}} || {{no}} || Contains images with non-gim formats (png, jpg).
|-
| [[videoplayer_plugin]].rco || videoplayer || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[videoplayer_util]].rco || videoplayer || {{no}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[vmc_savedata_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[wboard_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[webbrowser_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[webrender_plugin]].rco || sample || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[xmb_ingame]].rco || xmb_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|-
| [[xmb_plugin_normal]].rco || xmb_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} || Associated .sprx has a different name.
|-
| [[ycon_manual_plugin]].rco || ycon_plugin || {{yes}} || {{yes}} || {{no}} || {{yes}} || {{no}} ||
|}
 
*'''VSMXfile''' and '''ModelTree''' are not included in the table above because none of the PS3 .rco files includes them<!--or rcomage is not able to extract them-->
*Other .rco files from previous firmwares (not present in latest firmwares) using the MainTree name '''sample'''
**xai_plugin.rco


= RCOXML Structure =
= RCOXML Structure =
Not all nodes below are required, and various object/anim entries are omitted.
This is a '''not-working''' example intended to place all together as an overview. Not all nodes below are required, and various object/anim entries are omitted.


RcoFile - XML root element; generally does not need to be modified
{{Boxcode|code=<syntaxhighlight lang="xml">
MainTree - root RCO node from which everything must descend from
<?xml version="1.0" encoding="iso-8859-1"?>
VSMXFile - attached UMD virtual machine instruction code, for UMD and some LFTV RCOs.  Only one may exist in an RCO file
<!-- This XML representation of an RCO structure was generated by Rcomage v1.1.2 -->
ImageTree - parent node from which all image resources descend from
<RcoFile UMDFlag="0" rcomageXmlVer="1.1" type="psp" minFirmwareVer="1.5"> <!-- XML root element, generally does not need to be modified -->
Image
<MainTree name="sample"> <!-- root RCO node from which everything must descend from -->
Image
<VSMXFile name="main" src="main.vsmx"></VSMXFile> <!-- attached virtual machine instruction code, only one may exist in an RCO file -->
...
<ImageTree> <!-- parent node from which all image resources descend from -->
TextTree - parent node from which all text language resources descend from
<Image name="texture" src="texture.gim" format="gim" compression="zlib" unknownByte="0" />
TextLang
</ImageTree>
TextLang
<FontTree> <!-- parent node from which all fonts descend from -->
...
<FontStyle name="fontstyle_default" unknownShort1="0x0" unknownShort2="0x0" unknownInt3="0x0" unknownInt4="0x41600000" />
ModelTree - parent node from which all model resources descend from
</FontTree>
Model
<TextTree> <!-- parent node from which all text language resources descend from -->
Model
<TextLang src="00_Japanese.xml" language="00_Japanese" format="utf16" />
...
</TextTree>
SoundTree - parent node from which all sound resources descend from
<ModelTree> <!-- parent node from which all model resources descend from -->
Sound
<Model name="page_model" src="page_model.gmo" format="gmo" compression="zlib" unknownByte="0" />
Sound
</ModelTree>
...
<SoundTree> <!-- parent node from which all sound resources descend from -->
ObjectTree - parent node from which all object pages descend from
<Sound name="sound" src="sound.ch*.vag" format="vag" channels="2" />
<Page>
</SoundTree>
page objects go here
<ObjectTree> <!-- parent node from which all object pages descend from -->
<Page>
<Page name="main_page" pageMode="0x111" pageOnInit="event:script:/main/onInitMainPage" pageOnCancel="nothing" pageOnContext="nothing" pageOnActivate="nothing">
page objects go here
<Plane name="main_page_plane" ...standard object attributes here... planeImage="image:texture" planeResizeMode="0x0">
...
<ModelObject name="main_page_model"  ...standard object attributes here...  modelobjectModel="model:page_model"></ModelObject>
AnimTree - parent node from which all animation sequences descend from
<Action name="go" actionText="text:msg_go"></Action>
<Animation>
</Plane>
animation entries go here
</Page>
<Animation>
</ObjectTree>
animation entries go here
<AnimTree> <!-- parent node from which all animation sequences descend from -->
...
<Animation name="main_page_fade">
<Fade object="object:main_page_plane" duration="100" accelMode="0x0" transparency="1" />
<FireEvent event="anim:main_page_fade" />
</Animation>
</AnimTree>
</MainTree>
</RcoFile>
</syntaxhighlight>}}


==MainTree==
==MainTree==
Line 309: Line 55:
**The same label can be used by several .rco's that shares functions
**The same label can be used by several .rco's that shares functions
**This label names doesnt appears in the associated .sprx
**This label names doesnt appears in the associated .sprx
*Other .rco files from previous firmwares (not present in latest firmwares) using the MainTree name '''sample'''
**xai_plugin.rco
**In PSP firmware there are also some .rco files using the MainTree name '''sample'''


===VSMXFile===
===VSMXFile===
None of the PS3 rco's uses a VSMXFile
None of the PS3 rco's uses a VSMXFile. But some PSP .rco's uses it
 
*rough explain of how it works
**The purpose of this script is to communicate with the associated module/sprx, the code inside the script is [[PlayStation JavaScript]] based (see also [[VSMX]] format) and it can call functions with parameters from the module/sprx. It works as a simple way to store predefined actions for the .sprx inside the .rco with a bit of code control involved. The [[RCOXML Objects]] captures the button presses from the controller and based on them loads the script using the buttons as parameters, then the code inside the script is processed and triggers the .sprx
**An script can contain several different actions (are actually .js code functions) and his names are the same than the action names used in [[RCOXML Objects]], as example: '''OnFocusRight''' (action triggered when moving right in the controller)


===ImageTree===
===ImageTree===
===FontTree===
Only used in PS3, only used in sysconf_plugin.rco and hknw_plugin.rco


===TextTree===
===TextTree===
Line 323: Line 80:


===ObjectTree===
===ObjectTree===
*in [http://ctfs.wiki.fc2.com/wiki/RCOmageXML this page] under the section "ObjectTree" are explained what seems to be a few golden rules related to:
**object display priority
**children objects inherited attributes from parent object


===AnimTree===
===AnimTree===

Latest revision as of 17:56, 11 February 2022

Description[edit | edit source]

An RCOXML file is a XML file that represents the contents of a RCO file. This RCOXML files doesnt exists inside the RCO file (are just a representation of it). In the compilation enviroment used officially by sony this RCOXML files "should" work as a "pre-build" layout, contains all the info and settings needed to build an RCO file

Tools like Rcomage generates this RCOXML files that can be used to rebuild the RCO, or to build a custom RCO from scratch, this RCOXML files generated by rcomage "should" be pretty similar to the officials because all the info is based in the TOC area of the RCO that is structured as an XML so the conversion from TOC to XML format is direct (also, rcomage adds some info for rebuilding purposes that is not part of the TOC), see Resource Container (RCO)

RCOXML contents PS3 firmware 4.76 (122 .rco files)  · 

RCOXML Structure[edit | edit source]

This is a not-working example intended to place all together as an overview. Not all nodes below are required, and various object/anim entries are omitted.

<?xml version="1.0" encoding="iso-8859-1"?>
<!-- This XML representation of an RCO structure was generated by Rcomage v1.1.2 -->
<RcoFile UMDFlag="0" rcomageXmlVer="1.1" type="psp" minFirmwareVer="1.5">				<!-- XML root element, generally does not need to be modified -->
	<MainTree name="sample">									<!-- root RCO node from which everything must descend from -->
		<VSMXFile name="main" src="main.vsmx"></VSMXFile>					<!-- attached virtual machine instruction code, only one may exist in an RCO file -->
		<ImageTree>										<!-- parent node from which all image resources descend from -->
			<Image name="texture" src="texture.gim" format="gim" compression="zlib" unknownByte="0" />
		</ImageTree>
		<FontTree>										<!-- parent node from which all fonts descend from -->
			<FontStyle name="fontstyle_default" unknownShort1="0x0" unknownShort2="0x0" unknownInt3="0x0" unknownInt4="0x41600000" />
		</FontTree>
		<TextTree>										<!-- parent node from which all text language resources descend from -->
			<TextLang src="00_Japanese.xml" language="00_Japanese" format="utf16" />
		</TextTree>
		<ModelTree>										<!-- parent node from which all model resources descend from -->
			<Model name="page_model" src="page_model.gmo" format="gmo" compression="zlib" unknownByte="0" />
		</ModelTree>
		<SoundTree>										<!-- parent node from which all sound resources descend from -->
			<Sound name="sound" src="sound.ch*.vag" format="vag" channels="2" />
		</SoundTree>
		<ObjectTree>										<!-- parent node from which all object pages descend from -->
			<Page name="main_page" pageMode="0x111" pageOnInit="event:script:/main/onInitMainPage" pageOnCancel="nothing" pageOnContext="nothing" pageOnActivate="nothing">
				<Plane name="main_page_plane" ...standard object attributes here... planeImage="image:texture" planeResizeMode="0x0">
					<ModelObject name="main_page_model"  ...standard object attributes here...  modelobjectModel="model:page_model"></ModelObject>
					<Action name="go" actionText="text:msg_go"></Action>
				</Plane>
			</Page>
		</ObjectTree>
		<AnimTree>										<!-- parent node from which all animation sequences descend from -->
			<Animation name="main_page_fade">
				<Fade object="object:main_page_plane" duration="100" accelMode="0x0" transparency="1" />
				<FireEvent event="anim:main_page_fade" />
			</Animation>
		</AnimTree>
	</MainTree>
</RcoFile>

MainTree[edit | edit source]

All RCOXML files starts with the tag:

	<MainTree name="label">

MainTree represents the root of the container, so it seems the label is the name of the .rco container and is working as an identifyer of it

  • Is unknown how this labels works and his purpose, but follows a few rules:
    • The same label can be used by several .rco's that shares functions
    • This label names doesnt appears in the associated .sprx
  • Other .rco files from previous firmwares (not present in latest firmwares) using the MainTree name sample
    • xai_plugin.rco
    • In PSP firmware there are also some .rco files using the MainTree name sample

VSMXFile[edit | edit source]

None of the PS3 rco's uses a VSMXFile. But some PSP .rco's uses it

  • rough explain of how it works
    • The purpose of this script is to communicate with the associated module/sprx, the code inside the script is PlayStation JavaScript based (see also VSMX format) and it can call functions with parameters from the module/sprx. It works as a simple way to store predefined actions for the .sprx inside the .rco with a bit of code control involved. The RCOXML Objects captures the button presses from the controller and based on them loads the script using the buttons as parameters, then the code inside the script is processed and triggers the .sprx
    • An script can contain several different actions (are actually .js code functions) and his names are the same than the action names used in RCOXML Objects, as example: OnFocusRight (action triggered when moving right in the controller)

ImageTree[edit | edit source]

FontTree[edit | edit source]

Only used in PS3, only used in sysconf_plugin.rco and hknw_plugin.rco

TextTree[edit | edit source]

ModelTree[edit | edit source]

None of the PS3 rco's uses a ModelTree

SoundTree[edit | edit source]

ObjectTree[edit | edit source]

  • in this page under the section "ObjectTree" are explained what seems to be a few golden rules related to:
    • object display priority
    • children objects inherited attributes from parent object

AnimTree[edit | edit source]