⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ftdbgmem.c

📁 下载来的一个看图软件的源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
/***************************************************************************//*                                                                         *//*  ftdbgmem.c                                                             *//*                                                                         *//*    Memory debugger (body).                                              *//*                                                                         *//*  Copyright 2001, 2002, 2003 by                                          *//*  David Turner, Robert Wilhelm, and Werner Lemberg.                      *//*                                                                         *//*  This file is part of the FreeType project, and may only be used,       *//*  modified, and distributed under the terms of the FreeType project      *//*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     *//*  this file you indicate that you have read the license and              *//*  understand and accept it fully.                                        *//*                                                                         *//***************************************************************************/#include <ft2build.h>#include FT_CONFIG_CONFIG_H#include FT_INTERNAL_DEBUG_H#include FT_INTERNAL_MEMORY_H#include FT_SYSTEM_H#include FT_ERRORS_H#include FT_TYPES_H#ifdef FT_DEBUG_MEMORY#include <stdio.h>#include <stdlib.h>  typedef struct FT_MemNodeRec_*   FT_MemNode;  typedef struct FT_MemTableRec_*  FT_MemTable;#define FT_MEM_VAL( addr )  ((FT_ULong)(FT_Pointer)( addr ))  typedef struct  FT_MemNodeRec_  {    FT_Byte*     address;    FT_Long      size;     /* < 0 if the block was freed */    const char*  alloc_file_name;    FT_Long      alloc_line_no;    const char*  free_file_name;    FT_Long      free_line_no;    FT_MemNode   link;  } FT_MemNodeRec;  typedef struct  FT_MemTableRec_  {    FT_ULong         size;    FT_ULong         nodes;    FT_MemNode*      buckets;    FT_ULong         alloc_total;    FT_ULong         alloc_current;    FT_ULong         alloc_max;    FT_ULong         alloc_count;    FT_Bool          bound_total;        FT_ULong         alloc_total_max;        FT_Bool          bound_count;    FT_ULong         alloc_count_max;    const char*      file_name;    FT_Long          line_no;    FT_Memory        memory;    FT_Pointer       memory_user;    FT_Alloc_Func    alloc;    FT_Free_Func     free;    FT_Realloc_Func  realloc;  } FT_MemTableRec;#define FT_MEM_SIZE_MIN  7#define FT_MEM_SIZE_MAX  13845163#define FT_FILENAME( x )  ((x) ? (x) : "unknown file")  static const FT_UInt  ft_mem_primes[] =  {    7,    11,    19,    37,    73,    109,    163,    251,    367,    557,    823,    1237,    1861,    2777,    4177,    6247,    9371,    14057,    21089,    31627,    47431,    71143,    106721,    160073,    240101,    360163,    540217,    810343,    1215497,    1823231,    2734867,    4102283,    6153409,    9230113,    13845163,  };  extern void  ft_mem_debug_panic( const char*  fmt, ... )  {    va_list  ap;    printf( "FreeType.Debug: " );    va_start( ap, fmt );    vprintf( fmt, ap );    va_end( ap );    printf( "\n" );    exit( EXIT_FAILURE );  }  static FT_ULong  ft_mem_closest_prime( FT_ULong  num )  {    FT_UInt  i;    for ( i = 0;          i < sizeof ( ft_mem_primes ) / sizeof ( ft_mem_primes[0] ); i++ )      if ( ft_mem_primes[i] > num )        return ft_mem_primes[i];    return FT_MEM_SIZE_MAX;  }  static FT_Pointer  ft_mem_table_alloc( FT_MemTable  table,                      FT_Long      size )  {    FT_Memory   memory = table->memory;    FT_Pointer  block;    memory->user = table->memory_user;    block = table->alloc( memory, size );    memory->user = table;   return block;  }  static void  ft_mem_table_free( FT_MemTable  table,                     FT_Pointer   block )  {    FT_Memory  memory = table->memory;    memory->user = table->memory_user;    table->free( memory, block );    memory->user = table;  }  static void  ft_mem_table_resize( FT_MemTable  table )  {    FT_ULong  new_size;    new_size = ft_mem_closest_prime( table->nodes );    if ( new_size != table->size )    {      FT_MemNode*  new_buckets ;      FT_ULong     i;      new_buckets = (FT_MemNode *)                    ft_mem_table_alloc( table,                                        new_size * sizeof ( FT_MemNode ) );      if ( new_buckets == NULL )        return;      FT_MEM_ZERO( new_buckets, sizeof ( FT_MemNode ) * new_size );      for ( i = 0; i < table->size; i++ )      {        FT_MemNode  node, next, *pnode;        FT_ULong    hash;        node = table->buckets[i];        while ( node )        {          next  = node->link;          hash  = FT_MEM_VAL( node->address ) % new_size;          pnode = new_buckets + hash;          node->link = pnode[0];          pnode[0]   = node;          node = next;        }      }      if ( table->buckets )        ft_mem_table_free( table, table->buckets );      table->buckets = new_buckets;      table->size    = new_size;    }  }  static FT_MemTable  ft_mem_table_new( FT_Memory  memory )  {    FT_MemTable  table;    table = (FT_MemTable)memory->alloc( memory, sizeof ( *table ) );    if ( table == NULL )      goto Exit;    FT_MEM_ZERO( table, sizeof ( *table ) );    table->size  = FT_MEM_SIZE_MIN;    table->nodes = 0;    table->memory = memory;    table->memory_user = memory->user;    table->alloc   = memory->alloc;    table->realloc = memory->realloc;    table->free    = memory->free;    table->buckets = (FT_MemNode *)                     memory->alloc( memory,                                    table->size * sizeof ( FT_MemNode ) );    if ( table->buckets )      FT_MEM_ZERO( table->buckets, sizeof ( FT_MemNode ) * table->size );    else    {      memory->free( memory, table );      table = NULL;    }  Exit:    return table;  }  static void  ft_mem_table_destroy( FT_MemTable  table )  {    FT_ULong  i;    if ( table )    {      FT_Long    leak_count = 0;      FT_ULong   leaks = 0;      for ( i = 0; i < table->size; i++ )      {        FT_MemNode  *pnode = table->buckets + i, next, node = *pnode;        while ( node )        {          next       = node->link;          node->link = 0;          if ( node->size > 0 )          {            printf(              "leaked memory block at address %p, size %8ld in (%s:%ld)\n",              node->address, node->size,              FT_FILENAME( node->alloc_file_name ),              node->alloc_line_no );            leak_count++;            leaks += node->size;            ft_mem_table_free( table, node->address );          }          node->address = NULL;          node->size    = 0;          free( node );          node = next;        }        table->buckets[i] = 0;      }      ft_mem_table_free( table, table->buckets );      table->buckets = NULL;      table->size   = 0;      table->nodes  = 0;      printf(        "FreeType: total memory allocations = %ld\n", table->alloc_total );      printf(        "FreeType: maximum memory footprint = %ld\n", table->alloc_max );      free( table );      if ( leak_count > 0 )        ft_mem_debug_panic(          "FreeType: %ld bytes of memory leaked in %ld blocks\n",          leaks, leak_count );      printf( "FreeType: No memory leaks detected!\n" );    }  }  static FT_MemNode*  ft_mem_table_get_nodep( FT_MemTable  table,                          FT_Byte*     address )  {    FT_ULong     hash;    FT_MemNode  *pnode, node;    hash  = FT_MEM_VAL( address );    pnode = table->buckets + ( hash % table->size );    for (;;)    {

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -