added 'loadp'
This commit is contained in:
		
							
								
								
									
										271
									
								
								src/console.c
									
									
									
									
									
								
							
							
						
						
									
										271
									
								
								src/console.c
									
									
									
									
									
								
							@@ -509,55 +509,6 @@ static void onCartLoaded(Console* console, const char* name)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(TIC80_PRO)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void loadProjectCode(Console* console, const void* data, s32 size)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	tic_mem* tic = console->tic;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	SDL_memcpy(tic->cart.code.data, data, SDL_min(size, sizeof(tic_code)));
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void loadProject(Console* console, const char* name)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	tic_mem* tic = console->tic;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	SDL_memset(&tic->cart, 0, sizeof(tic_cartridge));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	static struct{const char* name; void(*func)(Console* console, const void* data, s32 size);} ProjectFiles[] = 
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
		{"code.lua", loadProjectCode},
 | 
					 | 
				
			||||||
		{"sprites.gif", NULL},
 | 
					 | 
				
			||||||
		{"tiles.gif", NULL},
 | 
					 | 
				
			||||||
		{"palette.dat", NULL},
 | 
					 | 
				
			||||||
		{"map.dat", NULL},
 | 
					 | 
				
			||||||
		{"waves.dat", NULL},
 | 
					 | 
				
			||||||
		{"sfx.dat", NULL},
 | 
					 | 
				
			||||||
		{"music.dat", NULL},
 | 
					 | 
				
			||||||
		{"cover.gif", NULL},
 | 
					 | 
				
			||||||
	};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for(s32 i = 0; i < COUNT_OF(ProjectFiles); i++)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
		char path[FILENAME_MAX];
 | 
					 | 
				
			||||||
		sprintf(path, "%s/%s", name, ProjectFiles[i].name);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		s32 size = 0;
 | 
					 | 
				
			||||||
		void* data = fsLoadFile(console->fs, path, &size);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if(data)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
			ProjectFiles[i].func(console, data, size);
 | 
					 | 
				
			||||||
			SDL_free(data);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	onCartLoaded(console, name);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	commandDone(console);
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
static void onConsoleLoadCommandConfirmed(Console* console, const char* param)
 | 
					static void onConsoleLoadCommandConfirmed(Console* console, const char* param)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if(onConsoleLoadSectionCommand(console, param)) return;
 | 
						if(onConsoleLoadSectionCommand(console, param)) return;
 | 
				
			||||||
@@ -567,14 +518,6 @@ static void onConsoleLoadCommandConfirmed(Console* console, const char* param)
 | 
				
			|||||||
		s32 size = 0;
 | 
							s32 size = 0;
 | 
				
			||||||
		const char* name = getCartName(param);
 | 
							const char* name = getCartName(param);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(TIC80_PRO)
 | 
					 | 
				
			||||||
		if(fsIsDir(console->fs, name))
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
			loadProject(console, name);
 | 
					 | 
				
			||||||
			return;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		void* data = strcmp(name, CONFIG_TIC_PATH) == 0
 | 
							void* data = strcmp(name, CONFIG_TIC_PATH) == 0
 | 
				
			||||||
			? fsLoadRootFile(console->fs, name, &size)
 | 
								? fsLoadRootFile(console->fs, name, &size)
 | 
				
			||||||
			: fsLoadFile(console->fs, name, &size);
 | 
								: fsLoadFile(console->fs, name, &size);
 | 
				
			||||||
