File: move_stack_compact_alloc.h

package info (click to toggle)
freecell-solver 5.0.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,256 kB
  • sloc: ansic: 28,700; perl: 10,050; xml: 5,600; python: 1,339; sh: 533; cpp: 275; makefile: 20; javascript: 8
file content (36 lines) | stat: -rw-r--r-- 1,513 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/*
 * This file is part of Freecell Solver. It is subject to the license terms in
 * the COPYING.txt file found in the top-level directory of this distribution
 * and at http://fc-solve.shlomifish.org/docs/distro/COPYING.html . No part of
 * Freecell Solver, including this file, may be copied, modified, propagated,
 * or distributed except according to the terms contained in the COPYING file.
 *
 * Copyright (c) 2000 Shlomi Fish
 */
// move_stack_compact_alloc.h - A header file for a (possibly inline) function
// that compactly allocates a move stack.
#pragma once

#include "instance.h"
#include "move.h"

#ifdef FCS_WITH_MOVES
static inline fcs_move_stack *fc_solve_move_stack_compact_allocate(
    fcs_hard_thread *const hard_thread,
    fcs_move_stack *const old_move_stack_to_parent)
{
    char *const ptr =
        (char *)fcs_compact_alloc_ptr(&(HT_FIELD(hard_thread, allocator)),
            (sizeof(fcs_move_stack) +
                sizeof(fcs_move_t) * old_move_stack_to_parent->num_moves));

    fcs_move_stack *const new_move_stack_to_parent = (fcs_move_stack *)ptr;
    fcs_internal_move *const new_moves_to_parent =
        (fcs_internal_move *)(ptr + sizeof(fcs_move_stack));
    new_move_stack_to_parent->moves = new_moves_to_parent;
    new_move_stack_to_parent->num_moves = old_move_stack_to_parent->num_moves;
    memcpy(new_moves_to_parent, old_move_stack_to_parent->moves,
        sizeof(fcs_move_t) * old_move_stack_to_parent->num_moves);
    return new_move_stack_to_parent;
}
#endif