mirror of
https://github.com/Luca1991/NDSFactory.git
synced 2025-07-09 13:30:12 +02:00
Compare commits
No commits in common. "master" and "v1.2" have entirely different histories.
226
.github/workflows/build.yml
vendored
226
.github/workflows/build.yml
vendored
@ -7,148 +7,124 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-linux:
|
build-linux:
|
||||||
runs-on: ubuntu-24.04
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4.1.7
|
- uses: actions/checkout@v4.1.7
|
||||||
|
|
||||||
- name: Create Build Environment
|
- name: Create Build Environment
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y build-essential libgl1-mesa-dev libglvnd-dev cmake qt6-base-dev
|
sudo apt-get install -y build-essential libgl1-mesa-dev and libglvnd-dev cmake qt6-base-dev
|
||||||
mkdir build
|
mkdir build
|
||||||
|
|
||||||
- name: Configure CMake
|
- name: Configure CMake
|
||||||
working-directory: ${{github.workspace}}/build
|
working-directory: ${{github.workspace}}/build
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
cmake -DCMAKE_BUILD_TYPE=Release ..
|
cmake -DCMAKE_BUILD_TYPE=Release ..
|
||||||
|
|
||||||
- name: Build
|
|
||||||
working-directory: ${{github.workspace}}/build
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
make -j4
|
|
||||||
|
|
||||||
- name: Archive Artifact
|
|
||||||
working-directory: ${{github.workspace}}/build
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
tar -czvf NDSFactory-${{ github.ref_name }}-Linux-x64.tar.gz NDSFactory ../README.md ../LICENSE
|
|
||||||
|
|
||||||
- name: Release on GitHub
|
|
||||||
uses: softprops/action-gh-release@v2.0.8
|
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
with:
|
|
||||||
files: "build/NDSFactory-${{ github.ref_name }}-Linux-x64.tar.gz"
|
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
make -j4
|
||||||
|
|
||||||
|
- name: Archive Artifact
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
tar -czvf NDSFactory-${{ github.ref_name }}-Linux-x64.tar.gz NDSFactory ../README.md ../LICENSE
|
||||||
|
|
||||||
|
- name: Release on GitHub
|
||||||
|
uses: softprops/action-gh-release@v2.0.8
|
||||||
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
|
with:
|
||||||
|
files: "build/NDSFactory-${{ github.ref_name }}-Linux-x64.tar.gz"
|
||||||
|
|
||||||
build-macos:
|
build-macos:
|
||||||
runs-on: macos-latest
|
runs-on: macos-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4.1.7
|
- uses: actions/checkout@v4.1.7
|
||||||
|
|
||||||
|
- name: Install Qt
|
||||||
|
uses: jurplel/install-qt-action@v4
|
||||||
|
with:
|
||||||
|
version: '6.7.2'
|
||||||
|
|
||||||
|
- name: Install CMake
|
||||||
|
uses: lukka/get-cmake@latest
|
||||||
|
|
||||||
- name: Install Qt
|
- name: Create Build Environment
|
||||||
uses: jurplel/install-qt-action@v4
|
run: |
|
||||||
with:
|
mkdir build
|
||||||
version: "6.7.2"
|
|
||||||
|
- name: Configure CMake
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
cmake -DCMAKE_BUILD_TYPE=Release ..
|
||||||
|
|
||||||
- name: Install CMake
|
- name: Build
|
||||||
uses: lukka/get-cmake@latest
|
working-directory: ${{github.workspace}}/build
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
make -j4
|
||||||
|
macdeployqt NDSFactory.app
|
||||||
|
|
||||||
- name: Create Build Environment
|
- name: Archive Artifact
|
||||||
run: |
|
working-directory: ${{github.workspace}}/build
|
||||||
mkdir -p build/x86_64 build/arm64 build/universal
|
shell: bash
|
||||||
|
run: |
|
||||||
|
zip -r NDSFactory-${{ github.ref_name }}-macOS.zip NDSFactory.app ../README.md ../LICENSE
|
||||||
|
|
||||||
- name: Configure CMake (x86_64)
|
- name: Release on GitHub
|
||||||
working-directory: ${{ github.workspace }}/build/x86_64
|
uses: softprops/action-gh-release@v2.0.8
|
||||||
shell: bash
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
run: |
|
with:
|
||||||
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_OSX_ARCHITECTURES=x86_64 ../..
|
files: "build/NDSFactory-${{ github.ref_name }}-macOS.zip"
|
||||||
|
|
||||||
- name: Configure CMake (arm64)
|
|
||||||
working-directory: ${{ github.workspace }}/build/arm64
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_OSX_ARCHITECTURES=arm64 ../..
|
|
||||||
|
|
||||||
- name: Build (x86_64)
|
|
||||||
working-directory: ${{ github.workspace }}/build/x86_64
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
make -j4
|
|
||||||
|
|
||||||
- name: Build (arm64)
|
|
||||||
working-directory: ${{ github.workspace }}/build/arm64
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
make -j4
|
|
||||||
|
|
||||||
- name: Create Universal Binary
|
|
||||||
working-directory: ${{ github.workspace }}/build
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
cp -R x86_64/NDSFactory.app universal/
|
|
||||||
lipo -create -output universal/NDSFactory.app/Contents/MacOS/NDSFactory x86_64/NDSFactory.app/Contents/MacOS/NDSFactory arm64/NDSFactory.app/Contents/MacOS/NDSFactory
|
|
||||||
|
|
||||||
- name: Deploy Qt Frameworks
|
|
||||||
working-directory: ${{ github.workspace }}/build/universal
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
macdeployqt NDSFactory.app -verbose=1
|
|
||||||
|
|
||||||
- name: Archive Artifact
|
|
||||||
working-directory: ${{ github.workspace }}/build/universal
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
zip -r NDSFactory-${{ github.ref_name }}-macOS.zip NDSFactory.app ../README.md ../LICENSE
|
|
||||||
|
|
||||||
- name: Release on GitHub
|
|
||||||
uses: softprops/action-gh-release@v2.0.8
|
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
with:
|
|
||||||
files: "build/universal/NDSFactory-${{ github.ref_name }}-macOS.zip"
|
|
||||||
|
|
||||||
build-windows:
|
build-windows:
|
||||||
runs-on: windows-latest
|
runs-on: windows-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4.1.7
|
- uses: actions/checkout@v4.1.7
|
||||||
|
|
||||||
|
- name: Install Qt
|
||||||
|
uses: jurplel/install-qt-action@v4
|
||||||
|
with:
|
||||||
|
version: '6.7.2'
|
||||||
|
|
||||||
|
- name: Install CMake
|
||||||
|
uses: lukka/get-cmake@latest
|
||||||
|
|
||||||
- name: Install Qt
|
- name: Create Build Environment
|
||||||
uses: jurplel/install-qt-action@v4
|
run: |
|
||||||
with:
|
mkdir build
|
||||||
version: "6.7.2"
|
|
||||||
|
- name: Configure CMake
|
||||||
|
working-directory: ${{github.workspace}}/build
|
||||||
|
run: |
|
||||||
|
cmake ..
|
||||||
|
|
||||||
- name: Install CMake
|
- name: Build
|
||||||
uses: lukka/get-cmake@latest
|
working-directory: ${{github.workspace}}/build
|
||||||
|
run: |
|
||||||
|
cmake --build . -j4 --config Release
|
||||||
|
mkdir .\Release\prod
|
||||||
|
move .\Release\NDSFactory.exe .\Release\prod
|
||||||
|
windeployqt .\Release\prod\NDSFactory.exe
|
||||||
|
|
||||||
|
- name: Archive Artifact
|
||||||
|
working-directory: ${{github.workspace}}/build/Release
|
||||||
|
run: |
|
||||||
|
xcopy ..\..\README.md .\prod
|
||||||
|
xcopy ..\..\LICENSE .\prod
|
||||||
|
powershell "Compress-Archive -Path .\prod\* -DestinationPath .\NDSFactory-${{ github.ref_name }}-Windows-x64.zip"
|
||||||
|
|
||||||
- name: Create Build Environment
|
- name: Release on GitHub
|
||||||
run: |
|
uses: softprops/action-gh-release@v2.0.8
|
||||||
mkdir build
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
|
with:
|
||||||
- name: Configure CMake
|
files: "build/Release/NDSFactory-${{ github.ref_name }}-Windows-x64.zip"
|
||||||
working-directory: ${{github.workspace}}/build
|
|
||||||
run: |
|
|
||||||
cmake ..
|
|
||||||
|
|
||||||
- name: Build
|
|
||||||
working-directory: ${{github.workspace}}/build
|
|
||||||
run: |
|
|
||||||
cmake --build . -j4 --config Release
|
|
||||||
mkdir .\Release\prod
|
|
||||||
move .\Release\NDSFactory.exe .\Release\prod
|
|
||||||
windeployqt .\Release\prod\NDSFactory.exe
|
|
||||||
|
|
||||||
- name: Archive Artifact
|
|
||||||
working-directory: ${{github.workspace}}/build/Release
|
|
||||||
run: |
|
|
||||||
xcopy ..\..\README.md .\prod
|
|
||||||
xcopy ..\..\LICENSE .\prod
|
|
||||||
powershell "Compress-Archive -Path .\prod\* -DestinationPath .\NDSFactory-${{ github.ref_name }}-Windows-x64.zip"
|
|
||||||
|
|
||||||
- name: Release on GitHub
|
|
||||||
uses: softprops/action-gh-release@v2.0.8
|
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
with:
|
|
||||||
files: "build/Release/NDSFactory-${{ github.ref_name }}-Windows-x64.zip"
|
|
@ -84,7 +84,7 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Set C++ standard for the target
|
# Set C++ standard for the target
|
||||||
target_compile_features(${PROJECT_NAME} PUBLIC cxx_std_20)
|
target_compile_features(${PROJECT_NAME} PUBLIC cxx_std_14)
|
||||||
|
|
||||||
# Enable Qt's automatic features for the target
|
# Enable Qt's automatic features for the target
|
||||||
set_target_properties(${PROJECT_NAME} PROPERTIES
|
set_target_properties(${PROJECT_NAME} PROPERTIES
|
||||||
|
24
README.md
24
README.md
@ -39,28 +39,18 @@ In the Unpacker Tab, you can load your Nintendo DS software (.nds) and extract t
|
|||||||
**You can then do what you want with these sections (inject code, apply patches etc.)**
|
**You can then do what you want with these sections (inject code, apply patches etc.)**
|
||||||
|
|
||||||
## Packer Tab
|
## Packer Tab
|
||||||
In the Packer Tab, you can recreate a .nds file using your edited sections.
|
In the Packer Tab, you can recreate a .nds file using your edited sections. If your sections are larger than the originals, you must update their addresses and sizes in the header. Ensure that the addresses do not overlap, or the final ROM will be broken. If you repack edited sections and the FAT files' address is different from the original, you must patch the FAT (fat.bin). The FAT contains absolute addresses representing each file's start and end addresses, so you need to update them accordingly (use the FAT Patching Tab for this).
|
||||||
If your sections are larger than the originals, you must update their addresses and sizes in the header.
|
|
||||||
Ensure that the addresses do not overlap, or the final ROM will be broken.
|
|
||||||
If you repack edited sections and the FAT files' address is different from the original, you must patch the FAT (fat.bin).
|
|
||||||
The FAT contains absolute addresses representing each file's start and end addresses, so you need to update them accordingly (use the FAT Patching Tab for this).
|
|
||||||
|
|
||||||
WARNING: if the ROM contains ARM9/ARM7 overlays and your sections are larger than the original, you must manually update the overlay offsets in the ovr and fat binaries (using an hex editor).
|
|
||||||
|
|
||||||
## Fat Tools Tab
|
## Fat Tools Tab
|
||||||
In this tab, you can:
|
In this tab, you can:
|
||||||
* extract the FAT files from fat_data.bin.
|
* extract the FAT files from fat_data.bin.
|
||||||
* rebuild the FAT files into a new fat.bin and fat_data.bin.
|
* patch the FAT section (fat.bin): this is only necessary if the FAT files' final address (fat_data.bin) differs from the original. Patching the FAT is straightforward: load your fat.bin, and fill in the original and new addresses of fat_data.bin. This will produce a patched fat.bin for use in the packing process.
|
||||||
If the ROM contains ARM9/ARM7 overlays you must provide the original fat.bin to extract the overlay offsets.
|
|
||||||
|
|
||||||
WARNING: DO NOT MODIFY FAT FILES NAMES OR EXTENSIONS, OR YOU WILL NEED A NEW fnt.bin.
|
|
||||||
* patch the FAT section (fat.bin): this is only necessary if the FAT files' final address (fat_data.bin) differs from the original.
|
|
||||||
Patching the FAT is straightforward: load your fat.bin, and fill in the original and new addresses of fat_data.bin. This will produce a patched fat.bin for use in the packing process.
|
|
||||||
|
|
||||||
# Credits
|
# Known Limitations/Possible Future Features/Bugs
|
||||||
|
|
||||||
|
* Add support to rebuild a new fat_data.bin and fat.bin from a set of files inside a directory.
|
||||||
|
|
||||||
If you find a bug, feel free to open an issue or submit a pull request :)
|
If you find a bug, feel free to open an issue or submit a pull request :)
|
||||||
|
|
||||||
Special thanks to [Antonio Barba](https://github.com/antoniobarba) & [Davide Trogu](https://github.com/Dax89)
|
### Developed with ❤ by Luca D'Amico
|
||||||
|
### Special thanks to Antonio Barba & Davide Trogu
|
||||||
Developed with ❤ by Luca D'Amico
|
|
||||||
|
@ -6,8 +6,3 @@ struct FatRange {
|
|||||||
uint32_t startAddr;
|
uint32_t startAddr;
|
||||||
uint32_t endAddr;
|
uint32_t endAddr;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct FatFileID {
|
|
||||||
uint16_t id;
|
|
||||||
std::string path;
|
|
||||||
};
|
|
@ -3,7 +3,6 @@
|
|||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
#include <format>
|
|
||||||
#include "ndsfactory.h"
|
#include "ndsfactory.h"
|
||||||
#include "fatstruct.h"
|
#include "fatstruct.h"
|
||||||
#include "crctable.h"
|
#include "crctable.h"
|
||||||
@ -22,94 +21,94 @@
|
|||||||
#define ROOT_DIRECTORY_ADDRESS 0xF000
|
#define ROOT_DIRECTORY_ADDRESS 0xF000
|
||||||
|
|
||||||
|
|
||||||
NFResult NDSFactory::loadRomHeader(const std::string& romPath, std::vector<char>& romHeader)
|
NDSFactory::NDSFactory()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
bool NDSFactory::loadRomHeader(const std::string& romPath, std::vector<char>& romHeader)
|
||||||
{
|
{
|
||||||
std::streampos headerSize = sizeof(NDSHeader);
|
std::streampos headerSize = sizeof(NDSHeader);
|
||||||
std::ifstream romFile (romPath, std::ios::binary);
|
std::ifstream romFile (romPath, std::ios::in|std::ios::binary|std::ios::ate);
|
||||||
if (!romFile.is_open())
|
if (romFile.is_open())
|
||||||
return NFResult({ false, "Error opening file: " + romPath });
|
|
||||||
|
|
||||||
romHeader.resize(static_cast<unsigned long>(headerSize));
|
|
||||||
romFile.read (romHeader.data(), headerSize);
|
|
||||||
romFile.close();
|
|
||||||
return NFResult({ true, "" });
|
|
||||||
}
|
|
||||||
|
|
||||||
NFResult NDSFactory::dumpDataFromFile(const std::string& romPath, const std::string& savePath, uint32_t startAddr, uint32_t size)
|
|
||||||
{
|
|
||||||
std::ifstream romFile (romPath, std::ios::binary);
|
|
||||||
std::ofstream savedFile (savePath, std::ios::binary);
|
|
||||||
if (!romFile.is_open()) return NFResult({ false, "Error opening file: " + romPath });
|
|
||||||
if (!savedFile.is_open()) return NFResult({ false, "Error creating file: " + savePath });
|
|
||||||
|
|
||||||
std::vector<char> dumpBuffer(size);
|
|
||||||
romFile.seekg (startAddr, std::ios::beg);
|
|
||||||
romFile.read (dumpBuffer.data(), size);
|
|
||||||
romFile.close();
|
|
||||||
|
|
||||||
savedFile.write(dumpBuffer.data(), size);
|
|
||||||
savedFile.close();
|
|
||||||
return NFResult({ true, "" });
|
|
||||||
}
|
|
||||||
|
|
||||||
bool NDSFactory::logToFile(const std::string& logPath, const std::string& log)
|
|
||||||
{
|
|
||||||
std::ofstream savedFile(logPath, std::ios::out | std::ios::binary | std::ios::app);
|
|
||||||
if (!savedFile.is_open()) return false;
|
|
||||||
|
|
||||||
savedFile.write(log.c_str(), log.size());
|
|
||||||
savedFile.close();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
NFResult NDSFactory::readBytesFromFile(std::vector<char>& byteBuffer, const std::string& romPath, uint32_t startAddr, uint32_t size)
|
|
||||||
{
|
|
||||||
std::ifstream romFile (romPath, std::ios::binary);
|
|
||||||
if (!romFile.is_open())
|
|
||||||
return NFResult({ false, "Error opening file: " + romPath });
|
|
||||||
|
|
||||||
romFile.seekg (startAddr, std::ios::beg);
|
|
||||||
romFile.read (byteBuffer.data(), size);
|
|
||||||
romFile.close();
|
|
||||||
return NFResult({ true, "" });
|
|
||||||
}
|
|
||||||
|
|
||||||
NFResult NDSFactory::writeSectionToFile(const std::string& sectionPath, const std::string& savePath, uint32_t startAddr, uint32_t size)
|
|
||||||
{
|
|
||||||
std::ifstream sectionFile (sectionPath, std::ios::binary);
|
|
||||||
if (!sectionFile.is_open())
|
|
||||||
return NFResult({ false, "Error opening file: " + sectionPath });
|
|
||||||
|
|
||||||
std::vector<char> dumpBuffer(size);
|
|
||||||
sectionFile.read (dumpBuffer.data(), size);
|
|
||||||
sectionFile.close();
|
|
||||||
return writeBytesToFile(dumpBuffer, savePath, startAddr, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
NFResult NDSFactory::writeBytesToFile(std::vector<char>& byteBuffer, const std::string& savePath, uint32_t startAddr, uint32_t size)
|
|
||||||
{
|
|
||||||
std::ofstream savedFile (savePath, std::ios::in | std::ios::out | std::ios::binary);
|
|
||||||
if (!savedFile.is_open())
|
|
||||||
{
|
{
|
||||||
savedFile.open(savePath, std::ios::out | std::ios::binary);
|
romHeader.resize(static_cast<unsigned long>(headerSize));
|
||||||
if (!savedFile.is_open()) {
|
|
||||||
return NFResult({ false, "Error creating file: " + savePath });
|
|
||||||
}
|
|
||||||
savedFile.close();
|
|
||||||
savedFile.open(savePath, std::ios::in | std::ios::out | std::ios::binary);
|
|
||||||
if (!savedFile.is_open())
|
|
||||||
return NFResult({ false, "Error opening file: " + savePath });
|
|
||||||
}
|
|
||||||
|
|
||||||
savedFile.seekp(startAddr);
|
romFile.seekg (0, std::ios::beg);
|
||||||
savedFile.write(byteBuffer.data(), size);
|
romFile.read (romHeader.data(), headerSize);
|
||||||
savedFile.close();
|
romFile.close();
|
||||||
return NFResult({ true, "" });
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool NDSFactory::dumpDataFromFile(const std::string& romPath, const std::string& savePath, uint32_t startAddr, uint32_t size)
|
||||||
|
{
|
||||||
|
std::ifstream romFile (romPath, std::ios::in|std::ios::binary|std::ios::ate);
|
||||||
|
std::ofstream savedFile (savePath, std::ios::out|std::ios::binary|std::ios::ate);
|
||||||
|
if (romFile.is_open() && savedFile.is_open())
|
||||||
|
{
|
||||||
|
std::vector<char> dumpBuffer(size);
|
||||||
|
romFile.seekg (startAddr, std::ios::beg);
|
||||||
|
romFile.read (dumpBuffer.data(), size);
|
||||||
|
romFile.close();
|
||||||
|
|
||||||
|
savedFile.write(dumpBuffer.data(), size);
|
||||||
|
savedFile.close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
NFResult NDSFactory::writePaddingToFile(char paddingChar, const std::string& filePath, uint32_t startAddr, const uint32_t size)
|
bool NDSFactory::readBytesFromFile(std::vector<char>& byteBuffer, const std::string& romPath, uint32_t startAddr, uint32_t size)
|
||||||
|
{
|
||||||
|
std::ifstream romFile (romPath, std::ios::in|std::ios::binary|std::ios::ate);
|
||||||
|
if (romFile.is_open())
|
||||||
|
{
|
||||||
|
romFile.seekg (startAddr, std::ios::beg);
|
||||||
|
romFile.read (byteBuffer.data(), size);
|
||||||
|
romFile.close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool NDSFactory::writeSectionToFile(const std::string& sectionPath, const std::string& savePath, uint32_t startAddr, uint32_t size)
|
||||||
|
{
|
||||||
|
std::ifstream sectionFile (sectionPath, std::ios::in|std::ios::binary|std::ios::ate);
|
||||||
|
std::ofstream savedFile (savePath, std::ios::out|std::ios::binary|std::ios::app);
|
||||||
|
if (sectionFile.is_open() && savedFile.is_open())
|
||||||
|
{
|
||||||
|
std::vector<char> dumpBuffer(size);
|
||||||
|
sectionFile.seekg (0, std::ios::beg);
|
||||||
|
sectionFile.read (dumpBuffer.data(), size);
|
||||||
|
sectionFile.close();
|
||||||
|
|
||||||
|
savedFile.seekp(startAddr, std::ios::beg);
|
||||||
|
savedFile.write(dumpBuffer.data(), size);
|
||||||
|
savedFile.close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool NDSFactory::writeBytesToFile(std::vector<char>& byteBuffer, const std::string& savePath, uint32_t startAddr, uint32_t size)
|
||||||
|
{
|
||||||
|
std::ofstream savedFile (savePath, std::ios::out|std::ios::binary|std::ios::app);
|
||||||
|
if (savedFile.is_open())
|
||||||
|
{
|
||||||
|
savedFile.seekp(startAddr, std::ios::beg);
|
||||||
|
savedFile.write(byteBuffer.data(), size);
|
||||||
|
savedFile.close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool NDSFactory::writePaddingToFile(char paddingChar, const std::string& filePath, uint32_t startAddr, const uint32_t size)
|
||||||
{
|
{
|
||||||
std::vector<char> paddingBytes(size, paddingChar);
|
std::vector<char> paddingBytes(size, paddingChar);
|
||||||
return writeBytesToFile(paddingBytes, filePath, startAddr, size);
|
return writeBytesToFile(paddingBytes, filePath, startAddr, size);
|
||||||
@ -122,7 +121,7 @@ int NDSFactory::getCardSizeInBytes(int cardType)
|
|||||||
|
|
||||||
bool NDSFactory::checkArm9FooterPresence(const std::string& sectionPath, uint32_t size)
|
bool NDSFactory::checkArm9FooterPresence(const std::string& sectionPath, uint32_t size)
|
||||||
{
|
{
|
||||||
std::ifstream sectionFile (sectionPath, std::ios::binary | std::ios::ate);
|
std::ifstream sectionFile (sectionPath, std::ios::in|std::ios::binary|std::ios::ate);
|
||||||
if (sectionFile.is_open())
|
if (sectionFile.is_open())
|
||||||
{
|
{
|
||||||
std::streamoff sectionRealSize = sectionFile.tellg();
|
std::streamoff sectionRealSize = sectionFile.tellg();
|
||||||
@ -135,15 +134,15 @@ bool NDSFactory::checkArm9FooterPresence(const std::string& sectionPath, uint32_
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult NDSFactory::extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
bool NDSFactory::extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
||||||
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath, bool logFileIDs)
|
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath)
|
||||||
{
|
{
|
||||||
std::vector<char> fatDataBytes;
|
std::vector<char> fatDataBytes;
|
||||||
std::vector<char> fatBytes;
|
std::vector<char> fatBytes;
|
||||||
std::vector<char> fntBytes;
|
std::vector<char> fntBytes;
|
||||||
|
|
||||||
std::ifstream fatDataSectionFile(fatDataSectionPath, std::ios::in | std::ios::binary | std::ios::ate);
|
std::ifstream fatDataSectionFile(fatDataSectionPath, std::ios::in | std::ios::binary | std::ios::ate);
|
||||||
if (!fatDataSectionFile.is_open()) return NFResult({ false, "Error opening file: " + fatDataSectionPath });
|
if (!fatDataSectionFile.is_open()) return false;
|
||||||
std::streamoff fatDataSectionSize = fatDataSectionFile.tellg();
|
std::streamoff fatDataSectionSize = fatDataSectionFile.tellg();
|
||||||
fatDataBytes.resize(fatDataSectionSize);
|
fatDataBytes.resize(fatDataSectionSize);
|
||||||
fatDataSectionFile.seekg(0, std::ios::beg);
|
fatDataSectionFile.seekg(0, std::ios::beg);
|
||||||
@ -151,7 +150,7 @@ NFResult NDSFactory::extractFatData(const std::string& fatDataSectionPath, const
|
|||||||
fatDataSectionFile.close();
|
fatDataSectionFile.close();
|
||||||
|
|
||||||
std::ifstream fatSectionFile(fatSectionPath, std::ios::in | std::ios::binary | std::ios::ate);
|
std::ifstream fatSectionFile(fatSectionPath, std::ios::in | std::ios::binary | std::ios::ate);
|
||||||
if (!fatSectionFile.is_open()) return NFResult({ false, "Error opening file: " + fatSectionPath });
|
if (!fatSectionFile.is_open()) return false;
|
||||||
std::streamoff fatSectionSize = fatSectionFile.tellg();
|
std::streamoff fatSectionSize = fatSectionFile.tellg();
|
||||||
fatBytes.resize(fatSectionSize);
|
fatBytes.resize(fatSectionSize);
|
||||||
fatSectionFile.seekg(0, std::ios::beg);
|
fatSectionFile.seekg(0, std::ios::beg);
|
||||||
@ -159,7 +158,7 @@ NFResult NDSFactory::extractFatData(const std::string& fatDataSectionPath, const
|
|||||||
fatSectionFile.close();
|
fatSectionFile.close();
|
||||||
|
|
||||||
std::ifstream fntSectionFile(fntSectionPath, std::ios::in | std::ios::binary | std::ios::ate);
|
std::ifstream fntSectionFile(fntSectionPath, std::ios::in | std::ios::binary | std::ios::ate);
|
||||||
if (!fntSectionFile.is_open()) return NFResult({ false, "Error opening file: " + fntSectionPath });
|
if (!fntSectionFile.is_open()) return false;
|
||||||
std::streamoff fntSectionSize = fntSectionFile.tellg();
|
std::streamoff fntSectionSize = fntSectionFile.tellg();
|
||||||
fntBytes.resize(fntSectionSize);
|
fntBytes.resize(fntSectionSize);
|
||||||
fntSectionFile.seekg(0, std::ios::beg);
|
fntSectionFile.seekg(0, std::ios::beg);
|
||||||
@ -170,7 +169,7 @@ NFResult NDSFactory::extractFatData(const std::string& fatDataSectionPath, const
|
|||||||
|
|
||||||
// This lambda function was written by NyuBlara, all credits to him.
|
// This lambda function was written by NyuBlara, all credits to him.
|
||||||
// I edited it a bit to make it work with the rest of the updated code.
|
// I edited it a bit to make it work with the rest of the updated code.
|
||||||
auto parseFolder = [this, fntBytes, pfatrange, fatDataSectionPath, originalFatDataAddr, savePath, logFileIDs](uint32_t folderId, std::string curPath, auto& parseFolder) {
|
auto parseFolder = [this, fntBytes, pfatrange, fatDataSectionPath, originalFatDataAddr](uint32_t folderId, std::string curPath, auto& parseFolder) {
|
||||||
|
|
||||||
uint32_t currentOffset = 8 * (folderId & FNT_HEADER_OFFSET_MASK); // offset for the current directory's info in the FNT header
|
uint32_t currentOffset = 8 * (folderId & FNT_HEADER_OFFSET_MASK); // offset for the current directory's info in the FNT header
|
||||||
// Only the lower 12 bit of the given offset are relevant
|
// Only the lower 12 bit of the given offset are relevant
|
||||||
@ -235,16 +234,10 @@ NFResult NDSFactory::extractFatData(const std::string& fatDataSectionPath, const
|
|||||||
currentOffset += 2;
|
currentOffset += 2;
|
||||||
|
|
||||||
if (!std::filesystem::exists(newPath))
|
if (!std::filesystem::exists(newPath))
|
||||||
if (!std::filesystem::create_directory(newPath)) return NFResult({ false, "Error creating directory: " + newPath });
|
if (!std::filesystem::create_directory(newPath)) return false;
|
||||||
|
|
||||||
if (logFileIDs)
|
|
||||||
{
|
|
||||||
std::string log = std::format("{:x}",subFolderId) + ":::" + newPath.substr(savePath.size()+1) + '\n';
|
|
||||||
if (!logToFile(savePath + "/_file_IDs.txt", log)) return NFResult({ false, "Error writing to file: " + savePath + "/_file_IDs.txt" });
|
|
||||||
}
|
|
||||||
|
|
||||||
// Jump back to the FNT header and repeat the process for subdirectory !
|
// Jump back to the FNT header and repeat the process for subdirectory !
|
||||||
if (!parseFolder(subFolderId, newPath, parseFolder).result) return NFResult({ false, "Error parsing folder: " + newPath });
|
if (!parseFolder(subFolderId, newPath, parseFolder)) return false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -254,31 +247,25 @@ NFResult NDSFactory::extractFatData(const std::string& fatDataSectionPath, const
|
|||||||
|
|
||||||
uint32_t fileStartAddr = (pfatrange + fatOffset)->startAddr - originalFatDataAddr;
|
uint32_t fileStartAddr = (pfatrange + fatOffset)->startAddr - originalFatDataAddr;
|
||||||
uint32_t fileSize = (pfatrange + fatOffset)->endAddr - (pfatrange + fatOffset)->startAddr;
|
uint32_t fileSize = (pfatrange + fatOffset)->endAddr - (pfatrange + fatOffset)->startAddr;
|
||||||
if (!dumpDataFromFile(fatDataSectionPath, newPath, fileStartAddr, fileSize).result) return NFResult({ false, "Error dumping file: " + newPath });
|
if (!dumpDataFromFile(fatDataSectionPath, newPath, fileStartAddr, fileSize)) return false;
|
||||||
|
|
||||||
if (logFileIDs)
|
|
||||||
{
|
|
||||||
std::string log = std::format("{:x}", fatOffset) + ":::" + newPath.substr(savePath.size()+1) + '\n';
|
|
||||||
if (!logToFile(savePath + "/_file_IDs.txt", log)) return NFResult({ false, "Error writing to file: " + savePath + "/_file_IDs.txt" });
|
|
||||||
}
|
|
||||||
|
|
||||||
fatOffset++;
|
fatOffset++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NFResult({ true, "" });
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
return parseFolder(ROOT_DIRECTORY_ADDRESS, savePath, parseFolder);
|
return parseFolder(ROOT_DIRECTORY_ADDRESS, savePath, parseFolder);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult NDSFactory::patchFat(const std::string& fatSectionPath, uint32_t shiftSize, const std::string& savePath)
|
bool NDSFactory::patchFat(const std::string& fatSectionPath, uint32_t shiftSize, const std::string& savePath)
|
||||||
{
|
{
|
||||||
std::vector<char> fatBytes;
|
std::vector<char> fatBytes;
|
||||||
|
|
||||||
std::ifstream sectionFile (fatSectionPath, std::ios::in|std::ios::binary|std::ios::ate);
|
std::ifstream sectionFile (fatSectionPath, std::ios::in|std::ios::binary|std::ios::ate);
|
||||||
if (!sectionFile.is_open())
|
if (!sectionFile.is_open())
|
||||||
return { false, "Error opening file: " + fatSectionPath };
|
return false;
|
||||||
|
|
||||||
std::streamoff sectionSize = sectionFile.tellg();
|
std::streamoff sectionSize = sectionFile.tellg();
|
||||||
fatBytes.resize(sectionSize);
|
fatBytes.resize(sectionSize);
|
||||||
@ -295,97 +282,9 @@ NFResult NDSFactory::patchFat(const std::string& fatSectionPath, uint32_t shiftS
|
|||||||
pfatrange->endAddr += shiftSize;
|
pfatrange->endAddr += shiftSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::remove(savePath.c_str());
|
|
||||||
|
|
||||||
return writeBytesToFile(fatBytes, savePath, 0, static_cast<uint32_t>(sectionSize));
|
return writeBytesToFile(fatBytes, savePath, 0, static_cast<uint32_t>(sectionSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult NDSFactory::buildFatData(const std::string& fatDataDirPath, const std::string& originalFatPath, uint32_t fatDataAddr, const std::string& savePath)
|
|
||||||
{
|
|
||||||
std::vector<char> fatDataBytes;
|
|
||||||
std::vector<FatRange> fat;
|
|
||||||
std::vector<char> fntBytes;
|
|
||||||
|
|
||||||
std::vector<FatFileID> fileIDs;
|
|
||||||
std::ifstream fileIDsFile(fatDataDirPath + "/_file_IDs.txt", std::ios::in);
|
|
||||||
if (!fileIDsFile.is_open()) return { false, "Error opening file: " + fatDataDirPath + "/_file_IDs.txt" };
|
|
||||||
std::string fileIDsLine;
|
|
||||||
while (std::getline(fileIDsFile, fileIDsLine))
|
|
||||||
{
|
|
||||||
FatFileID fatFileID;
|
|
||||||
fatFileID.id = static_cast<uint16_t>(std::stoi(fileIDsLine.substr(0, fileIDsLine.find(":::")), nullptr, 16));
|
|
||||||
fatFileID.path = fileIDsLine.substr(fileIDsLine.find(":::") + 3);
|
|
||||||
fileIDs.push_back(fatFileID);
|
|
||||||
}
|
|
||||||
fileIDsFile.close();
|
|
||||||
|
|
||||||
// This loop is needed to detect if roms has overlay files
|
|
||||||
// and if so, we need to extract their addresses from the original fat.bin
|
|
||||||
// it is a hacky but it works
|
|
||||||
for (FatFileID fatFileID : fileIDs)
|
|
||||||
{
|
|
||||||
std::string currentFile = fatDataDirPath + "/" + fatFileID.path;
|
|
||||||
if (std::filesystem::is_directory(std::filesystem::path(currentFile))) continue;
|
|
||||||
|
|
||||||
int firstFileId = fatFileID.id;
|
|
||||||
if (firstFileId > 0)
|
|
||||||
{
|
|
||||||
std::ifstream originalFatFile(originalFatPath, std::ios::in | std::ios::binary);
|
|
||||||
if (!originalFatFile.is_open()) return { false, "Error opening file: " + originalFatPath };
|
|
||||||
std::vector<char> ovrBytes;
|
|
||||||
uint32_t requiredBytes = firstFileId * sizeof(FatRange);
|
|
||||||
ovrBytes.resize(requiredBytes);
|
|
||||||
originalFatFile.read(ovrBytes.data(), requiredBytes);
|
|
||||||
originalFatFile.close();
|
|
||||||
|
|
||||||
FatRange* pfatrange = reinterpret_cast<FatRange*>(ovrBytes.data());
|
|
||||||
for (size_t i = 0; i < ovrBytes.size(); i += sizeof(FatRange), pfatrange++)
|
|
||||||
fat.push_back({ pfatrange->startAddr, pfatrange->endAddr });
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (FatFileID fatFileID : fileIDs)
|
|
||||||
{
|
|
||||||
std::string currentFile = fatDataDirPath + "/" + fatFileID.path;
|
|
||||||
|
|
||||||
if (std::filesystem::is_directory(std::filesystem::path(currentFile))) continue;
|
|
||||||
|
|
||||||
FatRange fatRange;
|
|
||||||
fatRange.startAddr = fatDataAddr + static_cast<uint32_t>(fatDataBytes.size());
|
|
||||||
|
|
||||||
std::ifstream currentFatDataFile(currentFile, std::ios::in | std::ios::binary | std::ios::ate);
|
|
||||||
if (!currentFatDataFile.is_open()) return NFResult({ false, "Error opening file: " + currentFile });
|
|
||||||
std::streamsize size = currentFatDataFile.tellg();
|
|
||||||
currentFatDataFile.seekg(0, std::ios::beg);
|
|
||||||
|
|
||||||
std::vector<char> buffer(size);
|
|
||||||
if (currentFatDataFile.read(buffer.data(), size))
|
|
||||||
fatDataBytes.insert(fatDataBytes.end(), buffer.begin(), buffer.end());
|
|
||||||
else
|
|
||||||
{
|
|
||||||
currentFatDataFile.close();
|
|
||||||
return NFResult({ false, "Error reading file: " + currentFile });
|
|
||||||
}
|
|
||||||
currentFatDataFile.close();
|
|
||||||
|
|
||||||
fatRange.endAddr = fatDataAddr + static_cast<uint32_t>(fatDataBytes.size());
|
|
||||||
fat.push_back(fatRange);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
const char* fat_ptr = reinterpret_cast<const char*>(fat.data());
|
|
||||||
std::vector<char> fatBytes(fat_ptr, fat_ptr + fat.size() * sizeof(FatRange));
|
|
||||||
std::remove((savePath + "/fat_data.bin").c_str());
|
|
||||||
std::remove((savePath + "/fat.bin").c_str());
|
|
||||||
if (!writeBytesToFile(fatDataBytes, savePath + "/fat_data.bin", 0, static_cast<uint32_t>(fatDataBytes.size())).result)
|
|
||||||
return NFResult({ false, "Error writing to file: " + savePath + "/fat_data.bin" });
|
|
||||||
if (!writeBytesToFile(fatBytes, savePath + "/fat.bin", 0, static_cast<uint32_t>(fatBytes.size())).result)
|
|
||||||
return NFResult({ false, "Error writing to file: " + savePath + "/fat.bin" });
|
|
||||||
|
|
||||||
return NFResult({ true, "" });
|
|
||||||
}
|
|
||||||
|
|
||||||
uint16_t NDSFactory::calcHeaderCrc16(const std::vector<char>& romHeader)
|
uint16_t NDSFactory::calcHeaderCrc16(const std::vector<char>& romHeader)
|
||||||
{
|
{
|
||||||
uint8_t loc;
|
uint8_t loc;
|
||||||
|
@ -5,28 +5,27 @@
|
|||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include "ndsheader.h"
|
#include "ndsheader.h"
|
||||||
#include "fatstruct.h"
|
#include "fatstruct.h"
|
||||||
#include "nfresult.h"
|
|
||||||
|
|
||||||
|
|
||||||
class NDSFactory
|
class NDSFactory
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
NFResult loadRomHeader(const std::string& romPath, std::vector<char>& header);
|
NDSFactory();
|
||||||
NFResult dumpDataFromFile(const std::string& romPath, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
bool loadRomHeader(const std::string& romPath, std::vector<char>& header);
|
||||||
NFResult readBytesFromFile(std::vector<char>& byteBuffer, const std::string& romPath, uint32_t startAddr, uint32_t size);
|
bool dumpDataFromFile(const std::string& romPath, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
||||||
NFResult writeSectionToFile(const std::string& sectionPath, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
bool readBytesFromFile(std::vector<char>& byteBuffer, const std::string& romPath, uint32_t startAddr, uint32_t size);
|
||||||
NFResult writeBytesToFile(std::vector<char>& byteBuffer, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
bool writeSectionToFile(const std::string& sectionPath, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
||||||
NFResult writePaddingToFile(char paddingChar, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
bool writeBytesToFile(std::vector<char>& byteBuffer, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
||||||
|
bool writePaddingToFile(char paddingChar, const std::string& savePath, uint32_t startAddr, uint32_t size);
|
||||||
int getCardSizeInBytes(int cardType);
|
int getCardSizeInBytes(int cardType);
|
||||||
bool checkArm9FooterPresence(const std::string& sectionPath, uint32_t size);
|
bool checkArm9FooterPresence(const std::string& sectionPath, uint32_t size);
|
||||||
NFResult extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
bool extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
||||||
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath, bool logFileIDs);
|
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath);
|
||||||
NFResult patchFat(const std::string& sectionPath, uint32_t shiftSize, const std::string& savePath);
|
bool patchFat(const std::string& sectionPath, uint32_t shiftSize, const std::string& savePath);
|
||||||
NFResult buildFatData(const std::string& fatDataDirPath, const std::string& originalFatPath, uint32_t fatDataAddr, const std::string& savePath);
|
|
||||||
uint16_t calcHeaderCrc16(const std::vector<char>& romHeader);
|
uint16_t calcHeaderCrc16(const std::vector<char>& romHeader);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool logToFile(const std::string& logPath, const std::string& log);
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,9 +0,0 @@
|
|||||||
#pragma once
|
|
||||||
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
struct NFResult
|
|
||||||
{
|
|
||||||
bool result;
|
|
||||||
std::string message;
|
|
||||||
};
|
|
BIN
screenshot.png
BIN
screenshot.png
Binary file not shown.
Before Width: | Height: | Size: 45 KiB After Width: | Height: | Size: 62 KiB |
@ -42,7 +42,7 @@
|
|||||||
<bool>false</bool>
|
<bool>false</bool>
|
||||||
</property>
|
</property>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>NDSFactory V1.3.2</string>
|
<string>NDS Factory V1.2</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="alignment">
|
<property name="alignment">
|
||||||
<set>Qt::AlignmentFlag::AlignCenter</set>
|
<set>Qt::AlignmentFlag::AlignCenter</set>
|
||||||
@ -58,7 +58,7 @@
|
|||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>(C) 2019-2025 - Luca D'Amico</string>
|
<string>(C) 2019-2024 - Luca D'Amico</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="alignment">
|
<property name="alignment">
|
||||||
<set>Qt::AlignmentFlag::AlignCenter</set>
|
<set>Qt::AlignmentFlag::AlignCenter</set>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#ifndef REVISION_H
|
#ifndef REVISION_H
|
||||||
#define REVISION_H
|
#define REVISION_H
|
||||||
|
|
||||||
#define GIT_COMMIT_HASH "c916f47"
|
#define GIT_COMMIT_HASH "e788d95"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -58,9 +58,6 @@ private slots:
|
|||||||
void on_fatExtractorLoadFatBtn_clicked();
|
void on_fatExtractorLoadFatBtn_clicked();
|
||||||
void on_fatExtractorLoadFntBtn_clicked();
|
void on_fatExtractorLoadFntBtn_clicked();
|
||||||
void on_fatExtractorExtractBtn_clicked();
|
void on_fatExtractorExtractBtn_clicked();
|
||||||
void on_fatBuilderOpenFatDataDirBtn_clicked();
|
|
||||||
void on_fatBuilderLoadOriginalFatBtn_clicked();
|
|
||||||
void on_fatBuilderBuildBtn_clicked();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::MainWindow *ui;
|
Ui::MainWindow *ui;
|
||||||
@ -69,48 +66,48 @@ private:
|
|||||||
void populateHeader(NDSHeader* ndsHeader);
|
void populateHeader(NDSHeader* ndsHeader);
|
||||||
void enableExtractionButtons();
|
void enableExtractionButtons();
|
||||||
void disableExtractionButtons();
|
void disableExtractionButtons();
|
||||||
NFResult dumpHeader(const std::string& dirPath);
|
bool dumpHeader(const std::string& dirPath);
|
||||||
NFResult dumpArm9Bin(const std::string& dirPath, bool dumpExtraBytes);
|
bool dumpArm9Bin(const std::string& dirPath, bool dumpExtraBytes);
|
||||||
NFResult dumpArm7Bin(const std::string& dirPath);
|
bool dumpArm7Bin(const std::string& dirPath);
|
||||||
NFResult dumpFnt(const std::string& dirPath);
|
bool dumpFnt(const std::string& dirPath);
|
||||||
NFResult dumpFat(const std::string& dirPath);
|
bool dumpFat(const std::string& dirPath);
|
||||||
NFResult dumpArm9Overlay(const std::string& dirPath);
|
bool dumpArm9Overlay(const std::string& dirPath);
|
||||||
NFResult dumpArm9OverlayFiles(const std::string& dirPath);
|
bool dumpArm9OverlayFiles(const std::string& dirPath);
|
||||||
NFResult dumpArm7Overlay(const std::string& dirPath);
|
bool dumpArm7Overlay(const std::string& dirPath);
|
||||||
NFResult dumpArm7OverlayFiles(const std::string& dirPath);
|
bool dumpArm7OverlayFiles(const std::string& dirPath);
|
||||||
NFResult dumpIconTitle(const std::string& dirPath);
|
bool dumpIconTitle(const std::string& dirPath);
|
||||||
NFResult dumpFatFiles(const std::string& dirPath);
|
bool dumpFatFiles(const std::string& dirPath);
|
||||||
NFResult dumpEverything(QString dirPath);
|
bool dumpEverything(QString dirPath);
|
||||||
|
void notifyExtractionResult(bool result);
|
||||||
|
|
||||||
void populatePackerSectionHeader(NDSHeader *ndsHeader);
|
void populatePackerSectionHeader(NDSHeader *ndsHeader);
|
||||||
void enableCalcCrcButton();
|
void enableCalcCrcButton();
|
||||||
void enableBuildRomButton();
|
void enableBuildRomButton();
|
||||||
void generateHeader(NDSHeader* pRomHeader);
|
void generateHeader(NDSHeader* pRomHeader);
|
||||||
NFResult writeHeader(const std::string& savePath);
|
bool writeHeader(const std::string& savePath);
|
||||||
void calcHeaderCrc16();
|
void calcHeaderCrc16();
|
||||||
NFResult writeArm9Bin(const std::string& savePath, bool isArm9FooterPresent);
|
bool writeArm9Bin(const std::string& savePath, bool isArm9FooterPresent);
|
||||||
NFResult writeArm7Bin(const std::string& savePath);
|
bool writeArm7Bin(const std::string& savePath);
|
||||||
NFResult writeFnt(const std::string& savePath);
|
bool writeFnt(const std::string& savePath);
|
||||||
NFResult writeFat(const std::string& savePath);
|
bool writeFat(const std::string& savePath);
|
||||||
NFResult writeArm9Overlay(const std::string& savePath);
|
bool writeArm9Overlay(const std::string& savePath);
|
||||||
NFResult writeArm9OverlayFiles(const std::string& savePath);
|
bool writeArm9OverlayFiles(const std::string& savePath);
|
||||||
NFResult writeArm7Overlay(const std::string& savePath);
|
bool writeArm7Overlay(const std::string& savePath);
|
||||||
NFResult writeArm7OverlayFiles(const std::string& savePath);
|
bool writeArm7OverlayFiles(const std::string& savePath);
|
||||||
NFResult writeIconTitle(const std::string& savePath);
|
bool writeIconTitle(const std::string& savePath);
|
||||||
NFResult writeFatFiles(const std::string& savePath);
|
bool writeFatFiles(const std::string& savePath);
|
||||||
NFResult writeEverything(const std::string& savePath);
|
bool writeEverything(const std::string& savePath);
|
||||||
|
|
||||||
NFResult writeHeaderPadding(char paddingByte, const std::string& savePath);
|
bool writeHeaderPadding(char paddingByte, const std::string& savePath);
|
||||||
NFResult writeArm9BinPadding(char paddingByte, const std::string& savePath, bool isArm9FooterPresent);
|
bool writeArm9BinPadding(char paddingByte, const std::string& savePath, bool isArm9FooterPresent);
|
||||||
NFResult writeArm7BinPadding(char paddingByte, const std::string& savePath);
|
bool writeArm7BinPadding(char paddingByte, const std::string& savePath);
|
||||||
NFResult writeFntPadding(char paddingByte, const std::string& savePath);
|
bool writeFntPadding(char paddingByte, const std::string& savePath);
|
||||||
NFResult writeFatPadding(char paddingByte, const std::string& savePath);
|
bool writeFatPadding(char paddingByte, const std::string& savePath);
|
||||||
NFResult writeRomPadding(const std::string& savePath);
|
bool writeRomPadding(const std::string& savePath);
|
||||||
|
|
||||||
QString extractPackerHeaderTableData(int index);
|
QString extractPackerHeaderTableData(int index);
|
||||||
|
|
||||||
NFResult extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
bool extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
||||||
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath, bool logFileIDs);
|
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath);
|
||||||
NFResult patchFat(const std::string& loadPath, uint32_t shiftSize, const std::string& savePath);
|
bool patchFat(const std::string& loadPath, uint32_t shiftSize, const std::string& savePath);
|
||||||
NFResult buildFatData(const std::string& fatDataDirPath, const std::string& originalFatPath, uint32_t fatDataAddr, const std::string& savePath);
|
|
||||||
};
|
};
|
||||||
|
@ -697,17 +697,6 @@
|
|||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_8">
|
|
||||||
<item>
|
|
||||||
<widget class="QCheckBox" name="fatExtractorSaveFileIDsCbx">
|
|
||||||
<property name="text">
|
|
||||||
<string>Save file IDs to _file_IDs.txt (required for rebuilding FAT)</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
<item>
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_41">
|
<layout class="QHBoxLayout" name="horizontalLayout_41">
|
||||||
<property name="leftMargin">
|
<property name="leftMargin">
|
||||||
@ -736,83 +725,6 @@
|
|||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_17">
|
|
||||||
<item>
|
|
||||||
<widget class="QGroupBox" name="groupBox_8">
|
|
||||||
<property name="title">
|
|
||||||
<string>FAT Builder</string>
|
|
||||||
</property>
|
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_18">
|
|
||||||
<item>
|
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_19">
|
|
||||||
<item>
|
|
||||||
<widget class="QLabel" name="label_3">
|
|
||||||
<property name="text">
|
|
||||||
<string>Original fat.bin is required ONLY if the ROM has an overlay...</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_9">
|
|
||||||
<item>
|
|
||||||
<widget class="QLineEdit" name="fatBuilderFatDirPathEdt"/>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<widget class="QPushButton" name="fatBuilderOpenFatDataDirBtn">
|
|
||||||
<property name="text">
|
|
||||||
<string>Open FAT Data Directory</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_12">
|
|
||||||
<item>
|
|
||||||
<widget class="QLineEdit" name="fatBuilderOriginalFatPathEdt"/>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<widget class="QPushButton" name="fatBuilderLoadOriginalFatBtn">
|
|
||||||
<property name="text">
|
|
||||||
<string>Load Original fat.bin</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_11">
|
|
||||||
<item>
|
|
||||||
<widget class="QLabel" name="label_2">
|
|
||||||
<property name="text">
|
|
||||||
<string>Fat Files (fat_data.bin) Addr:</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<widget class="QLineEdit" name="fatBuilderFatAddrEdt"/>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_10">
|
|
||||||
<item>
|
|
||||||
<widget class="QPushButton" name="fatBuilderBuildBtn">
|
|
||||||
<property name="text">
|
|
||||||
<string>Build!</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
|
||||||
</item>
|
|
||||||
<item>
|
<item>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_12">
|
<layout class="QVBoxLayout" name="verticalLayout_12">
|
||||||
<item>
|
<item>
|
||||||
|
@ -151,7 +151,7 @@ bool NDSHeaderModel::setData(const QModelIndex &index, const QVariant &value, in
|
|||||||
case 37: ndsHeader->DebugRomAddr = static_cast<uint32_t>(value.toString().toUInt(nullptr, 16)); break;
|
case 37: ndsHeader->DebugRomAddr = static_cast<uint32_t>(value.toString().toUInt(nullptr, 16)); break;
|
||||||
case 38: ndsHeader->DebugSize = static_cast<uint32_t>(value.toString().toUInt(nullptr, 16)); break;
|
case 38: ndsHeader->DebugSize = static_cast<uint32_t>(value.toString().toUInt(nullptr, 16)); break;
|
||||||
case 39: ndsHeader->DebugRamAddr = static_cast<uint32_t>(value.toString().toUInt(nullptr, 16)); break;
|
case 39: ndsHeader->DebugRamAddr = static_cast<uint32_t>(value.toString().toUInt(nullptr, 16)); break;
|
||||||
case 40: QMessageBox::information(nullptr, tr("NDSFactory"), tr("FAT files address is automatically calculated based on Icon/Title address!")); break;
|
case 40: QMessageBox::information(nullptr, tr("NDS Factory"), tr("FAT files address is automatically calculated based on Icon/Title address!")); break;
|
||||||
default: return false;
|
default: return false;
|
||||||
}
|
}
|
||||||
Q_EMIT this->dataChanged(index, index);
|
Q_EMIT this->dataChanged(index, index);
|
||||||
|
@ -1,19 +1,13 @@
|
|||||||
#include <filesystem>
|
|
||||||
#include "./../../mainwindow.h"
|
#include "./../../mainwindow.h"
|
||||||
|
|
||||||
|
|
||||||
NFResult MainWindow::extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
bool MainWindow::extractFatData(const std::string& fatDataSectionPath, const std::string& fatSectionPath,
|
||||||
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath, bool logFileIDs)
|
const std::string& fntSectionPath, uint32_t originalFatDataAddr, const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.extractFatData(fatDataSectionPath, fatSectionPath, fntSectionPath, originalFatDataAddr, savePath, logFileIDs);
|
return ndsFactory.extractFatData(fatDataSectionPath, fatSectionPath, fntSectionPath, originalFatDataAddr, savePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::patchFat(const std::string& loadPath, uint32_t shiftSize, const std::string& savePath)
|
bool MainWindow::patchFat(const std::string& loadPath, uint32_t shiftSize, const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.patchFat(loadPath, shiftSize, savePath);
|
return ndsFactory.patchFat(loadPath, shiftSize, savePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::buildFatData(const std::string& fatDataDirPath, const std::string& originalFatPath, uint32_t fatDataAddr, const std::string& savePath)
|
|
||||||
{
|
|
||||||
return ndsFactory.buildFatData(fatDataDirPath, originalFatPath, fatDataAddr, savePath);
|
|
||||||
}
|
|
||||||
|
@ -2,14 +2,13 @@
|
|||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include "./../../mainwindow.h"
|
#include "./../../mainwindow.h"
|
||||||
#include "./../../ui_mainwindow.h"
|
#include "./../../ui_mainwindow.h"
|
||||||
#include "./../../utils/filepicker.h"
|
|
||||||
|
|
||||||
void MainWindow::on_fatExtractorLoadFatDataBtn_clicked()
|
void MainWindow::on_fatExtractorLoadFatDataBtn_clicked()
|
||||||
{
|
{
|
||||||
QString FatDataPath = QFileDialog::getOpenFileName(
|
QString FatDataPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fat Data",
|
"NDS Fat Data",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS FAT_DATA (*.bin)");
|
"NDS FAT_DATA (*.bin)");
|
||||||
|
|
||||||
if (!FatDataPath.isNull())
|
if (!FatDataPath.isNull())
|
||||||
@ -23,7 +22,7 @@ void MainWindow::on_fatExtractorLoadFatBtn_clicked()
|
|||||||
QString FatPath = QFileDialog::getOpenFileName(
|
QString FatPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fat",
|
"NDS Fat",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS FAT (*.bin)");
|
"NDS FAT (*.bin)");
|
||||||
|
|
||||||
if (!FatPath.isNull())
|
if (!FatPath.isNull())
|
||||||
@ -37,7 +36,7 @@ void MainWindow::on_fatExtractorLoadFntBtn_clicked()
|
|||||||
QString FntPath = QFileDialog::getOpenFileName(
|
QString FntPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fnt",
|
"NDS Fnt",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS FNT (*.bin)");
|
"NDS FNT (*.bin)");
|
||||||
|
|
||||||
if (!FntPath.isNull())
|
if (!FntPath.isNull())
|
||||||
@ -48,25 +47,18 @@ void MainWindow::on_fatExtractorLoadFntBtn_clicked()
|
|||||||
|
|
||||||
void MainWindow::on_fatExtractorExtractBtn_clicked()
|
void MainWindow::on_fatExtractorExtractBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->fatExtractorExtractBtn->setEnabled(false);
|
|
||||||
|
|
||||||
QString dirPath = QFileDialog::getExistingDirectory(
|
QString dirPath = QFileDialog::getExistingDirectory(
|
||||||
this, tr("Select Directory"),
|
this, tr("Select Directory"),
|
||||||
"",
|
"",
|
||||||
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
|
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
|
||||||
|
|
||||||
if (!dirPath.isNull()) {
|
if (!dirPath.isNull())
|
||||||
NFResult nfResult = extractFatData(ui->fatExtractorFatDataPathEdt->text().toStdString(),
|
extractFatData(ui->fatExtractorFatDataPathEdt->text().toStdString(),
|
||||||
ui->fatExtractorFatPathEdt->text().toStdString(),
|
ui->fatExtractorFatPathEdt->text().toStdString(),
|
||||||
ui->fatExtractorFntPathEdt->text().toStdString(),
|
ui->fatExtractorFntPathEdt->text().toStdString(),
|
||||||
ui->fatExtractorOriginalFatFilesAddrEdt->text().toUInt(nullptr, 16),
|
ui->fatExtractorOriginalFatFilesAddrEdt->text().toUInt(nullptr, 16),
|
||||||
dirPath.toStdString(),
|
dirPath.toStdString()) ? QMessageBox::information(this, tr("NDS Factory"), tr("FAT files extraction completed!"))
|
||||||
ui->fatExtractorSaveFileIDsCbx->isChecked());
|
: QMessageBox::critical(this, tr("NDS Factory"), tr("Error extracting FAT files!"));
|
||||||
nfResult.result? QMessageBox::information(this, tr("NDSFactory"), tr("FAT files extraction completed!"))
|
|
||||||
: QMessageBox::critical(this, tr("NDSFactory"), nfResult.message.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
ui->fatExtractorExtractBtn->setEnabled(true);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,81 +67,41 @@ void MainWindow::on_fatPatcherLoadFatBtn_clicked()
|
|||||||
QString fatPath = QFileDialog::getOpenFileName(
|
QString fatPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fat",
|
"NDS Fat",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS Fat (*.bin)");
|
"NDS Fat (*.bin)");
|
||||||
|
|
||||||
if(!fatPath.isNull())
|
if( !fatPath.isNull() )
|
||||||
ui->fatPatcherFatPathEdt->setText(fatPath.toUtf8());
|
{
|
||||||
|
ui->fatPatcherFatPathEdt->setText(fatPath.toUtf8());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_fatPatcherPatchFatBtn_clicked()
|
void MainWindow::on_fatPatcherPatchFatBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->fatPatcherPatchFatBtn->setEnabled(false);
|
|
||||||
|
|
||||||
uint32_t positionDiff = 0;
|
uint32_t positionDiff = 0;
|
||||||
uint32_t originalPos = ui->fatPatcherOriginalFatFilesAddrEdt->text().toUInt(nullptr, 16);
|
uint32_t originalPos = ui->fatPatcherOriginalFatFilesAddrEdt->text().toUInt(nullptr, 16);
|
||||||
uint32_t newPos = ui->fatPatcherNewFatFilesAddrEdt->text().toUInt(nullptr, 16);
|
uint32_t newPos = ui->fatPatcherNewFatFilesAddrEdt->text().toUInt(nullptr, 16);
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS FAT",
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
"fat.bin",
|
Q_NULLPTR,
|
||||||
"Binary (*.bin)");
|
"NDS FAT",
|
||||||
|
"fat.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
if (!dirPath.isNull())
|
if(dirPath.isNull())
|
||||||
{
|
{
|
||||||
if(originalPos < newPos)
|
return;
|
||||||
positionDiff = newPos - originalPos;
|
|
||||||
else
|
|
||||||
positionDiff = originalPos - newPos;
|
|
||||||
|
|
||||||
NFResult nfResult = patchFat(ui->fatPatcherFatPathEdt->text().toStdString(), positionDiff, dirPath.toStdString());
|
|
||||||
nfResult.result ? QMessageBox::information(this, tr("NDSFactory"), tr("FAT patching completed!"))
|
|
||||||
: QMessageBox::critical(this, tr("NDSFactory"), nfResult.message.c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ui->fatPatcherPatchFatBtn->setEnabled(true);
|
if (originalPos < newPos)
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::on_fatBuilderOpenFatDataDirBtn_clicked()
|
|
||||||
{
|
|
||||||
QString fatDirPat = QFileDialog::getExistingDirectory(
|
|
||||||
this, tr("Select Directory"),
|
|
||||||
"",
|
|
||||||
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
|
|
||||||
|
|
||||||
if (!fatDirPat.isNull())
|
|
||||||
ui->fatBuilderFatDirPathEdt->setText(fatDirPat.toUtf8());
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::on_fatBuilderLoadOriginalFatBtn_clicked()
|
|
||||||
{
|
|
||||||
QString fatPath = QFileDialog::getOpenFileName(
|
|
||||||
Q_NULLPTR,
|
|
||||||
"NDS Fat",
|
|
||||||
"",
|
|
||||||
"NDS Fat (*.bin)");
|
|
||||||
|
|
||||||
if (!fatPath.isNull())
|
|
||||||
ui->fatBuilderOriginalFatPathEdt->setText(fatPath.toUtf8());
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::on_fatBuilderBuildBtn_clicked()
|
|
||||||
{
|
|
||||||
ui->fatBuilderOpenFatDataDirBtn->setEnabled(false);
|
|
||||||
|
|
||||||
QString dirPath = QFileDialog::getExistingDirectory(
|
|
||||||
this, tr("Select Directory"),
|
|
||||||
"",
|
|
||||||
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
|
|
||||||
|
|
||||||
if (!dirPath.isNull())
|
|
||||||
{
|
{
|
||||||
NFResult nfResult = buildFatData(ui->fatBuilderFatDirPathEdt->text().toStdString(),
|
positionDiff = newPos-originalPos;
|
||||||
ui->fatBuilderOriginalFatPathEdt->text().toStdString(),
|
} else {
|
||||||
ui->fatBuilderFatAddrEdt->text().toUInt(nullptr, 16),
|
positionDiff = originalPos-newPos;
|
||||||
dirPath.toStdString());
|
|
||||||
nfResult.result? QMessageBox::information(this, tr("NDSFactory"), tr("fat_data.bin and fat.bin correctly built!"))
|
|
||||||
: QMessageBox::critical(this, tr("NDSFactory"), nfResult.message.c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ui->fatBuilderOpenFatDataDirBtn->setEnabled(true);
|
patchFat(ui->fatPatcherFatPathEdt->text().toStdString(), positionDiff, dirPath.toStdString())
|
||||||
}
|
? QMessageBox::information(this, tr("NDS Factory"), tr("FAT patching completed!"))
|
||||||
|
: QMessageBox::critical(this, tr("NDS Factory"), tr("Error patching FAT!"));
|
||||||
|
|
||||||
|
}
|
||||||
|
@ -102,17 +102,17 @@ void MainWindow::calcHeaderCrc16()
|
|||||||
ui->packerHeaderDataTable->model()->setData(headerCrcIndex, QString::number(ndsFactory.calcHeaderCrc16(romHeaderBuffer), 16), Qt::EditRole);
|
ui->packerHeaderDataTable->model()->setData(headerCrcIndex, QString::number(ndsFactory.calcHeaderCrc16(romHeaderBuffer), 16), Qt::EditRole);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeHeader(const std::string& savePath)
|
bool MainWindow::writeHeader(const std::string& savePath)
|
||||||
{
|
{
|
||||||
std::vector<char> romHeaderBuffer(sizeof(NDSHeader));
|
std::vector<char> romHeaderBuffer(sizeof(NDSHeader));
|
||||||
NDSHeader* pRomHeader = reinterpret_cast<NDSHeader*>(romHeaderBuffer.data());
|
NDSHeader* pRomHeader = reinterpret_cast<NDSHeader*>(romHeaderBuffer.data());
|
||||||
|
|
||||||
generateHeader(pRomHeader);
|
generateHeader(pRomHeader);
|
||||||
|
|
||||||
return ndsFactory.writeBytesToFile(romHeaderBuffer, savePath, 0, sizeof(NDSHeader));
|
return ndsFactory.writeBytesToFile(romHeaderBuffer, savePath, 0, sizeof(NDSHeader));;
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeHeaderPadding(char paddingType, const std::string& savePath)
|
bool MainWindow::writeHeaderPadding(char paddingType, const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = sizeof(NDSHeader);
|
uint32_t startAddr = sizeof(NDSHeader);
|
||||||
uint32_t size = extractPackerHeaderTableData(NDSHeaderNames::ARM9RomAddress).toUInt(nullptr, 16) - startAddr;
|
uint32_t size = extractPackerHeaderTableData(NDSHeaderNames::ARM9RomAddress).toUInt(nullptr, 16) - startAddr;
|
||||||
@ -124,7 +124,7 @@ NFResult MainWindow::writeHeaderPadding(char paddingType, const std::string& sav
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm9Bin(const std::string& savePath, bool isArm9FooterPresent)
|
bool MainWindow::writeArm9Bin(const std::string& savePath, bool isArm9FooterPresent)
|
||||||
{
|
{
|
||||||
uint32_t size = extractPackerHeaderTableData(NDSHeaderNames::ARM9Size).toUInt(nullptr, 16);
|
uint32_t size = extractPackerHeaderTableData(NDSHeaderNames::ARM9Size).toUInt(nullptr, 16);
|
||||||
if (isArm9FooterPresent)
|
if (isArm9FooterPresent)
|
||||||
@ -137,7 +137,7 @@ NFResult MainWindow::writeArm9Bin(const std::string& savePath, bool isArm9Footer
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
NFResult MainWindow::writeArm9BinPadding(char paddingType, const std::string& savePath, bool isFooterPresent)
|
bool MainWindow::writeArm9BinPadding(char paddingType, const std::string& savePath, bool isFooterPresent)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM9RomAddress).toUInt(nullptr, 16) +
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM9RomAddress).toUInt(nullptr, 16) +
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM9Size).toUInt(nullptr, 16);
|
extractPackerHeaderTableData(NDSHeaderNames::ARM9Size).toUInt(nullptr, 16);
|
||||||
@ -148,10 +148,7 @@ NFResult MainWindow::writeArm9BinPadding(char paddingType, const std::string& sa
|
|||||||
size = extractPackerHeaderTableData(NDSHeaderNames::ARM7RomAddress).toUInt(nullptr, 16) - startAddr;
|
size = extractPackerHeaderTableData(NDSHeaderNames::ARM7RomAddress).toUInt(nullptr, 16) - startAddr;
|
||||||
|
|
||||||
if (isFooterPresent)
|
if (isFooterPresent)
|
||||||
{
|
|
||||||
startAddr += Arm9FooterSize;
|
|
||||||
size -= Arm9FooterSize;
|
size -= Arm9FooterSize;
|
||||||
}
|
|
||||||
|
|
||||||
return ndsFactory.writePaddingToFile(
|
return ndsFactory.writePaddingToFile(
|
||||||
paddingType,
|
paddingType,
|
||||||
@ -160,7 +157,7 @@ NFResult MainWindow::writeArm9BinPadding(char paddingType, const std::string& sa
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm9Overlay(const std::string& savePath)
|
bool MainWindow::writeArm9Overlay(const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.writeSectionToFile(
|
return ndsFactory.writeSectionToFile(
|
||||||
ui->loadedArm9OverlayPathEdt->text().toStdString(),
|
ui->loadedArm9OverlayPathEdt->text().toStdString(),
|
||||||
@ -169,7 +166,7 @@ NFResult MainWindow::writeArm9Overlay(const std::string& savePath)
|
|||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlaySize).toUInt(nullptr, 16));
|
extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlaySize).toUInt(nullptr, 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm9OverlayFiles(const std::string& savePath)
|
bool MainWindow::writeArm9OverlayFiles(const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlayAddress).toUInt(nullptr, 16) +
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlayAddress).toUInt(nullptr, 16) +
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlaySize).toUInt(nullptr, 16);
|
extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlaySize).toUInt(nullptr, 16);
|
||||||
@ -181,7 +178,7 @@ NFResult MainWindow::writeArm9OverlayFiles(const std::string& savePath)
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm7Bin(const std::string& savePath)
|
bool MainWindow::writeArm7Bin(const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.writeSectionToFile(
|
return ndsFactory.writeSectionToFile(
|
||||||
ui->loadedArm7BinPathEdt->text().toStdString(),
|
ui->loadedArm7BinPathEdt->text().toStdString(),
|
||||||
@ -190,7 +187,7 @@ NFResult MainWindow::writeArm7Bin(const std::string& savePath)
|
|||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM7Size).toUInt(nullptr, 16));
|
extractPackerHeaderTableData(NDSHeaderNames::ARM7Size).toUInt(nullptr, 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm7BinPadding(char paddingType, const std::string& savePath)
|
bool MainWindow::writeArm7BinPadding(char paddingType, const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM7RomAddress).toUInt(nullptr, 16) +
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM7RomAddress).toUInt(nullptr, 16) +
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM7Size).toUInt(nullptr, 16);
|
extractPackerHeaderTableData(NDSHeaderNames::ARM7Size).toUInt(nullptr, 16);
|
||||||
@ -207,7 +204,7 @@ NFResult MainWindow::writeArm7BinPadding(char paddingType, const std::string& sa
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm7Overlay(const std::string& savePath)
|
bool MainWindow::writeArm7Overlay(const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.writeSectionToFile(
|
return ndsFactory.writeSectionToFile(
|
||||||
ui->loadedArm7OverlayPathEdt->text().toStdString(),
|
ui->loadedArm7OverlayPathEdt->text().toStdString(),
|
||||||
@ -216,7 +213,7 @@ NFResult MainWindow::writeArm7Overlay(const std::string& savePath)
|
|||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlaySize).toUInt(nullptr, 16));
|
extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlaySize).toUInt(nullptr, 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeArm7OverlayFiles(const std::string& savePath)
|
bool MainWindow::writeArm7OverlayFiles(const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlayAddress).toUInt(nullptr, 16) +
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlayAddress).toUInt(nullptr, 16) +
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlaySize).toUInt(nullptr, 16);
|
extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlaySize).toUInt(nullptr, 16);
|
||||||
@ -228,7 +225,7 @@ NFResult MainWindow::writeArm7OverlayFiles(const std::string& savePath)
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeFnt(const std::string& savePath)
|
bool MainWindow::writeFnt(const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.writeSectionToFile(
|
return ndsFactory.writeSectionToFile(
|
||||||
ui->loadedFntPathEdt->text().toStdString(),
|
ui->loadedFntPathEdt->text().toStdString(),
|
||||||
@ -237,7 +234,7 @@ NFResult MainWindow::writeFnt(const std::string& savePath)
|
|||||||
extractPackerHeaderTableData(NDSHeaderNames::FilenameTableSize).toUInt(nullptr, 16));
|
extractPackerHeaderTableData(NDSHeaderNames::FilenameTableSize).toUInt(nullptr, 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeFntPadding(char paddingType, const std::string& savePath)
|
bool MainWindow::writeFntPadding(char paddingType, const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::FilenameTableAddress).toUInt(nullptr, 16) +
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::FilenameTableAddress).toUInt(nullptr, 16) +
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::FilenameTableSize).toUInt(nullptr, 16);
|
extractPackerHeaderTableData(NDSHeaderNames::FilenameTableSize).toUInt(nullptr, 16);
|
||||||
@ -250,7 +247,7 @@ NFResult MainWindow::writeFntPadding(char paddingType, const std::string& savePa
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeFat(const std::string& savePath)
|
bool MainWindow::writeFat(const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.writeSectionToFile(
|
return ndsFactory.writeSectionToFile(
|
||||||
ui->loadedFatPathEdt->text().toStdString(),
|
ui->loadedFatPathEdt->text().toStdString(),
|
||||||
@ -259,7 +256,7 @@ NFResult MainWindow::writeFat(const std::string& savePath)
|
|||||||
extractPackerHeaderTableData(NDSHeaderNames::FATSize).toUInt(nullptr, 16));
|
extractPackerHeaderTableData(NDSHeaderNames::FATSize).toUInt(nullptr, 16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeFatPadding(char paddingType, const std::string& savePath)
|
bool MainWindow::writeFatPadding(char paddingType, const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::FATAddress).toUInt(nullptr, 16) +
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::FATAddress).toUInt(nullptr, 16) +
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::FATSize).toUInt(nullptr, 16);
|
extractPackerHeaderTableData(NDSHeaderNames::FATSize).toUInt(nullptr, 16);
|
||||||
@ -272,7 +269,7 @@ NFResult MainWindow::writeFatPadding(char paddingType, const std::string& savePa
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeIconTitle(const std::string& savePath)
|
bool MainWindow::writeIconTitle(const std::string& savePath)
|
||||||
{
|
{
|
||||||
return ndsFactory.writeSectionToFile(
|
return ndsFactory.writeSectionToFile(
|
||||||
ui->loadedIconTitlePathEdt->text().toStdString(),
|
ui->loadedIconTitlePathEdt->text().toStdString(),
|
||||||
@ -281,7 +278,7 @@ NFResult MainWindow::writeIconTitle(const std::string& savePath)
|
|||||||
IconTitleSize);
|
IconTitleSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeFatFiles(const std::string& savePath)
|
bool MainWindow::writeFatFiles(const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::IconTitleAddress).toUInt(nullptr, 16) + IconTitleSize;
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::IconTitleAddress).toUInt(nullptr, 16) + IconTitleSize;
|
||||||
uint32_t size = extractPackerHeaderTableData(NDSHeaderNames::UsedRomSize).toUInt(nullptr, 16) - startAddr;
|
uint32_t size = extractPackerHeaderTableData(NDSHeaderNames::UsedRomSize).toUInt(nullptr, 16) - startAddr;
|
||||||
@ -293,7 +290,7 @@ NFResult MainWindow::writeFatFiles(const std::string& savePath)
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeRomPadding(const std::string& savePath)
|
bool MainWindow::writeRomPadding(const std::string& savePath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::UsedRomSize).toUInt(nullptr, 16);
|
uint32_t startAddr = extractPackerHeaderTableData(NDSHeaderNames::UsedRomSize).toUInt(nullptr, 16);
|
||||||
uint32_t size = static_cast<uint32_t>(ndsFactory.getCardSizeInBytes(extractPackerHeaderTableData(NDSHeaderNames::CardSize).toInt())) - startAddr;
|
uint32_t size = static_cast<uint32_t>(ndsFactory.getCardSizeInBytes(extractPackerHeaderTableData(NDSHeaderNames::CardSize).toInt())) - startAddr;
|
||||||
@ -305,9 +302,9 @@ NFResult MainWindow::writeRomPadding(const std::string& savePath)
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::writeEverything(const std::string& savePath)
|
bool MainWindow::writeEverything(const std::string& savePath)
|
||||||
{
|
{
|
||||||
NFResult nfResult;
|
bool res = true;
|
||||||
char paddingType;
|
char paddingType;
|
||||||
bool isArm9FooterPresent = ndsFactory.checkArm9FooterPresence(ui->loadedArm9BinPathEdt->text().toStdString(),
|
bool isArm9FooterPresent = ndsFactory.checkArm9FooterPresence(ui->loadedArm9BinPathEdt->text().toStdString(),
|
||||||
extractPackerHeaderTableData(NDSHeaderNames::ARM9Size).toUInt(nullptr, 16));
|
extractPackerHeaderTableData(NDSHeaderNames::ARM9Size).toUInt(nullptr, 16));
|
||||||
@ -318,49 +315,32 @@ NFResult MainWindow::writeEverything(const std::string& savePath)
|
|||||||
|
|
||||||
std::remove(savePath.c_str());
|
std::remove(savePath.c_str());
|
||||||
|
|
||||||
nfResult = writeHeader(savePath);
|
res &= writeHeader(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeHeaderPadding(paddingType, savePath);
|
||||||
nfResult = writeHeaderPadding(paddingType, savePath);
|
res &= writeArm9Bin(savePath, isArm9FooterPresent);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeArm9BinPadding(paddingType, savePath, isArm9FooterPresent);
|
||||||
nfResult = writeArm9Bin(savePath, isArm9FooterPresent);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
nfResult = writeArm9BinPadding(paddingType, savePath, isArm9FooterPresent);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
if (extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlayAddress).toUInt(nullptr, 16) != 0)
|
if (extractPackerHeaderTableData(NDSHeaderNames::ARM9OverlayAddress).toUInt(nullptr, 16) != 0)
|
||||||
{
|
{
|
||||||
nfResult = writeArm9Overlay(savePath);
|
res &= writeArm9Overlay(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeArm9OverlayFiles(savePath);
|
||||||
nfResult = writeArm9OverlayFiles(savePath);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
}
|
}
|
||||||
nfResult = writeArm7Bin(savePath);
|
res &= writeArm7Bin(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeArm7BinPadding(paddingType, savePath);
|
||||||
nfResult = writeArm7BinPadding(paddingType, savePath);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
if (extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlayAddress).toUInt(nullptr, 16) != 0) {
|
if (extractPackerHeaderTableData(NDSHeaderNames::ARM7OverlayAddress).toUInt(nullptr, 16) != 0) {
|
||||||
nfResult = writeArm7Overlay(savePath);
|
res &= writeArm7Overlay(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeArm7OverlayFiles(savePath);
|
||||||
nfResult = writeArm7OverlayFiles(savePath);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
}
|
}
|
||||||
nfResult = writeFnt(savePath);
|
res &= writeFnt(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeFntPadding(paddingType, savePath);
|
||||||
nfResult = writeFntPadding(paddingType, savePath);
|
res &= writeFat(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeFatPadding(paddingType, savePath);
|
||||||
nfResult = writeFat(savePath);
|
res &= writeIconTitle(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
res &= writeFatFiles(savePath);
|
||||||
nfResult = writeFatPadding(paddingType, savePath);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
nfResult = writeIconTitle(savePath);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
nfResult = writeFatFiles(savePath);
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
if(!ui->packerTrimRomsCbx->isChecked())
|
if(!ui->packerTrimRomsCbx->isChecked())
|
||||||
{
|
{
|
||||||
nfResult = writeRomPadding(savePath);
|
res &= writeRomPadding(savePath);
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
}
|
}
|
||||||
return { true, "" };
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString MainWindow::extractPackerHeaderTableData(int index)
|
QString MainWindow::extractPackerHeaderTableData(int index)
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include "./../../mainwindow.h"
|
#include "./../../mainwindow.h"
|
||||||
#include "./../../ui_mainwindow.h"
|
#include "./../../ui_mainwindow.h"
|
||||||
#include "./../../utils/filepicker.h"
|
|
||||||
#include "../commons/headernames.h"
|
#include "../commons/headernames.h"
|
||||||
|
|
||||||
|
|
||||||
@ -16,9 +15,13 @@ void MainWindow::on_packerLoadHeaderBtn_clicked()
|
|||||||
QDir::currentPath(),
|
QDir::currentPath(),
|
||||||
"NDS Header (*.bin)");
|
"NDS Header (*.bin)");
|
||||||
|
|
||||||
if (headerPath.isNull()) return;
|
if(headerPath.isNull())
|
||||||
|
{
|
||||||
|
QMessageBox::critical(this, tr("NDS Factory"), tr("Unable to open file!"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (ndsFactory.loadRomHeader(headerPath.toStdString(), romHeader).result)
|
if (ndsFactory.loadRomHeader(headerPath.toStdString(), romHeader))
|
||||||
{
|
{
|
||||||
pNDSHeader = reinterpret_cast<NDSHeader*>(romHeader.data());
|
pNDSHeader = reinterpret_cast<NDSHeader*>(romHeader.data());
|
||||||
populatePackerSectionHeader(pNDSHeader);
|
populatePackerSectionHeader(pNDSHeader);
|
||||||
@ -32,7 +35,7 @@ void MainWindow::on_packerLoadArm9BinBtn_clicked()
|
|||||||
QString arm9BinPath = QFileDialog::getOpenFileName(
|
QString arm9BinPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Arm9Bin",
|
"NDS Arm9Bin",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS Arm9Bin (*.bin)");
|
"NDS Arm9Bin (*.bin)");
|
||||||
|
|
||||||
if(!arm9BinPath.isNull())
|
if(!arm9BinPath.isNull())
|
||||||
@ -46,7 +49,7 @@ void MainWindow::on_packerLoadArm7BinBtn_clicked()
|
|||||||
QString arm7BinPath = QFileDialog::getOpenFileName(
|
QString arm7BinPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Arm7Bin",
|
"NDS Arm7Bin",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS Arm7Bin (*.bin)");
|
"NDS Arm7Bin (*.bin)");
|
||||||
|
|
||||||
if(!arm7BinPath.isNull())
|
if(!arm7BinPath.isNull())
|
||||||
@ -60,7 +63,7 @@ void MainWindow::on_packerLoadFntBtn_clicked()
|
|||||||
QString fntPath = QFileDialog::getOpenFileName(
|
QString fntPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fnt",
|
"NDS Fnt",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS Fnt (*.bin)");
|
"NDS Fnt (*.bin)");
|
||||||
|
|
||||||
if(!fntPath.isNull())
|
if(!fntPath.isNull())
|
||||||
@ -74,7 +77,7 @@ void MainWindow::on_packerLoadFatBtn_clicked()
|
|||||||
QString fatPath = QFileDialog::getOpenFileName(
|
QString fatPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fat",
|
"NDS Fat",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS Fat (*.bin)");
|
"NDS Fat (*.bin)");
|
||||||
|
|
||||||
if(!fatPath.isNull())
|
if(!fatPath.isNull())
|
||||||
@ -88,7 +91,7 @@ void MainWindow::on_packerLoadArm9OverlayBtn_clicked()
|
|||||||
QString arm9OverlayPath = QFileDialog::getOpenFileName(
|
QString arm9OverlayPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Arm9Overlay",
|
"NDS Arm9Overlay",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS A9OVR (*.bin)");
|
"NDS A9OVR (*.bin)");
|
||||||
|
|
||||||
if( !arm9OverlayPath.isNull() )
|
if( !arm9OverlayPath.isNull() )
|
||||||
@ -102,7 +105,7 @@ void MainWindow::on_packerLoadArm9OverlayFilesBtn_clicked()
|
|||||||
QString arm9OverlayFilesPath = QFileDialog::getOpenFileName(
|
QString arm9OverlayFilesPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Arm9Overlay Data",
|
"NDS Arm9Overlay Data",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS A9OVR_DATA (*.bin)");
|
"NDS A9OVR_DATA (*.bin)");
|
||||||
|
|
||||||
if(!arm9OverlayFilesPath.isNull())
|
if(!arm9OverlayFilesPath.isNull())
|
||||||
@ -116,7 +119,7 @@ void MainWindow::on_packerLoadArm7OverlayBtn_clicked()
|
|||||||
QString arm7OverlayPath = QFileDialog::getOpenFileName(
|
QString arm7OverlayPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Arm7Overlay",
|
"NDS Arm7Overlay",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS A7OVR (*.bin)");
|
"NDS A7OVR (*.bin)");
|
||||||
|
|
||||||
if(!arm7OverlayPath.isNull())
|
if(!arm7OverlayPath.isNull())
|
||||||
@ -130,7 +133,7 @@ void MainWindow::on_packerLoadArm7OverlayFilesBtn_clicked()
|
|||||||
QString arm7OverlayFilesPath = QFileDialog::getOpenFileName(
|
QString arm7OverlayFilesPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Arm7Overlay Data",
|
"NDS Arm7Overlay Data",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS A7OVR_DATA (*.bin)");
|
"NDS A7OVR_DATA (*.bin)");
|
||||||
|
|
||||||
if(!arm7OverlayFilesPath.isNull())
|
if(!arm7OverlayFilesPath.isNull())
|
||||||
@ -144,7 +147,7 @@ void MainWindow::on_packerLoadIconTitleBtn_clicked()
|
|||||||
QString iconTitlePath = QFileDialog::getOpenFileName(
|
QString iconTitlePath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS IconTitleLogo",
|
"NDS IconTitleLogo",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS ITL (*.bin)");
|
"NDS ITL (*.bin)");
|
||||||
|
|
||||||
if(!iconTitlePath.isNull())
|
if(!iconTitlePath.isNull())
|
||||||
@ -158,7 +161,7 @@ void MainWindow::on_packerLoadFatFilesBtn_clicked()
|
|||||||
QString fatFilesPath = QFileDialog::getOpenFileName(
|
QString fatFilesPath = QFileDialog::getOpenFileName(
|
||||||
Q_NULLPTR,
|
Q_NULLPTR,
|
||||||
"NDS Fat Data",
|
"NDS Fat Data",
|
||||||
"",
|
QDir::currentPath(),
|
||||||
"NDS FAT_DATA (*.bin)");
|
"NDS FAT_DATA (*.bin)");
|
||||||
|
|
||||||
if(!fatFilesPath.isNull())
|
if(!fatFilesPath.isNull())
|
||||||
@ -169,19 +172,17 @@ void MainWindow::on_packerLoadFatFilesBtn_clicked()
|
|||||||
|
|
||||||
void MainWindow::on_packerBuildNDSRomBtn_clicked()
|
void MainWindow::on_packerBuildNDSRomBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->packerBuildNDSRomBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
QString dirPath = customSaveFileDialog("NDS Rom",
|
"NDS Rom",
|
||||||
"rom.nds",
|
"rom.nds",
|
||||||
"NDS ROM (*.nds)");
|
"NDS ROM (*.nds)");
|
||||||
|
|
||||||
if (!dirPath.isNull())
|
if (!dirPath.isNull())
|
||||||
{
|
{
|
||||||
NFResult nfResult = writeEverything(dirPath.toStdString());
|
writeEverything(dirPath.toStdString()) ? QMessageBox::information(this, tr("NDS Factory"), tr("Creation completed!"))
|
||||||
nfResult.result? QMessageBox::information(this, tr("NDSFactory"), tr("Creation completed!"))
|
: QMessageBox::critical(this, tr("NDS Factory"), tr("Error during the creation!"));
|
||||||
: QMessageBox::critical(this, tr("NDSFactory"), nfResult.message.c_str());
|
|
||||||
}
|
}
|
||||||
ui->packerBuildNDSRomBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_packerCalcHeaderCrcBtn_clicked()
|
void MainWindow::on_packerCalcHeaderCrcBtn_clicked()
|
||||||
|
@ -23,26 +23,14 @@ void MainWindow::enableExtractionButtons()
|
|||||||
{
|
{
|
||||||
ui->unpackerExtractorGbx->setEnabled(true);
|
ui->unpackerExtractorGbx->setEnabled(true);
|
||||||
ui->unpackerExtraGbx->setEnabled(true);
|
ui->unpackerExtraGbx->setEnabled(true);
|
||||||
if (ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlayAddress, 1).data().toString().toUInt(nullptr,16) == 0)
|
if (ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlayAddress, 1).data().toString().toUInt(nullptr,16) == 0){
|
||||||
{
|
|
||||||
ui->unpackerDumpArm9OverlayBtn->setEnabled(false);
|
ui->unpackerDumpArm9OverlayBtn->setEnabled(false);
|
||||||
ui->unpackerDumpArm9OverlayFilesBtn->setEnabled(false);
|
ui->unpackerDumpArm9OverlayFilesBtn->setEnabled(false);
|
||||||
}
|
}
|
||||||
else
|
if (ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlayAddress, 1).data().toString().toUInt(nullptr,16) == 0){
|
||||||
{
|
|
||||||
ui->unpackerDumpArm9OverlayBtn->setEnabled(true);
|
|
||||||
ui->unpackerDumpArm9OverlayFilesBtn->setEnabled(true);
|
|
||||||
}
|
|
||||||
if (ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlayAddress, 1).data().toString().toUInt(nullptr,16) == 0)
|
|
||||||
{
|
|
||||||
ui->unpackerDumpArm7OverlayBtn->setEnabled(false);
|
ui->unpackerDumpArm7OverlayBtn->setEnabled(false);
|
||||||
ui->unpackerDumpArm7OverlayFilesBtn->setEnabled(false);
|
ui->unpackerDumpArm7OverlayFilesBtn->setEnabled(false);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->unpackerDumpArm7OverlayBtn->setEnabled(true);
|
|
||||||
ui->unpackerDumpArm7OverlayFilesBtn->setEnabled(true);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::disableExtractionButtons()
|
void MainWindow::disableExtractionButtons()
|
||||||
@ -51,7 +39,7 @@ void MainWindow::disableExtractionButtons()
|
|||||||
ui->unpackerExtraGbx->setEnabled(false);
|
ui->unpackerExtraGbx->setEnabled(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpHeader(const std::string& dirPath)
|
bool MainWindow::dumpHeader(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -60,7 +48,7 @@ NFResult MainWindow::dumpHeader(const std::string& dirPath)
|
|||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::HeaderSize, 1).data().toString().toUInt(nullptr,16));
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::HeaderSize, 1).data().toString().toUInt(nullptr,16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpArm9Bin(const std::string& dirPath, bool dumpExtraBytes)
|
bool MainWindow::dumpArm9Bin(const std::string& dirPath, bool dumpExtraBytes)
|
||||||
{
|
{
|
||||||
uint32_t size = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9Size, 1).data().toString().toUInt(nullptr,16);
|
uint32_t size = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9Size, 1).data().toString().toUInt(nullptr,16);
|
||||||
if (dumpExtraBytes)
|
if (dumpExtraBytes)
|
||||||
@ -72,7 +60,7 @@ NFResult MainWindow::dumpArm9Bin(const std::string& dirPath, bool dumpExtraBytes
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpArm7Bin(const std::string& dirPath)
|
bool MainWindow::dumpArm7Bin(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -81,7 +69,7 @@ NFResult MainWindow::dumpArm7Bin(const std::string& dirPath)
|
|||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7Size, 1).data().toString().toUInt(nullptr,16));
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7Size, 1).data().toString().toUInt(nullptr,16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpFnt(const std::string& dirPath)
|
bool MainWindow::dumpFnt(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -90,7 +78,7 @@ NFResult MainWindow::dumpFnt(const std::string& dirPath)
|
|||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::FilenameTableSize, 1).data().toString().toUInt(nullptr,16));
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::FilenameTableSize, 1).data().toString().toUInt(nullptr,16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpFat(const std::string& dirPath)
|
bool MainWindow::dumpFat(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -99,7 +87,7 @@ NFResult MainWindow::dumpFat(const std::string& dirPath)
|
|||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::FATSize, 1).data().toString().toUInt(nullptr,16));
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::FATSize, 1).data().toString().toUInt(nullptr,16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpArm9Overlay(const std::string& dirPath)
|
bool MainWindow::dumpArm9Overlay(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -108,7 +96,7 @@ NFResult MainWindow::dumpArm9Overlay(const std::string& dirPath)
|
|||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlaySize, 1).data().toString().toUInt(nullptr,16));
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlaySize, 1).data().toString().toUInt(nullptr,16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpArm9OverlayFiles(const std::string& dirPath)
|
bool MainWindow::dumpArm9OverlayFiles(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlayAddress, 1).data().toString().toUInt(nullptr, 16) +
|
uint32_t startAddr = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlayAddress, 1).data().toString().toUInt(nullptr, 16) +
|
||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlaySize, 1).data().toString().toUInt(nullptr, 16);
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlaySize, 1).data().toString().toUInt(nullptr, 16);
|
||||||
@ -121,7 +109,7 @@ NFResult MainWindow::dumpArm9OverlayFiles(const std::string& dirPath)
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpArm7Overlay(const std::string& dirPath)
|
bool MainWindow::dumpArm7Overlay(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -130,7 +118,7 @@ NFResult MainWindow::dumpArm7Overlay(const std::string& dirPath)
|
|||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlaySize, 1).data().toString().toUInt(nullptr,16));
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlaySize, 1).data().toString().toUInt(nullptr,16));
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpArm7OverlayFiles(const std::string& dirPath)
|
bool MainWindow::dumpArm7OverlayFiles(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlayAddress, 1).data().toString().toUInt(nullptr, 16) +
|
uint32_t startAddr = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlayAddress, 1).data().toString().toUInt(nullptr, 16) +
|
||||||
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlaySize, 1).data().toString().toUInt(nullptr, 16);
|
ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlaySize, 1).data().toString().toUInt(nullptr, 16);
|
||||||
@ -143,7 +131,7 @@ NFResult MainWindow::dumpArm7OverlayFiles(const std::string& dirPath)
|
|||||||
size);
|
size);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpIconTitle(const std::string& dirPath)
|
bool MainWindow::dumpIconTitle(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
return ndsFactory.dumpDataFromFile(
|
return ndsFactory.dumpDataFromFile(
|
||||||
ui->loadedRomPath->text().toStdString(),
|
ui->loadedRomPath->text().toStdString(),
|
||||||
@ -152,7 +140,7 @@ NFResult MainWindow::dumpIconTitle(const std::string& dirPath)
|
|||||||
ICON_TITLE_SIZE);
|
ICON_TITLE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
NFResult MainWindow::dumpFatFiles(const std::string& dirPath)
|
bool MainWindow::dumpFatFiles(const std::string& dirPath)
|
||||||
{
|
{
|
||||||
uint32_t startAddr = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::IconTitleAddress, 1).data().toString().toUInt(nullptr,16) + IconTitleSize ;
|
uint32_t startAddr = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::IconTitleAddress, 1).data().toString().toUInt(nullptr,16) + IconTitleSize ;
|
||||||
uint32_t size = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::UsedRomSize, 1).data().toString().toUInt(nullptr,16) - startAddr;
|
uint32_t size = ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::UsedRomSize, 1).data().toString().toUInt(nullptr,16) - startAddr;
|
||||||
@ -165,34 +153,23 @@ NFResult MainWindow::dumpFatFiles(const std::string& dirPath)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
NFResult MainWindow::dumpEverything(QString dirPath)
|
bool MainWindow::dumpEverything(QString dirPath)
|
||||||
{
|
{
|
||||||
NFResult nfResult;
|
bool result = true;
|
||||||
nfResult = dumpHeader(QDir::toNativeSeparators(dirPath + "/header.bin").toStdString());
|
result &= dumpHeader(QDir::toNativeSeparators(dirPath+"/header.bin").toStdString());
|
||||||
if (!nfResult.result) return nfResult;
|
result &= dumpArm9Bin(QDir::toNativeSeparators(dirPath+"/arm9.bin").toStdString(), true);
|
||||||
nfResult = dumpArm9Bin(QDir::toNativeSeparators(dirPath+"/arm9.bin").toStdString(), true);
|
result &= dumpArm7Bin(QDir::toNativeSeparators(dirPath+"/arm7.bin").toStdString());
|
||||||
if (!nfResult.result) return nfResult;
|
result &= dumpFnt(QDir::toNativeSeparators(dirPath+"/fnt.bin").toStdString());
|
||||||
nfResult = dumpArm7Bin(QDir::toNativeSeparators(dirPath+"/arm7.bin").toStdString());
|
result &= dumpFat(QDir::toNativeSeparators(dirPath+"/fat.bin").toStdString());
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
nfResult = dumpFnt(QDir::toNativeSeparators(dirPath+"/fnt.bin").toStdString());
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
nfResult = dumpFat(QDir::toNativeSeparators(dirPath+"/fat.bin").toStdString());
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
if(ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlayAddress, 1).data().toString().toUInt(nullptr,16) != 0) {
|
if(ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM9OverlayAddress, 1).data().toString().toUInt(nullptr,16) != 0) {
|
||||||
nfResult = dumpArm9Overlay(QDir::toNativeSeparators(dirPath+"/a9ovr.bin").toStdString());
|
result &= dumpArm9Overlay(QDir::toNativeSeparators(dirPath+"/a9ovr.bin").toStdString());
|
||||||
if (!nfResult.result) return nfResult;
|
result &= dumpArm9OverlayFiles(QDir::toNativeSeparators(dirPath+"/a9ovr_data.bin").toStdString());
|
||||||
nfResult = dumpArm9OverlayFiles(QDir::toNativeSeparators(dirPath+"/a9ovr_data.bin").toStdString());
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
}
|
}
|
||||||
if(ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlayAddress, 1).data().toString().toUInt(nullptr,16) != 0) {
|
if(ui->unpackerHeaderDataTable->model()->index(NDSHeaderNames::ARM7OverlayAddress, 1).data().toString().toUInt(nullptr,16) != 0) {
|
||||||
nfResult = dumpArm7Overlay(QDir::toNativeSeparators(dirPath+"/a7ovr.bin").toStdString());
|
result &= dumpArm7Overlay(QDir::toNativeSeparators(dirPath+"/a7ovr.bin").toStdString());
|
||||||
if (!nfResult.result) return nfResult;
|
result &= dumpArm7OverlayFiles(QDir::toNativeSeparators(dirPath+"/a7ovr_data.bin").toStdString());
|
||||||
nfResult = dumpArm7OverlayFiles(QDir::toNativeSeparators(dirPath+"/a7ovr_data.bin").toStdString());
|
}
|
||||||
if (!nfResult.result) return nfResult;
|
result &= dumpIconTitle(QDir::toNativeSeparators(dirPath+"/itl.bin").toStdString());
|
||||||
}
|
result &= dumpFatFiles(QDir::toNativeSeparators(dirPath+"/fat_data.bin").toStdString());
|
||||||
nfResult = dumpIconTitle(QDir::toNativeSeparators(dirPath+"/itl.bin").toStdString());
|
return result;
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
nfResult = dumpFatFiles(QDir::toNativeSeparators(dirPath+"/fat_data.bin").toStdString());
|
|
||||||
if (!nfResult.result) return nfResult;
|
|
||||||
return { true, "" };
|
|
||||||
}
|
}
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include "./../../mainwindow.h"
|
#include "./../../mainwindow.h"
|
||||||
#include "./../../ui_mainwindow.h"
|
#include "./../../ui_mainwindow.h"
|
||||||
#include "./../../utils/filepicker.h"
|
|
||||||
#include "./../../utils/ui.h"
|
|
||||||
|
|
||||||
|
|
||||||
void MainWindow::on_loadRomBtn_clicked()
|
void MainWindow::on_loadRomBtn_clicked()
|
||||||
@ -17,11 +15,12 @@ void MainWindow::on_loadRomBtn_clicked()
|
|||||||
QDir::currentPath(),
|
QDir::currentPath(),
|
||||||
"NDS Rom (*.nds)");
|
"NDS Rom (*.nds)");
|
||||||
|
|
||||||
if (romPath.isNull()) return;
|
if( !romPath.isNull() )
|
||||||
|
{
|
||||||
|
ui->loadedRomPath->setText(romPath.toUtf8());
|
||||||
|
}
|
||||||
|
|
||||||
ui->loadedRomPath->setText(romPath.toUtf8());
|
if (ndsFactory.loadRomHeader(ui->loadedRomPath->text().toStdString(), romHeader))
|
||||||
|
|
||||||
if (ndsFactory.loadRomHeader(ui->loadedRomPath->text().toStdString(), romHeader).result)
|
|
||||||
{
|
{
|
||||||
pNDSHeader = reinterpret_cast<NDSHeader*>(romHeader.data());
|
pNDSHeader = reinterpret_cast<NDSHeader*>(romHeader.data());
|
||||||
populateHeader(pNDSHeader);
|
populateHeader(pNDSHeader);
|
||||||
@ -35,135 +34,132 @@ void MainWindow::on_loadRomBtn_clicked()
|
|||||||
|
|
||||||
void MainWindow::on_unpackerDumpHeaderBtn_clicked()
|
void MainWindow::on_unpackerDumpHeaderBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpHeaderBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS Header",
|
||||||
|
"header.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS Header", "header.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpHeader(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpHeader(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpHeaderBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpArm9Btn_clicked()
|
void MainWindow::on_unpackerDumpArm9Btn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpArm9Btn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
QString dirPath = customSaveFileDialog("NDS ARM9", "arm9.bin", "Binary (*.bin)");
|
"NDS ARM9",
|
||||||
|
"arm9.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QMessageBox::StandardButton dumpExtraBytes = QMessageBox::question(
|
QMessageBox::StandardButton dumpExtraBytes = QMessageBox::question(
|
||||||
this,
|
this,
|
||||||
"NDSFactory",
|
"NDS Factory",
|
||||||
"Do you want to dump the extra 12 bytes? (click yes if you want a 1:1 arm9 dump)",
|
"Do you want to dump the extra 12 bytes? (click yes if you want a 1:1 arm9 dump)",
|
||||||
QMessageBox::Yes|QMessageBox::No);
|
QMessageBox::Yes|QMessageBox::No);
|
||||||
|
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpArm9Bin(dirPath.toStdString(), dumpExtraBytes == QMessageBox::Yes ? true : false));
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpArm9Bin(dirPath.toStdString(), dumpExtraBytes == QMessageBox::Yes ? true : false));
|
||||||
ui->unpackerDumpArm9Btn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpArm7Btn_clicked()
|
void MainWindow::on_unpackerDumpArm7Btn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpArm7Btn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS ARM7",
|
||||||
|
"arm7.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS ARM7", "arm7.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpArm7Bin(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpArm7Bin(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpArm7Btn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpFntBtn_clicked()
|
void MainWindow::on_unpackerDumpFntBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpFntBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS FNT",
|
||||||
|
"fnt.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS FNT", "fnt.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpFnt(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpFnt(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpFntBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpFatBtn_clicked()
|
void MainWindow::on_unpackerDumpFatBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpFatBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS FAT",
|
||||||
|
"fat.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS FAT", "fat.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpFat(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpFat(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpFatBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpArm9OverlayBtn_clicked()
|
void MainWindow::on_unpackerDumpArm9OverlayBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpArm9OverlayBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS ARM9 Overlay",
|
||||||
|
"a9ovr.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS ARM9 Overlay", "a9ovr.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpArm9Overlay(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpArm9Overlay(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpArm9OverlayBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpArm7OverlayBtn_clicked()
|
void MainWindow::on_unpackerDumpArm7OverlayBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpArm7OverlayBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS ARM7 Overlay",
|
||||||
|
"a7ovr.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS ARM7 Overlay", "a7ovr.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpArm7Overlay(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpArm7Overlay(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpArm7OverlayBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpIconTitleLogoBtn_clicked()
|
void MainWindow::on_unpackerDumpIconTitleLogoBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpIconTitleLogoBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS IconTitleLogo",
|
||||||
|
"itl.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS IconTitleLogo", "itl.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpIconTitle(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpIconTitle(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpIconTitleLogoBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpFatFilesBtn_clicked()
|
void MainWindow::on_unpackerDumpFatFilesBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpFatFilesBtn->setEnabled(false);
|
QString dirPath = QFileDialog::getSaveFileName(
|
||||||
|
Q_NULLPTR,
|
||||||
|
"NDS FAT Files",
|
||||||
|
"fat_data.bin",
|
||||||
|
"Binary (*.bin)");
|
||||||
|
|
||||||
QString dirPath = customSaveFileDialog("NDS FAT Files", "fat_data.bin", "Binary (*.bin)");
|
if (!dirPath.isNull())
|
||||||
|
notifyExtractionResult(dumpFatFiles(dirPath.toStdString()));
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpFatFiles(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpFatFilesBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpArm9OverlayFilesBtn_clicked()
|
void MainWindow::on_unpackerDumpArm9OverlayFilesBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpArm9OverlayFilesBtn->setEnabled(false);
|
QMessageBox::warning(this, tr("NDS Factory"), tr("This function is currently not implemented!"));
|
||||||
|
//dumpArm9OverlayFiles()
|
||||||
QString dirPath = customSaveFileDialog("NDS ARM9 Overlay Data", "a9ovr_data.bin", "Binary (*.bin)");
|
|
||||||
|
|
||||||
if (!dirPath.isNull()) notifyExtractionResult(dumpArm9OverlayFiles(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpArm9OverlayFilesBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpArm7OverlayFilesBtn_clicked()
|
void MainWindow::on_unpackerDumpArm7OverlayFilesBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpArm7OverlayFilesBtn->setEnabled(false);
|
QMessageBox::warning(this, tr("NDS Factory"), tr("This function is currently not implemented!"));
|
||||||
|
//dumpArm7OverlayFiles()
|
||||||
QString dirPath = customSaveFileDialog("NDS ARM7 Overlay Data", "a7ovr_data.bin", "Binary (*.bin)");
|
|
||||||
|
|
||||||
if (!dirPath.isNull())
|
|
||||||
notifyExtractionResult(dumpArm7OverlayFiles(dirPath.toStdString()));
|
|
||||||
|
|
||||||
ui->unpackerDumpArm7OverlayFilesBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_unpackerDumpEverythingBtn_clicked()
|
void MainWindow::on_unpackerDumpEverythingBtn_clicked()
|
||||||
{
|
{
|
||||||
ui->unpackerDumpEverythingBtn->setEnabled(false);
|
|
||||||
QString dirPath = QFileDialog::getExistingDirectory(
|
QString dirPath = QFileDialog::getExistingDirectory(
|
||||||
this, tr("Select Directory"),
|
this, tr("Select Directory"),
|
||||||
"",
|
"",
|
||||||
@ -171,5 +167,16 @@ void MainWindow::on_unpackerDumpEverythingBtn_clicked()
|
|||||||
|
|
||||||
if (!dirPath.isNull())
|
if (!dirPath.isNull())
|
||||||
notifyExtractionResult(dumpEverything(dirPath));
|
notifyExtractionResult(dumpEverything(dirPath));
|
||||||
ui->unpackerDumpEverythingBtn->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::notifyExtractionResult(bool result)
|
||||||
|
{
|
||||||
|
if(result)
|
||||||
|
{
|
||||||
|
QMessageBox::information(this, tr("NDS Factory"), tr("Extraction completed!"));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
QMessageBox::critical(this, tr("NDS Factory"), tr("Error during the extraction!"));
|
||||||
|
}
|
||||||
|
}
|
@ -1,20 +0,0 @@
|
|||||||
#pragma once
|
|
||||||
|
|
||||||
#include <QFileDialog>
|
|
||||||
|
|
||||||
inline QString customSaveFileDialog(const QString& title, const QString& defaultName, const QString& filter)
|
|
||||||
{
|
|
||||||
|
|
||||||
static QString lastUsedPath;
|
|
||||||
|
|
||||||
QString selectedPath = QFileDialog::getSaveFileName(
|
|
||||||
Q_NULLPTR,
|
|
||||||
title,
|
|
||||||
lastUsedPath + defaultName,
|
|
||||||
filter);
|
|
||||||
|
|
||||||
if (!selectedPath.isNull())
|
|
||||||
lastUsedPath = selectedPath.mid(0, selectedPath.lastIndexOf('/', Qt::CaseInsensitive)+1);
|
|
||||||
|
|
||||||
return selectedPath;
|
|
||||||
}
|
|
@ -49,7 +49,7 @@ inline void setTheme(QString themeValue)
|
|||||||
{
|
{
|
||||||
QSettings settings;
|
QSettings settings;
|
||||||
settings.setValue("theme", themeValue);
|
settings.setValue("theme", themeValue);
|
||||||
QMessageBox::information(nullptr, "NDSFactory", "Restart NDSFactory to change theme!");
|
QMessageBox::information(nullptr, "NDS Factory", "Restart NDSFactory to change theme!");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,16 +0,0 @@
|
|||||||
#pragma once
|
|
||||||
|
|
||||||
#include <QMessageBox>
|
|
||||||
#include "../../ndsfactory/nfresult.h"
|
|
||||||
|
|
||||||
void notifyExtractionResult(NFResult nfResult)
|
|
||||||
{
|
|
||||||
if (nfResult.result)
|
|
||||||
{
|
|
||||||
QMessageBox::information(Q_NULLPTR, "NDSFactory", "Extraction completed!");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
QMessageBox::critical(Q_NULLPTR, "NDSFactory", nfResult.message.c_str());
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user