shithub: pokered

Download patch

ref: 6fd6c7af4675e97f9bcf677edf426b37998f9c13
parent: 443ff15688285af0e4635f5a58e263210b756459
author: KuroiIeWa5Da <[email protected]>
date: Fri Jan 27 19:38:49 EST 2012

big update after strip

hg-commit-id: dcfb20faef4d


--- a/music/pokeredmusicdisasm/Console.cpp
+++ b/music/pokeredmusicdisasm/Console.cpp
@@ -1,4 +1,4 @@
-#include "console.h"
+#include "Console.h"
 
 using namespace std;
 
--- a/music/pokeredmusicdisasm/Duty.h
+++ b/music/pokeredmusicdisasm/Duty.h
@@ -25,7 +25,7 @@
     // Custom Functions
     std::string LookupDutyString();
 
-    const enum dutyList : unsigned char
+    enum dutyList : unsigned char
     {
         duty12_5 = 0x0,
         duty25 = 0x1,
--- /dev/null
+++ b/music/pokeredmusicdisasm/Makefile
@@ -1,0 +1,65 @@
+
+OBJECTS = main.o Jump.o Modulation.o Note.o Octave.o Parser.o Stop.o \
+Tempo.o UnkCode.o UnkEB.o Velocity.o Volume.o Console.o AbstractData.o Call.o \
+Duty.o
+
+CC = g++
+CFLAGS = -std=c++0x
+
+pokeredmusicdisasm: $(OBJECTS)
+	$(CC) $(CFLAGS) $(OBJECTS) -o "../../extras/pokeredmusicdisasm.exe"
+
+Parser.o: Jump.h Modulation.h Note.h Octave.h Parser.h Stop.h \
+Tempo.h UnkCode.h UnkEB.h Velocity.h Volume.h
+	$(CC) $(CFLAGS) -c main.cpp Jump.cpp Modulation.cpp \
+Note.cpp Octave.cpp Parser.cpp Stop.cpp Tempo.cpp UnkCode.cpp UnkEB.cpp \
+Velocity.cpp Volume.cpp
+
+Duty.o: Duty.h AbstractData.h
+	$(CC) $(CFLAGS) -c Duty.cpp AbstractData.cpp
+
+Console.o: Console.h
+	$(CC) $(CFLAGS) -c Console.cpp
+
+AbstractData.o: AbstractData.h
+	$(CC) $(CFLAGS) -c AbstractData.cpp
+
+Call.o: Call.h Call.cpp AbstractData.h
+	$(CC) $(CFLAGS) -c Call.cpp AbstractData.cpp
+
+main.o: main.cpp Console.h Parser.h
+	$(CC) $(CFLAGS) -c main.cpp Console.cpp Parser.cpp
+
+Jump.o: Jump.h AbstractData.h
+	$(CC) $(CFLAGS) -c Jump.cpp AbstractData.cpp
+
+Modulation.o: Modulation.h AbstractData.h
+	$(CC) $(CFLAGS) -c Modulation.cpp AbstractData.cpp
+
+Note.o: Note.h AbstractData.h
+	$(CC) $(CFLAGS) -c Note.cpp AbstractData.cpp
+
+Octave.o: Octave.h AbstractData.h
+	$(CC) $(CFLAGS) -c Octave.cpp AbstractData.cpp
+
+Stop.o: Stop.h AbstractData.h
+	$(CC) $(CFLAGS) -c Stop.cpp AbstractData.cpp
+
+Tempo.o: Tempo.h AbstractData.h
+	$(CC) $(CFLAGS) -c Tempo.cpp AbstractData.cpp
+
+UnkCode.o: UnkCode.h AbstractData.h
+	$(CC) $(CFLAGS) -c UnkCode.cpp AbstractData.cpp
+
+UnkEB.o: UnkEB.h AbstractData.h
+	$(CC) $(CFLAGS) -c UnkEB.cpp AbstractData.cpp
+
+Velocity.o: Velocity.h AbstractData.h
+	$(CC) $(CFLAGS) -c Velocity.cpp AbstractData.cpp
+
+Volume.o: Volume.h AbstractData.h
+	$(CC) $(CFLAGS) -c Volume.cpp AbstractData.cpp
+
+clean:
+	rm *.o
+	rm ../../extras/pokeredmusicdisasm.exe
--- a/music/pokeredmusicdisasm/Note.h
+++ b/music/pokeredmusicdisasm/Note.h
@@ -29,42 +29,42 @@
 	std::string LookupPitchStr();
 	std::string LookupDelayStr();
 
-	const enum pitch_code : unsigned char
-	{
-		noteC = 0x0,
-		noteCS = 0x1,
-		noteD = 0x2,
-		noteDS = 0x3,
-		noteE = 0x4,
-		noteF = 0x5,
-		noteFS = 0x6,
-		noteG = 0x7,
-		noteGS = 0x8,
-		noteA = 0x9,
-		noteAS = 0xA,
-		noteB = 0xB,
-		noteRst = 0xC
-	};
+        enum pitch_code : unsigned char
+        {
+            noteC = 0x0,
+            noteCS = 0x1,
+            noteD = 0x2,
+            noteDS = 0x3,
+            noteE = 0x4,
+            noteF = 0x5,
+            noteFS = 0x6,
+            noteG = 0x7,
+            noteGS = 0x8,
+            noteA = 0x9,
+            noteAS = 0xA,
+            noteB = 0xB,
+            noteRst = 0xC
+        };
 
-	const enum delay_code : unsigned char
-	{
-		note16 = 0x0,
-		note8 = 0x1,
-		note8_16 = 0x2,
-		note4 = 0x3,
-		note4_16 = 0x4,
-		note4_8 = 0x5,
-		note4_8_16 = 0x6,
-		note2 = 0x7,
-		note2_16 = 0x8,
-		note2_8 = 0x9,
-		note2_8_16 = 0xA,
-		note2_4 = 0xB,
-		note2_4_16 = 0xC,
-		note2_4_8 = 0xD,
-		note2_4_8_16 = 0xE,
-		note1 = 0xF
-	};
+        enum delay_code : unsigned char
+        {
+            note16 = 0x0,
+            note8 = 0x1,
+            note8_16 = 0x2,
+            note4 = 0x3,
+            note4_16 = 0x4,
+            note4_8 = 0x5,
+            note4_8_16 = 0x6,
+            note2 = 0x7,
+            note2_16 = 0x8,
+            note2_8 = 0x9,
+            note2_8_16 = 0xA,
+            note2_4 = 0xB,
+            note2_4_16 = 0xC,
+            note2_4_8 = 0xD,
+            note2_4_8_16 = 0xE,
+            note1 = 0xF
+        };
 private:
 	unsigned char pitch;
 	unsigned char delay;
--- a/music/pokeredmusicdisasm/Octave.h
+++ b/music/pokeredmusicdisasm/Octave.h
@@ -24,17 +24,17 @@
 
 	std::string LookupOctString();
 
-	const enum OctaveCode : unsigned char
-	{
-		oct0 = 0xE7,
-		oct1 = 0xE6,
-		oct2 = 0xE5,
-		oct3 = 0xE4,
-		oct4 = 0xE3,
-		oct5 = 0xE2,
-		oct6 = 0xE1,
-		oct7 = 0xE0,
-	};
+        enum OctaveCode : unsigned char
+        {
+            oct0 = 0xE7,
+            oct1 = 0xE6,
+            oct2 = 0xE5,
+            oct3 = 0xE4,
+            oct4 = 0xE3,
+            oct5 = 0xE2,
+            oct6 = 0xE1,
+            oct7 = 0xE0
+        };
 
 private:
 	unsigned char octave;
--- a/music/pokeredmusicdisasm/Parser.h
+++ b/music/pokeredmusicdisasm/Parser.h
@@ -54,22 +54,22 @@
 	template<class T>
 	bool ParseData(unsigned int& pos, bool reado = false);
 
-	const enum dataType : unsigned char
-	{
-		DATA_NA,
-		DATA_CALL,
-		DATA_DUTY,
-		DATA_JUMP,
-		DATA_MODULATION,
-		DATA_NOTE,
-		DATA_OCTAVE,
-		DATA_STOP,
-		DATA_TEMPO,
-		DATA_UNKCODE,
-		DATA_UNKEB,
-		DATA_VELOCITY,
-		DATA_VOLUME
-	};
+        enum dataType : unsigned char
+        {
+            DATA_NA,
+            DATA_CALL,
+            DATA_DUTY,
+            DATA_JUMP,
+            DATA_MODULATION,
+            DATA_NOTE,
+            DATA_OCTAVE,
+            DATA_STOP,
+            DATA_TEMPO,
+            DATA_UNKCODE,
+            DATA_UNKEB,
+            DATA_VELOCITY,
+            DATA_VOLUME
+        };
 
 private:
 	std::string filename;
--- /dev/null
+++ b/music/pokeredmusicdisasm/README.txt
@@ -1,0 +1,22 @@
+to compile you must have g++ installed
+type: make
+and it will install to the extras folder
+
+if you want to unmake
+type: make clean
+and it will remove make objects and the executable
+
+the program usage is: pokeredmusicdisasm [<offset> [<file> | --] [--stop]
+offset is the rom offset in hexidecimal (FFFF or 0xFFFF)
+file is the rom file, you can use -- for "../baserom.gbc"
+--stop is the hexidecimal stop number
+
+to make things quick and easy you can just enter the hexidecimal offset
+pokeredmusicdisasm <offset>
+
+to use the stop parameter you must use it as the 3rd argument as below
+pokeredmusicdisasm <offset> -- --stop=FFFF
+pokeredmusicdisasm <offset> <file> --stop=FFFF
+
+you may enter limited interactive mode by not supplying any arguments
+pokeredmusicdisasm
\ No newline at end of file
--- a/music/pokeredmusicdisasm/Stop.cpp
+++ b/music/pokeredmusicdisasm/Stop.cpp
@@ -27,7 +27,7 @@
 string Stop::GenAsm()
 {
 	string tmpRet = AbstractData::GenAsm();
-	if(tmpRet != "") return false;
+	if(tmpRet != "") return tmpRet;
 
 	stringstream tmpAsmOut;
 	tmpAsmOut << "mus_end";
--- a/music/pokeredmusicdisasm/Tempo.cpp
+++ b/music/pokeredmusicdisasm/Tempo.cpp
@@ -56,7 +56,7 @@
 string Tempo::GenAsm()
 {
 	string tmpRet = AbstractData::GenAsm();
-	if(tmpRet != "") return false;
+	if(tmpRet != "") return tmpRet;
 
 	stringstream tmpAsmOut;
 	tmpAsmOut << "mus_tempo" << " " << (short)divider << ", " << (short)modifier;
--- a/music/pokeredmusicdisasm/UnkCode.cpp
+++ b/music/pokeredmusicdisasm/UnkCode.cpp
@@ -1,16 +1,4 @@
 #include <sstream>
-
-#include "Call.h"
-#include "Duty.h"
-#include "Jump.h"
-#include "Modulation.h"
-#include "Note.h"
-#include "Octave.h"
-#include "Stop.h"
-#include "Tempo.h"
-#include "Velocity.h"
-#include "Volume.h"
-
 #include "UnkCode.h"
 
 using namespace std;
--- a/music/pokeredmusicdisasm/UnkEB.cpp
+++ b/music/pokeredmusicdisasm/UnkEB.cpp
@@ -1,16 +1,4 @@
 #include <sstream>
-
-#include "Call.h"
-#include "Duty.h"
-#include "Jump.h"
-#include "Modulation.h"
-#include "Note.h"
-#include "Octave.h"
-#include "Stop.h"
-#include "Tempo.h"
-#include "Velocity.h"
-#include "Volume.h"
-
 #include "UnkEB.h"
 
 using namespace std;
--- a/music/pokeredmusicdisasm/Volume.cpp
+++ b/music/pokeredmusicdisasm/Volume.cpp
@@ -44,7 +44,7 @@
 string Volume::GenAsm()
 {
 	string tmpRet = AbstractData::GenAsm();
-	if(tmpRet != "") return false;
+	if(tmpRet != "") return tmpRet;
 
 	stringstream tmpAsmOut;
 	tmpAsmOut << "mus_volume" << " " << (short)volume;
--- /dev/null
+++ b/music/pokeredwavptnvis/Console.cpp
@@ -1,0 +1,54 @@
+#include "Console.h"
+
+using namespace std;
+
+// Basic
+void Console::Get(char* value)
+{
+    cin >> value;
+}
+void Console::Get(string& value)
+{
+    cin >> value;
+}
+void Console::Print(const char* value)
+{
+    cout << value;
+}
+void Console::Error(const char* value)
+{
+    cerr << value;
+}
+
+// Upper-Basic
+void Console::PrintLn(const char* value)
+{
+    Print(value);
+    cout << endl;
+}
+void Console::ErrorLn(const char* value)
+{
+    Error(value);
+    cerr << endl;
+}
+
+// Higher
+void Console::Ask(const char* question, char* answer)
+{
+    Print(question);
+    Get(answer);
+}
+void Console::Ask(const char* question, string& answer)
+{
+    Print(question);
+    Get(answer);
+}
+
+// Better Error Handling
+int Console::atoi_ex(const char* input, bool supress)
+{
+	int convInp = atoi(input);
+	if((supress == false) && (convInp == 0))
+			PrintLn("Warning: the converted integer input is 0, this may not be what you intended");
+		return convInp;
+}
--- /dev/null
+++ b/music/pokeredwavptnvis/Console.h
@@ -1,0 +1,29 @@
+#ifndef CONSOLE_H
+#define CONSOLE_H
+
+#include <iostream>
+#include <string>
+
+// Just a Console Utility Library
+class Console
+{
+public:
+    // Basic
+    static void Get(char* value);
+    static void Get(std::string& value);
+    static void Print(const char* value);
+    static void Error(const char* value);
+
+    // Upper-Basic
+    static void PrintLn(const char* value);
+    static void ErrorLn(const char* value);
+
+    // Higher
+    static void Ask(const char* question, char* answer);
+    static void Ask(const char* question, std::string& answer);
+
+    // Better Error Handling
+    static int atoi_ex(const char* input, bool supress = false);
+};
+
+#endif // CONSOLE_H
--- /dev/null
+++ b/music/pokeredwavptnvis/Makefile
@@ -1,0 +1,18 @@
+
+OBJECTS = Console.o main.o
+
+CC = g++
+CFLAGS = -std=c++0x
+
+pokeredwavptnvis: $(OBJECTS)
+	$(CC) $(CFLAGS) $(OBJECTS) -o "../../extras/pokeredwavptnvis.exe"
+
+Console.o: Console.h
+	$(CC) $(CFLAGS) -c Console.cpp
+
+main.o: main.cpp Console.h
+	$(CC) $(CFLAGS) -c main.cpp Console.cpp
+
+clean:
+	rm *.o
+	rm ../../extras/pokeredwavptnvis.exe
--- /dev/null
+++ b/music/pokeredwavptnvis/README.txt
@@ -1,0 +1,17 @@
+to compile you must have g++ installed
+type: make
+and it will install to the extras folder
+
+if you want to unmake
+type: make clean
+and it will remove make objects and the executable
+
+the program usage is: pokeredwavptnvis [<offset> [<file> | --]
+offset is the rom offset in hexidecimal (FFFF or 0xFFFF)
+file is the rom file, you can use -- for "../baserom.gbc"
+
+to make things quick and easy you can just enter the hexidecimal offset
+pokeredwavptnvis <offset>
+
+you may enter limited interactive mode by not supplying any arguments
+pokeredwavptnvis
\ No newline at end of file
--- /dev/null
+++ b/music/pokeredwavptnvis/main.cpp
@@ -1,0 +1,156 @@
+#include <sstream>
+#include <string>
+#include <fstream>
+#include <vector>
+
+#include "Console.h"
+
+using namespace std;
+
+char* rawBytes = 0;
+unsigned int fileLength = 0;
+
+void Read(const char* filename)
+{
+	// open File
+	fstream tmpFile(filename, ios_base::in | ios_base::binary);
+
+	// Get Length
+	tmpFile.seekg(0, ios::end);
+	fileLength = tmpFile.tellg();
+	tmpFile.seekg(0, ios::beg);
+
+	// Allocate proper memory
+	rawBytes = new char[fileLength];
+
+	// Read filedata
+	tmpFile.read(rawBytes, fileLength);
+	tmpFile.close();
+}
+
+unsigned char GetNibble(unsigned char byte, bool high)
+{
+	if(high)
+	{
+		unsigned char tmp = byte & 0xF0;
+		tmp >>= 4;
+		return tmp;
+	}
+	else
+	{
+		unsigned char tmp = byte & 0x0F;
+		return tmp;
+	}
+}
+
+// Usage: pokeredwavptnvis [<offset> [<file> | --]]
+// If no parameters or a parameter is missing the program enters limited interactive mode
+int main(int argc, char** argv)
+{
+	const unsigned char parameters = 2;
+	const unsigned char self = 1;
+	const unsigned char _max_argc = parameters + self;
+	const string defFileLoc = "../baserom.gbc";
+
+	string arg1;	// Offset
+	string arg2;	// File or "--" (if "--" then the file is assumed)
+
+	string paramStopAddr;
+
+	if(argc >= _max_argc)
+	{
+		arg1 = argv[1];
+		arg2 = argv[2];
+	}
+	else if(argc == (_max_argc - 1))
+	{
+		arg1 = argv[1];
+		arg2 = defFileLoc;
+	}
+
+	if(arg1 == "") Console::Ask("What offset in the file in hex: ", arg1);
+	if(arg2 == "") Console::Ask("What file: ", arg2);
+	if(arg2 == "--") arg2 = defFileLoc;	// You can also put "--" for the default file location
+
+	stringstream arg1Conv;
+	unsigned int arg1ConvNum;
+	arg1Conv << arg1;
+	arg1Conv << hex;
+	arg1Conv >> arg1ConvNum;
+
+	Read(arg2.c_str());
+	unsigned char* rawBytesFixed = (unsigned char*)rawBytes;
+
+	// All the loading is done, create a 32x16 vector
+	vector<vector<bool>> image;
+	vector<string> lines;	// This is the array of output lines
+
+	// Initialize the vector image[x][y] and lines
+	for(unsigned char i = 0; i < 32; i++)
+	{
+		image.push_back(vector<bool>());
+
+		for(unsigned char j = 0; j < 16; j++)
+		{
+			image[i].push_back(false);
+			lines.push_back("");
+		}
+	}
+
+	unsigned char n1 = 0;
+	unsigned char n2 = 0;
+
+	vector<unsigned char> expBytes;
+	for(unsigned char i = 0; i < 16; i++)
+	{
+		n1 = GetNibble(rawBytesFixed[arg1ConvNum + i], true);
+		n2 = GetNibble(rawBytesFixed[arg1ConvNum + i], false);
+
+		expBytes.push_back(n1);
+		expBytes.push_back(n2);
+	}
+
+	// Go through each column in the vector and add a 1 on the appropiate line
+	for(unsigned char i = 0; i < 32; i++)
+	{
+		unsigned char _tmpVal = expBytes[i];	// Here for debugging reasons
+		image[i][_tmpVal] = true;
+	}
+
+	// Now draw the image
+	for(unsigned char i = 0; i < 32; i++)
+	{
+		for(unsigned char j = 0; j < 16; j++)
+		{
+			if(i == 0)
+			{
+				if(image[i][j]) lines[j].append("|*");
+				else lines[j].append("| ");
+			}
+			else if((i > 0) && (i < 31))
+			{
+				if(image[i][j]) lines[j].append(".*");
+				else lines[j].append(". ");
+			}
+			else
+			{
+				if(image[i][j]) lines[j].append(".*|");
+				else lines[j].append(". |");
+			}
+		}
+	}
+
+	// Now output the drawn lines (mirrored)
+	stringstream tmpCtr;
+	Console::PrintLn("  0 1 2 3 4 5 6 7 8 9 A B C D E F 0 1 2 3 4 5 6 7 8 9 A B C D E F");
+	Console::PrintLn("  ---------------------------------------------------------------");
+	for(unsigned char i = 0xF; (i >= 0x0) && (i < 0x10); i--)
+	{
+		tmpCtr << hex << uppercase << (short)i;
+		Console::Print(tmpCtr.str().c_str());
+		Console::PrintLn(lines[i].c_str());
+		tmpCtr.str("");
+	}
+
+	return 0;
+}
\ No newline at end of file