@@ -753,11 +696,6 @@ static bool printFilename(const char* name, const char* info, s32 id, void* data
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	printLine(console);
 | 
						printLine(console);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#if defined(TIC80_PRO)
 | 
					 | 
				
			||||||
	if(dir && SDL_strstr(name, CartExt) == (name + SDL_strlen(name) - SDL_strlen(CartExt)))
 | 
					 | 
				
			||||||
		dir = false;
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	if(dir)
 | 
						if(dir)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1657,6 +1595,17 @@ static bool bufferEmpty(const u8* data, s32 size)
 | 
				
			|||||||
	return true;
 | 
						return true;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static char* printText(char* ptr, const char* tag, const char* data)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if(strlen(data) == 0)
 | 
				
			||||||
 | 
							return ptr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						sprintf(ptr, "-- <%s>\n%s\n-- </%s>\n", tag, data, tag);
 | 
				
			||||||
 | 
						ptr += strlen(ptr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return ptr;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static char* printBuf(char* ptr, const void* data, s32 size, s32 row)
 | 
					static char* printBuf(char* ptr, const void* data, s32 size, s32 row)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if(bufferEmpty(data, size)) 
 | 
						if(bufferEmpty(data, size)) 
 | 
				
			||||||
@@ -1674,17 +1623,20 @@ static char* printBuf(char* ptr, const void* data, s32 size, s32 row)
 | 
				
			|||||||
	return ptr;
 | 
						return ptr;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static char* printSection(char* ptr, const char* tag, s32 count, const u8* data, s32 size)
 | 
					static char* printBinary(char* ptr, const char* tag, s32 count, const u8* data, s32 size)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if(bufferEmpty(data, size * count)) 
 | 
						if(bufferEmpty(data, size * count)) 
 | 
				
			||||||
		return ptr;
 | 
							return ptr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	sprintf(ptr, "\n-- ### %s:\n", tag);
 | 
						sprintf(ptr, "\n-- <%s>\n", tag);
 | 
				
			||||||
	ptr += strlen(ptr);
 | 
						ptr += strlen(ptr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for(s32 i = 0; i < count; i++, data += size)
 | 
						for(s32 i = 0; i < count; i++, data += size)
 | 
				
			||||||
		ptr = printBuf(ptr, data, size, i);
 | 
							ptr = printBuf(ptr, data, size, i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						sprintf(ptr, "-- </%s>\n", tag);
 | 
				
			||||||
 | 
						ptr += strlen(ptr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return ptr;
 | 
						return ptr;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1700,17 +1652,19 @@ static CartSaveResult saveProject(Console* console, const char* name)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if(stream)
 | 
							if(stream)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
			strcpy(stream, tic->cart.code.data);
 | 
								char* ptr = printText(stream, "CODE", tic->cart.code.data);
 | 
				
			||||||
			char* ptr = stream + strlen(stream);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			ptr = printSection(ptr, "PALETTE", 	1, tic->cart.palette.data, sizeof(tic_palette));
 | 
								// TODO: flip data for palette
 | 
				
			||||||
			ptr = printSection(ptr, "TILES", 	TIC_BANK_SPRITES, tic->cart.gfx.tiles[0].data, sizeof(tic_tile));
 | 
								ptr = printBinary(ptr, "PALETTE", 	1, tic->cart.palette.data, sizeof(tic_palette));
 | 
				
			||||||
			ptr = printSection(ptr, "SPRITES", 	TIC_BANK_SPRITES, tic->cart.gfx.sprites[0].data, sizeof(tic_tile));
 | 
								ptr = printBinary(ptr, "TILES", 	TIC_BANK_SPRITES, tic->cart.gfx.tiles[0].data, sizeof(tic_tile));
 | 
				
			||||||
			ptr = printSection(ptr, "MAP", 		TIC_MAP_HEIGHT, tic->cart.gfx.map.data, TIC_MAP_WIDTH);
 | 
								ptr = printBinary(ptr, "SPRITES", 	TIC_BANK_SPRITES, tic->cart.gfx.sprites[0].data, sizeof(tic_tile));
 | 
				
			||||||
			ptr = printSection(ptr, "WAVES", 	ENVELOPES_COUNT, tic->cart.sound.sfx.waveform.envelopes[0].data, sizeof(tic_waveform));
 | 
								ptr = printBinary(ptr, "MAP", 		TIC_MAP_HEIGHT, tic->cart.gfx.map.data, TIC_MAP_WIDTH);
 | 
				
			||||||
			ptr = printSection(ptr, "SFX", 		SFX_COUNT, (const u8*)&tic->cart.sound.sfx.data, sizeof(tic_sound_effect));
 | 
								ptr = printBinary(ptr, "WAVES", 	ENVELOPES_COUNT, tic->cart.sound.sfx.waveform.envelopes[0].data, sizeof(tic_waveform));
 | 
				
			||||||
			ptr = printSection(ptr, "PATTERNS", MUSIC_PATTERNS, (const u8*)&tic->cart.sound.music.patterns.data, sizeof(tic_track_pattern));
 | 
								ptr = printBinary(ptr, "SFX", 		SFX_COUNT, (const u8*)&tic->cart.sound.sfx.data, sizeof(tic_sound_effect));
 | 
				
			||||||
			ptr = printSection(ptr, "TRACKS", 	MUSIC_TRACKS, (const u8*)&tic->cart.sound.music.tracks.data, sizeof(tic_track));
 | 
								ptr = printBinary(ptr, "PATTERNS", 	MUSIC_PATTERNS, (const u8*)&tic->cart.sound.music.patterns.data, sizeof(tic_track_pattern));
 | 
				
			||||||
 | 
								ptr = printBinary(ptr, "TRACKS", 	MUSIC_TRACKS, (const u8*)&tic->cart.sound.music.tracks.data, sizeof(tic_track));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// TODO: add cover
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			name = getProjectName(name);
 | 
								name = getProjectName(name);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1773,6 +1727,174 @@ static void onConsoleSaveProjectCommand(Console* console, const char* param)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static bool loadProject(Console* console, const char* data, s32 size)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						tic_mem* tic = console->tic;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						char* project = (char*)SDL_malloc(size+1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						bool done = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(project)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							SDL_memcpy(project, data, size);
 | 
				
			||||||
 | 
							project[size] = '\0';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							tic_cartridge* cart = (tic_cartridge*)SDL_malloc(sizeof(tic_cartridge));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if(cart)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								SDL_memset(cart, 0, sizeof(tic_cartridge));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								// TODO: init default palette here
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									memcpy(&cart->palette, &tic->cart.palette, sizeof(tic_palette));
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								const char* projectEnd = project + strlen(project);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									const char* tag = "CODE";
 | 
				
			||||||
 | 
									char tagbuf[64];
 | 
				
			||||||
 | 
									sprintf(tagbuf, "-- <%s>\n", tag);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									const char* start = SDL_strstr(project, tagbuf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if(start)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										start += strlen(tagbuf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										if(start < projectEnd)
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											sprintf(tagbuf, "\n-- </%s>", tag);
 | 
				
			||||||
 | 
											const char* end = SDL_strstr(start, tagbuf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											s32 size = end - start;
 | 
				
			||||||
 | 
											if(size > 0)
 | 
				
			||||||
 | 
											{
 | 
				
			||||||
 | 
												SDL_memcpy(cart->code.data, start, end - start);
 | 
				
			||||||
 | 
												done = true;
 | 
				
			||||||
 | 
											}
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									const char* tag = "TILES";
 | 
				
			||||||
 | 
									char tagbuf[64];
 | 
				
			||||||
 | 
									sprintf(tagbuf, "-- <%s>\n", tag);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									const char* start = SDL_strstr(project, tagbuf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if(start)
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										start += strlen(tagbuf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										if(start < projectEnd)
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											sprintf(tagbuf, "\n-- </%s>", tag);
 | 
				
			||||||
 | 
											const char* end = SDL_strstr(start, tagbuf);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											s32 size = end - start;
 | 
				
			||||||
 | 
											if(size > 0)
 | 
				
			||||||
 | 
											{
 | 
				
			||||||
 | 
												s32 count = 256;
 | 
				
			||||||
 | 
												s32 size = sizeof(tic_tile) * 2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
												const char* ptr = start;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
												while(ptr < end)
 | 
				
			||||||
 | 
												{
 | 
				
			||||||
 | 
													char lineStr[] = "999";
 | 
				
			||||||
 | 
													memcpy(lineStr, ptr + strlen("-- "), strlen(lineStr));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
													s32 index = SDL_atoi(lineStr);
 | 
				
			||||||
 | 
													
 | 
				
			||||||
 | 
													if(index < count)
 | 
				
			||||||
 | 
													{
 | 
				
			||||||
 | 
														ptr += strlen("-- 999:");
 | 
				
			||||||
 | 
														str2buf(ptr, size, cart->gfx.tiles[index].data, true);
 | 
				
			||||||
 | 
														ptr += size + 1;
 | 
				
			||||||
 | 
													}
 | 
				
			||||||
 | 
												}
 | 
				
			||||||
 | 
											
 | 
				
			||||||
 | 
												done = true;
 | 
				
			||||||
 | 
											}
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if(done)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									SDL_memcpy(&tic->cart, cart, sizeof(tic_cartridge));
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								SDL_free(cart);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							SDL_free(project);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return done;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void onConsoleLoadProjectCommandConfirmed(Console* console, const char* param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						// if(onConsoleLoadProjectSectionCommand(console, param)) return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(param)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							s32 size = 0;
 | 
				
			||||||
 | 
							const char* name = getProjectName(param);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							void* data = fsLoadFile(console->fs, name, &size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if(data && loadProject(console, data, size))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								strcpy(console->romName, name);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								studioRomLoaded();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								printBack(console, "\nproject ");
 | 
				
			||||||
 | 
								printFront(console, console->romName);
 | 
				
			||||||
 | 
								printBack(console, " loaded!\nuse ");
 | 
				
			||||||
 | 
								printFront(console, "RUN");
 | 
				
			||||||
 | 
								printBack(console, " command to run it\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								SDL_free(data);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							else		
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								printBack(console, "\nproject loading error");
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else printBack(console, "\nproject name is missing");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						commandDone(console);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void onConsoleLoadProjectCommand(Console* console, const char* param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if(studioCartChanged())
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							static const char* Rows[] =
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								"YOU HAVE",
 | 
				
			||||||
 | 
								"UNSAVED CHANGES",
 | 
				
			||||||
 | 
								"",
 | 
				
			||||||
 | 
								"DO YOU REALLY WANT",
 | 
				
			||||||
 | 
								"TO LOAD PROJECT?",
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							confirmCommand(console, Rows, COUNT_OF(Rows), param, onConsoleLoadProjectCommandConfirmed);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							onConsoleLoadProjectCommandConfirmed(console, param);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static CartSaveResult saveCartName(Console* console, const char* name)
 | 
					static CartSaveResult saveCartName(Console* console, const char* name)
 | 
				
			||||||
@@ -2083,6 +2205,7 @@ static const struct
 | 
				
			|||||||
	{"load", 	NULL, "load cart", 					onConsoleLoadCommand},
 | 
						{"load", 	NULL, "load cart", 					onConsoleLoadCommand},
 | 
				
			||||||
	{"save", 	NULL, "save cart",	 				onConsoleSaveCommand},
 | 
						{"save", 	NULL, "save cart",	 				onConsoleSaveCommand},
 | 
				
			||||||
#if defined(TIC80_PRO)
 | 
					#if defined(TIC80_PRO)
 | 
				
			||||||
 | 
						{"loadp", 	NULL, "load project",				onConsoleLoadProjectCommand},
 | 
				
			||||||
	{"savep", 	NULL, "save project",		 		onConsoleSaveProjectCommand},
 | 
						{"savep", 	NULL, "save project",		 		onConsoleSaveProjectCommand},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	{"run",		NULL, "run loaded cart",			onConsoleRunCommand},
 | 
						{"run",		NULL, "run loaded cart",			onConsoleRunCommand},
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -999,7 +999,7 @@ static void copyFromClipboard(Map* map)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
				u8* data = SDL_malloc(size);
 | 
									u8* data = SDL_malloc(size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				str2buf(clipboard, data, true);
 | 
									str2buf(clipboard, strlen(clipboard), data, true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if(data[0] * data[1] == size - 2)
 | 
									if(data[0] * data[1] == size - 2)
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -598,7 +598,7 @@ static void copyFromClipboard(Music* music)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
				u8* data = SDL_malloc(size);
 | 
									u8* data = SDL_malloc(size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				str2buf(clipboard, data, true);
 | 
									str2buf(clipboard, strlen(clipboard), data, true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				ClipboardHeader header = {0};
 | 
									ClipboardHeader header = {0};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -342,13 +342,11 @@ void toClipboard(const void* data, s32 size, bool flip)
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void str2buf(const char* str, void* buf, bool flip)
 | 
					void str2buf(const char* str, s32 size, void* buf, bool flip)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	char val[] = "0x00";
 | 
						char val[] = "0x00";
 | 
				
			||||||
	const char* ptr = str;
 | 
						const char* ptr = str;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	s32 size = (s32)strlen(str);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for(s32 i = 0; i < size/2; i++)
 | 
						for(s32 i = 0; i < size/2; i++)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		if(flip)
 | 
							if(flip)
 | 
				
			||||||
@@ -378,7 +376,7 @@ bool fromClipboard(void* data, s32 size, bool flip)
 | 
				
			|||||||
			{
 | 
								{
 | 
				
			||||||
				bool valid = strlen(clipboard) == size * 2;
 | 
									bool valid = strlen(clipboard) == size * 2;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if(valid) str2buf(clipboard, data, flip);
 | 
									if(valid) str2buf(clipboard, strlen(clipboard), data, flip);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				SDL_free(clipboard);
 | 
									SDL_free(clipboard);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -146,7 +146,7 @@ EditorMode getStudioMode();
 | 
				
			|||||||
void exitStudio();
 | 
					void exitStudio();
 | 
				
			||||||
u32 unzip(u8** dest, const u8* source, size_t size);
 | 
					u32 unzip(u8** dest, const u8* source, size_t size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void str2buf(const char* str, void* buf, bool flip);
 | 
					void str2buf(const char* str, s32 size, void* buf, bool flip);
 | 
				
			||||||
void toClipboard(const void* data, s32 size, bool flip);
 | 
					void toClipboard(const void* data, s32 size, bool flip);
 | 
				
			||||||
bool fromClipboard(void* data, s32 size, bool flip);
 | 
					bool fromClipboard(void* data, s32 size, bool flip);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -29,6 +29,8 @@
 | 
				
			|||||||
#define TIC_VERSION_MAJOR 0
 | 
					#define TIC_VERSION_MAJOR 0
 | 
				
			||||||
#define TIC_VERSION_MINOR 47
 | 
					#define TIC_VERSION_MINOR 47
 | 
				
			||||||
#define TIC_VERSION_PATCH 0
 | 
					#define TIC_VERSION_PATCH 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// TODO: add PRO postfix to title
 | 
				
			||||||
#define TIC_VERSION_STATUS ""
 | 
					#define TIC_VERSION_STATUS ""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define TIC_MAKE_VERSION(major, minor, patch) ((major) * 10000 + (minor) * 100 + (patch))
 | 
					#define TIC_MAKE_VERSION(major, minor, patch) ((major) * 10000 + (minor) * 100 + (patch))
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user