1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-08 18:09:45 +01:00

Add suggestions from style pass

Co-authored-by: Misa Elizabeth Kai <infoteddy@infoteddy.info>
This commit is contained in:
Ally 2023-03-20 09:00:58 -03:00 committed by Misa Elizabeth Kai
parent 234776bbec
commit 0edbf6398a
2 changed files with 194 additions and 216 deletions

View file

@ -807,10 +807,8 @@ static void draw_entities(void)
} }
// Need to also check warp point destinations // Need to also check warp point destinations
if (entity->t == 13 && ed.warp_token_entity != i) if (entity->t == 13 && ed.warp_token_entity != i &&
{ entity->p1 / 40 == ed.levx && entity->p2 / 30 == ed.levy)
// Is the destination in this room?
if (entity->p1 / 40 == ed.levx && entity->p2 / 30 == ed.levy)
{ {
const int x = entity->p1 % 40 * 8; const int x = entity->p1 % 40 * 8;
const int y = entity->p2 % 30 * 8; const int y = entity->p2 % 30 * 8;
@ -832,7 +830,6 @@ static void draw_entities(void)
} }
} }
} }
}
static void draw_ghosts(void) static void draw_ghosts(void)
{ {
@ -1024,24 +1021,24 @@ static void draw_tile_drawer(int tileset)
const int numtiles = (int)(texturewidth / 8) * (textureheight / 8); const int numtiles = (int)(texturewidth / 8) * (textureheight / 8);
for (int x = 0; x < 40; x++) for (int x = 0; x < SCREEN_WIDTH_TILES; x++)
{ {
for (int y = 0; y < 5; y++) for (int y = 0; y < 5; y++)
{ {
if (tileset == 0) if (tileset == 0)
{ {
graphics.drawtile(x * 8, (y * 8) - t2, (temp + numtiles + (y * 40) + x) % numtiles); graphics.drawtile(x * 8, (y * 8) - t2, (temp + numtiles + (y * SCREEN_WIDTH_TILES) + x) % numtiles);
} }
else else
{ {
graphics.drawtile2(x * 8, (y * 8) - t2, (temp + numtiles + (y * 40) + x) % numtiles); graphics.drawtile2(x * 8, (y * 8) - t2, (temp + numtiles + (y * SCREEN_WIDTH_TILES) + x) % numtiles);
} }
} }
} }
// Highlight our little block // Highlight our little block
graphics.draw_rect(((ed.direct_mode_tile % 40) * 8) - 2, 16 - t2 - 2, 12, 12, graphics.getRGB(255 - help.glow, 196, 196)); graphics.draw_rect(((ed.direct_mode_tile % SCREEN_WIDTH_TILES) * 8) - 2, 16 - t2 - 2, 12, 12, graphics.getRGB(255 - help.glow, 196, 196));
graphics.draw_rect(((ed.direct_mode_tile % 40) * 8) - 1, 16 - t2 - 1, 10, 10, graphics.getRGB(0, 0, 0)); graphics.draw_rect(((ed.direct_mode_tile % SCREEN_WIDTH_TILES) * 8) - 1, 16 - t2 - 1, 10, 10, graphics.getRGB(0, 0, 0));
} }
if (ed.direct_mode_drawer > 0 && t2 <= 30) if (ed.direct_mode_drawer > 0 && t2 <= 30)
@ -1302,8 +1299,6 @@ static void draw_main_ui(void)
void editorclass::draw_tool(EditorTools tool, int x, int y) void editorclass::draw_tool(EditorTools tool, int x, int y)
{ {
extern editorclass ed;
switch (tool) switch (tool)
{ {
case EditorTool_WALLS: case EditorTool_WALLS:
@ -1340,7 +1335,7 @@ void editorclass::draw_tool(EditorTools tool, int x, int y)
graphics.drawtile(x + 8, y + 4, 1); graphics.drawtile(x + 8, y + 4, 1);
break; break;
case EditorTool_ENEMIES: case EditorTool_ENEMIES:
graphics.draw_sprite(x, y, 78 + ed.entframe, 196, 196, 196); graphics.draw_sprite(x, y, 78 + entframe, 196, 196, 196);
break; break;
case EditorTool_GRAVITY_LINES: case EditorTool_GRAVITY_LINES:
graphics.fill_rect(x + 2, y + 8, 12, 1, graphics.getRGB(255, 255, 255)); graphics.fill_rect(x + 2, y + 8, 12, 1, graphics.getRGB(255, 255, 255));
@ -1356,7 +1351,7 @@ void editorclass::draw_tool(EditorTools tool, int x, int y)
graphics.draw_rect(x + 4, y + 4, 8, 8, graphics.getRGB(96, 96, 96)); graphics.draw_rect(x + 4, y + 4, 8, 8, graphics.getRGB(96, 96, 96));
break; break;
case EditorTool_WARP_TOKENS: case EditorTool_WARP_TOKENS:
graphics.draw_sprite(x, y, 18 + (ed.entframe % 2), 196, 196, 196); graphics.draw_sprite(x, y, 18 + (entframe % 2), 196, 196, 196);
break; break;
case EditorTool_WARP_LINES: case EditorTool_WARP_LINES:
graphics.fill_rect(x + 6, y + 2, 4, 12, graphics.getRGB(255, 255, 255)); graphics.fill_rect(x + 6, y + 2, 4, 12, graphics.getRGB(255, 255, 255));
@ -1383,7 +1378,6 @@ void editorrender(void)
switch (ed.state) switch (ed.state)
{ {
case EditorState_DRAW: case EditorState_DRAW:
{
// Draw the editor guidelines // Draw the editor guidelines
draw_background_grid(); draw_background_grid();
@ -1461,47 +1455,46 @@ void editorrender(void)
} }
break; break;
}
case EditorState_SCRIPTS: case EditorState_SCRIPTS:
// Intended to look like Commodore 64's UI // Intended to look like Commodore 64's UI
graphics.fill_rect(0, 0, 320, 240, graphics.getRGB(123, 111, 218)); graphics.fill_rect(0, 0, 320, 240, graphics.getRGB(123, 111, 218));
graphics.fill_rect(14, 16, 292, 208, graphics.getRGB(61, 48, 162)); graphics.fill_rect(14, 16, 292, 208, graphics.getRGB(61, 48, 162));
if (ed.substate == EditorSubState_MAIN) switch (ed.substate)
{ {
case EditorSubState_MAIN:
font::print(PR_CEN, -1, 28, loc::gettext("**** VVVVVV SCRIPT EDITOR ****"), 123, 111, 218); font::print(PR_CEN, -1, 28, loc::gettext("**** VVVVVV SCRIPT EDITOR ****"), 123, 111, 218);
font::print(PR_CEN, -1, 44, loc::gettext("PRESS ESC TO RETURN TO MENU"), 123, 111, 218); font::print(PR_CEN, -1, 44, loc::gettext("PRESS ESC TO RETURN TO MENU"), 123, 111, 218);
if (!script.customscripts.empty()) if (script.customscripts.empty())
{ {
font::print(PR_CEN, -1, 110, loc::gettext("NO SCRIPT IDS FOUND"), 123, 111, 218);
font::print_wrap(PR_CEN, -1, 130, loc::gettext("CREATE A SCRIPT WITH EITHER THE TERMINAL OR SCRIPT BOX TOOLS"), 123, 111, 218, 10, 288);
break;
}
for (int i = 0; i < 9; i++) for (int i = 0; i < 9; i++)
{ {
if (ed.script_list_offset + i < (int)script.customscripts.size()) const int offset = ed.script_list_offset + i;
const bool draw = offset < (int) script.customscripts.size();
if (!draw)
{ {
if (ed.script_list_offset + i == ed.selected_script) continue;
}
if (offset == ed.selected_script)
{ {
std::string text_upper(loc::toupper(script.customscripts[(script.customscripts.size() - 1) - (ed.script_list_offset + i)].name)); std::string text_upper(loc::toupper(script.customscripts[script.customscripts.size() - 1 - offset].name));
char buffer[SCREEN_WIDTH_CHARS + 1]; char buffer[SCREEN_WIDTH_CHARS + 1];
vformat_buf(buffer, sizeof(buffer), loc::get_langmeta()->menu_select.c_str(), "label:str", text_upper.c_str()); vformat_buf(buffer, sizeof(buffer), loc::get_langmeta()->menu_select.c_str(), "label:str", text_upper.c_str());
font::print(PR_CEN, -1, 68 + (i * 16), buffer, 123, 111, 218); font::print(PR_CEN, -1, 68 + (i * 16), buffer, 123, 111, 218);
} }
else else
{ {
font::print(PR_CEN, -1, 68 + (i * 16), script.customscripts[(script.customscripts.size() - 1) - (ed.script_list_offset + i)].name, 123, 111, 218); font::print(PR_CEN, -1, 68 + (i * 16), script.customscripts[script.customscripts.size() - 1 - offset].name, 123, 111, 218);
} }
} }
} break;
} case EditorSubState_SCRIPTS_EDIT:
else
{
font::print(PR_CEN, -1, 110, loc::gettext("NO SCRIPT IDS FOUND"), 123, 111, 218);
font::print_wrap(PR_CEN, -1, 130, loc::gettext("CREATE A SCRIPT WITH EITHER THE TERMINAL OR SCRIPT BOX TOOLS"), 123, 111, 218, 10, 288);
}
}
else if (ed.substate == EditorSubState_SCRIPTS_EDIT)
{ {
// Draw the current script's name // Draw the current script's name
graphics.fill_rect(14, 226, 292, 12, graphics.getRGB(61, 48, 162)); graphics.fill_rect(14, 226, 292, 12, graphics.getRGB(61, 48, 162));
@ -1529,6 +1522,10 @@ void editorrender(void)
{ {
font::print(PR_FONT_LEVEL | PR_CJK_LOW, 16 + font::len(PR_FONT_LEVEL, ed.script_buffer[ed.script_cursor_y].c_str()), 20 + ((ed.script_cursor_y - ed.script_offset) * font_height), "_", 123, 111, 218); font::print(PR_FONT_LEVEL | PR_CJK_LOW, 16 + font::len(PR_FONT_LEVEL, ed.script_buffer[ed.script_cursor_y].c_str()), 20 + ((ed.script_cursor_y - ed.script_offset) * font_height), "_", 123, 111, 218);
} }
break;
}
default:
break;
} }
break; break;
case EditorState_MENU: case EditorState_MENU:
@ -1780,7 +1777,6 @@ static void input_submitted(void)
break; break;
case TEXT_WEBSITE: case TEXT_WEBSITE:
cl.website = key.keybuffer; cl.website = key.keybuffer;
break; break;
case TEXT_DESC1: case TEXT_DESC1:
cl.Desc1 = key.keybuffer; cl.Desc1 = key.keybuffer;
@ -1892,7 +1888,7 @@ static void set_tile_interpolated(const int x1, const int x2, const int y1, cons
const int dx = x2 - x1; const int dx = x2 - x1;
const int dy = y2 - y1; const int dy = y2 - y1;
const int steps = SDL_max(abs(dx), abs(dy)); const int steps = SDL_max(SDL_abs(dx), SDL_abs(dy));
if (steps == 0) if (steps == 0)
{ {
@ -1916,7 +1912,7 @@ void editorclass::handle_tile_placement(const int tile)
if (b_modifier) if (b_modifier)
{ {
// Vertical line // Vertical line
for (int i = 0; i < 30; i++) for (int i = 0; i < SCREEN_HEIGHT_TILES; i++)
{ {
set_tile_interpolated(old_tilex, tilex, i, i, tile); set_tile_interpolated(old_tilex, tilex, i, i, tile);
} }
@ -1925,7 +1921,7 @@ void editorclass::handle_tile_placement(const int tile)
else if (h_modifier) else if (h_modifier)
{ {
// Horizontal line // Horizontal line
for (int i = 0; i < 40; i++) for (int i = 0; i < SCREEN_WIDTH_TILES; i++)
{ {
set_tile_interpolated(i, i, old_tiley, tiley, tile); set_tile_interpolated(i, i, old_tiley, tiley, tile);
} }
@ -1979,7 +1975,7 @@ void editorclass::tool_remove()
for (size_t i = 0; i < customentities.size(); i++) for (size_t i = 0; i < customentities.size(); i++)
{ {
if (customentities[i].x == tilex + (levx * 40) && customentities[i].y == tiley + (levy * 30)) if (customentities[i].x == tilex + (levx * SCREEN_WIDTH_TILES) && customentities[i].y == tiley + (levy * SCREEN_HEIGHT_TILES))
{ {
remove_entity(i); remove_entity(i);
} }
@ -2053,8 +2049,7 @@ void editorclass::entity_clicked(const int index)
void editorclass::tool_place() void editorclass::tool_place()
{ {
const int entity = get_entity_at(tilex + (levx * SCREEN_WIDTH_TILES), tiley + (levy * SCREEN_HEIGHT_TILES));
const int entity = get_entity_at(tilex + (levx * 40), tiley + (levy * 30));
if (entity != -1) if (entity != -1)
{ {
entity_clicked(entity); entity_clicked(entity);
@ -2454,14 +2449,23 @@ static void start_at_checkpoint(void)
bool startpoint = false; bool startpoint = false;
for (size_t i = 0; i < customentities.size(); i++) for (size_t i = 0; i < customentities.size(); i++)
{
if (customentities[i].t == 16 || customentities[i].t == 10)
{
int tx = customentities[i].x / 40;
int ty = customentities[i].y / 30;
if (tx == ed.levx && ty == ed.levy)
{ {
startpoint = customentities[i].t == 16; startpoint = customentities[i].t == 16;
const bool is_startpoint_or_checkpoint = startpoint ||
customentities[i].t == 10;
if (!is_startpoint_or_checkpoint)
{
continue;
}
const int tx = customentities[i].x / 40;
const int ty = customentities[i].y / 30;
const bool in_room = tx == ed.levx && ty == ed.levy;
if (!in_room)
{
continue;
}
if (startpoint) if (startpoint)
{ {
// Oh, there's a start point! Let's use this. // Oh, there's a start point! Let's use this.
@ -2474,8 +2478,6 @@ static void start_at_checkpoint(void)
testeditor = i; testeditor = i;
} }
} }
}
}
if (testeditor == -1) if (testeditor == -1)
{ {
@ -2599,14 +2601,13 @@ static void handle_draw_input()
for (int i = 0; i < NUM_EditorTools; i++) for (int i = 0; i < NUM_EditorTools; i++)
{ {
if (key.keymap[ed.tool_keys[i]]) if (key.keymap[ed.tool_keys[i]] &&
{ ((shift_down && ed.tool_requires_shift[i]) ||
if ((shift_down && ed.tool_requires_shift[i]) || (!shift_down && !ed.tool_requires_shift[i])) (!shift_down && !ed.tool_requires_shift[i])))
{ {
ed.current_tool = (EditorTools) i; ed.current_tool = (EditorTools) i;
} }
} }
}
if (key.keymap[SDLK_w]) if (key.keymap[SDLK_w])
{ {
@ -2899,9 +2900,7 @@ void editorinput(void)
ed.substate = EditorSubState_MAIN; ed.substate = EditorSubState_MAIN;
} }
if (key.leftbutton) if (key.leftbutton && ed.lclickdelay == 0)
{
if (ed.lclickdelay == 0)
{ {
if (ed.box_corner == BoxCorner_FIRST) if (ed.box_corner == BoxCorner_FIRST)
{ {
@ -2949,7 +2948,6 @@ void editorinput(void)
} }
} }
} }
}
else else
{ {
ed.lclickdelay = 0; ed.lclickdelay = 0;
@ -3575,7 +3573,7 @@ int editorclass::get_enemy_tile(int t)
void editorclass::set_tile(int x, int y, int t) void editorclass::set_tile(int x, int y, int t)
{ {
if (x >= 0 && y >= 0 && x < 40 && y < 30) if (x >= 0 && y >= 0 && x < SCREEN_WIDTH_TILES && y < SCREEN_HEIGHT_TILES)
{ {
cl.settile(levx, levy, x, y, t); cl.settile(levx, levy, x, y, t);
} }
@ -3774,86 +3772,66 @@ bool editorclass::is_background(int x, int y)
x = SDL_clamp(x, 0, 39); x = SDL_clamp(x, 0, 39);
y = SDL_clamp(y, 0, 29); y = SDL_clamp(y, 0, 29);
return (cl.gettile(levx, levy, x, y) >= 680); const int tile = cl.gettile(levx, levy, x, y);
return tile >= 680 && tile <= 739;
} }
int editorclass::backfree( int x, int y ) bool editorclass::backfree(int x, int y)
{ {
// Returns 0 if tile is not a block or background tile, 1 otherwise
x = SDL_clamp(x, 0, 39); x = SDL_clamp(x, 0, 39);
y = SDL_clamp(y, 0, 29); y = SDL_clamp(y, 0, 29);
if (x >= 0 && y >= 0 && x < 40 && y < 30) const int tile = cl.gettile(levx, levy, x, y);
{
if (cl.gettile(levx, levy, x, y) == 0) return tile == 0;
{
return 0;
}
}
return 1;
} }
bool editorclass::lines_can_pass(int x, int y) bool editorclass::lines_can_pass(int x, int y)
{ {
// Returns 0 if tile is not a block or spike, 1 otherwise const int tile = cl.gettile(levx, levy, x, y);
if (x >= 0 && y >= 0 && x < SCREEN_WIDTH_TILES && y < SCREEN_HEIGHT_TILES)
if (x >= 0 && y >= 0 && x < 40 && y < 30)
{ {
return (cl.gettile(levx, levy, x, y) == 0) || (cl.gettile(levx, levy, x, y) >= 680); return tile == 0 || tile >= 680;
} }
return false; return false;
} }
int editorclass::free( int x, int y ) bool editorclass::free(int x, int y)
{ {
// Returns 0 if tile is not a block, 1 otherwise
x = SDL_clamp(x, 0, 39); x = SDL_clamp(x, 0, 39);
y = SDL_clamp(y, 0, 29); y = SDL_clamp(y, 0, 29);
if (cl.gettile(levx, levy, x, y) == 0) const int tile = cl.gettile(levx, levy, x, y);
{
return 0; return tile == 0 || (tile >= 2 && tile < 80) || tile >= 680;
}
else
{
if (cl.gettile(levx, levy, x, y) >= 2 && cl.gettile(levx, levy, x, y) < 80)
{
return 0;
}
if (cl.gettile(levx, levy, x, y) >= 680)
{
return 0;
}
}
return 1;
} }
int editorclass::match(int x, int y) int editorclass::match(int x, int y)
{ {
if (free(x - 1, y) == 0 && free(x, y - 1) == 0 && free(x + 1, y) == 0 && free(x, y + 1) == 0) return 0; if (free(x - 1, y) && free(x, y - 1) && free(x + 1, y) && free(x, y + 1)) return 0;
if (free(x - 1, y) == 0 && free(x, y - 1) == 0) return 10; if (free(x - 1, y) && free(x, y - 1)) return 10;
if (free(x + 1, y) == 0 && free(x, y - 1) == 0) return 11; if (free(x + 1, y) && free(x, y - 1)) return 11;
if (free(x - 1, y) == 0 && free(x, y + 1) == 0) return 12; if (free(x - 1, y) && free(x, y + 1)) return 12;
if (free(x + 1, y) == 0 && free(x, y + 1) == 0) return 13; if (free(x + 1, y) && free(x, y + 1)) return 13;
if (free(x, y - 1) == 0) return 1; if (free(x, y - 1)) return 1;
if (free(x - 1, y) == 0) return 2; if (free(x - 1, y)) return 2;
if (free(x, y + 1) == 0) return 3; if (free(x, y + 1)) return 3;
if (free(x + 1, y) == 0) return 4; if (free(x + 1, y)) return 4;
if (free(x - 1, y - 1) == 0) return 5; if (free(x - 1, y - 1)) return 5;
if (free(x + 1, y - 1) == 0) return 6; if (free(x + 1, y - 1)) return 6;
if (free(x - 1, y + 1) == 0) return 7; if (free(x - 1, y + 1)) return 7;
if (free(x + 1, y + 1) == 0) return 8; if (free(x + 1, y + 1)) return 8;
return 0; return 0;
} }
int editorclass::outsidematch(int x, int y) int editorclass::outsidematch(int x, int y)
{ {
if (is_background(x - 1, y) == 0 && is_background(x + 1, y) == 0) return 2; if (!is_background(x - 1, y) && !is_background(x + 1, y)) return 2;
if (is_background(x, y - 1) == 0 && is_background(x, y + 1) == 0) return 1; if (!is_background(x, y - 1) && !is_background(x, y + 1)) return 1;
return 0; return 0;
} }
@ -3864,21 +3842,21 @@ int editorclass::backmatch( int x, int y )
// 5 1 6 // 5 1 6
// 2 X 4 // 2 X 4
// 7 3 8 // 7 3 8
if (backfree(x - 1, y) == 0 && backfree(x, y - 1) == 0 && backfree(x + 1, y) == 0 && backfree(x, y + 1) == 0) return 0; if (backfree(x - 1, y) && backfree(x, y - 1) && backfree(x + 1, y) && backfree(x, y + 1)) return 0;
if (backfree(x - 1, y) == 0 && backfree(x, y - 1) == 0) return 10; if (backfree(x - 1, y) && backfree(x, y - 1)) return 10;
if (backfree(x + 1, y) == 0 && backfree(x, y - 1) == 0) return 11; if (backfree(x + 1, y) && backfree(x, y - 1)) return 11;
if (backfree(x - 1, y) == 0 && backfree(x, y + 1) == 0) return 12; if (backfree(x - 1, y) && backfree(x, y + 1)) return 12;
if (backfree(x + 1, y) == 0 && backfree(x, y + 1) == 0) return 13; if (backfree(x + 1, y) && backfree(x, y + 1)) return 13;
if (backfree(x, y - 1) == 0) return 1; if (backfree(x, y - 1)) return 1;
if (backfree(x - 1, y) == 0) return 2; if (backfree(x - 1, y)) return 2;
if (backfree(x, y + 1) == 0) return 3; if (backfree(x, y + 1)) return 3;
if (backfree(x + 1, y) == 0) return 4; if (backfree(x + 1, y)) return 4;
if (backfree(x - 1, y - 1) == 0) return 5; if (backfree(x - 1, y - 1)) return 5;
if (backfree(x + 1, y - 1) == 0) return 6; if (backfree(x + 1, y - 1)) return 6;
if (backfree(x - 1, y + 1) == 0) return 7; if (backfree(x - 1, y + 1)) return 7;
if (backfree(x + 1, y + 1) == 0) return 8; if (backfree(x + 1, y + 1)) return 8;
return 0; return 0;
} }
@ -4004,19 +3982,19 @@ int editorclass::backedgetile( int x, int y )
int editorclass::labspikedir(int x, int y, int t) int editorclass::labspikedir(int x, int y, int t)
{ {
// a slightly more tricky case // a slightly more tricky case
if (free(x, y + 1) == 1) return 63 + (t * 2); if (!free(x, y + 1)) return 63 + (t * 2);
if (free(x, y - 1) == 1) return 64 + (t * 2); if (!free(x, y - 1)) return 64 + (t * 2);
if (free(x - 1, y) == 1) return 51 + (t * 2); if (!free(x - 1, y)) return 51 + (t * 2);
if (free(x + 1, y) == 1) return 52 + (t * 2); if (!free(x + 1, y)) return 52 + (t * 2);
return 63 + (t * 2); return 63 + (t * 2);
} }
int editorclass::spikedir(int x, int y) int editorclass::spikedir(int x, int y)
{ {
if (free(x, y + 1) == 1) return 8; if (!free(x, y + 1)) return 8;
if (free(x, y - 1) == 1) return 9; if (!free(x, y - 1)) return 9;
if (free(x - 1, y) == 1) return 49; if (!free(x - 1, y)) return 49;
if (free(x + 1, y) == 1) return 50; if (!free(x + 1, y)) return 50;
return 8; return 8;
} }

View file

@ -129,7 +129,7 @@ public:
void entity_clicked(int index); void entity_clicked(int index);
void tool_place(); void tool_place();
void get_input_line(const enum TextMode mode, const std::string& prompt, std::string* ptr); void get_input_line(enum TextMode mode, const std::string& prompt, std::string* ptr);
void show_note(const char* text); void show_note(const char* text);
@ -148,9 +148,9 @@ public:
TileTypes get_tile_type(int x, int y, bool wrap); TileTypes get_tile_type(int x, int y, bool wrap);
bool is_background(int x, int y); bool is_background(int x, int y);
int backfree(int x, int y); bool backfree(int x, int y);
bool lines_can_pass(int x, int y); bool lines_can_pass(int x, int y);
int free(int x, int y); bool free(int x, int y);
int match(int x, int y); int match(int x, int y);
int outsidematch(int x, int y); int outsidematch(int x, int y);
int backmatch(int x, int y); int backmatch(int x, int y);