Skip to content
Snippets Groups Projects
Select Git revision
  • 4e31533e6bf28833bcccd8b9ce51521a0685ea1b
  • master default protected
  • 9.0
  • 8.0
  • nt-tools
  • 7.8
  • 7.6
  • 7.4
  • 7.2
  • 7.0
  • 0.6
  • rosuav/latex-markdown-renderer
  • rxnpatch/rxnpatch
  • marcus/gobject-introspection
  • rxnpatch/8.0
  • rosuav/pre-listening-ports
  • rosuav/async-annotations
  • rosuav/pgsql-ssl
  • rxnpatch/rxnpatch-broken/2023-10-06T094250
  • grubba/fdlib
  • grubba/wip/sakura/8.0
  • v8.0.2018
  • v8.0.2016
  • v8.0.2014
  • v8.0.2012
  • v8.0.2008
  • v8.0.2006
  • v8.0.2004
  • v8.0.2002
  • v8.0.2000
  • v8.0.1998
  • v8.0.1996
  • v8.0.1994
  • v8.0.1992
  • v8.0.1990
  • v8.0.1988
  • v8.0.1986
  • rxnpatch/clusters/8.0/2025-04-29T124414
  • rxnpatch/2025-04-29T124414
  • v8.0.1984
  • v8.0.1982
41 results

hashtable.c

Blame
    • Henrik (Grubba) Grubbström's avatar
      e0755c3e
      Fixed a few warnings. · e0755c3e
      Henrik (Grubba) Grubbström authored
      Rev: src/array.c:1.83
      Rev: src/backend.c:1.54
      Rev: src/docode.c:1.78
      Rev: src/encode.c:1.66
      Rev: src/error.c:1.60
      Rev: src/error.h:1.48
      Rev: src/errors.h:1.12
      Rev: src/fsort.c:1.14
      Rev: src/hashtable.c:1.7
      Rev: src/main.c:1.96
      Rev: src/pike_memory.h:1.21
      Rev: src/pike_types.c:1.133
      Rev: src/pike_types.h:1.43
      e0755c3e
      History
      Fixed a few warnings.
      Henrik (Grubba) Grubbström authored
      Rev: src/array.c:1.83
      Rev: src/backend.c:1.54
      Rev: src/docode.c:1.78
      Rev: src/encode.c:1.66
      Rev: src/error.c:1.60
      Rev: src/error.h:1.48
      Rev: src/errors.h:1.12
      Rev: src/fsort.c:1.14
      Rev: src/hashtable.c:1.7
      Rev: src/main.c:1.96
      Rev: src/pike_memory.h:1.21
      Rev: src/pike_types.c:1.133
      Rev: src/pike_types.h:1.43
    multiset.c 157.20 KiB
    /*
    || This file is part of Pike. For copyright information see COPYRIGHT.
    || Pike is distributed under GPL, LGPL and MPL. See the file COPYING
    || for more information.
    || $Id: multiset.c,v 1.115 2008/07/22 20:03:19 mast Exp $
    */
    
    #include "global.h"
    
    /* Multisets using rbtree.
     *
     * Created by Martin Stjernholm 2001-05-07
     */
    
    #include "builtin_functions.h"
    #include "gc.h"
    #include "interpret.h"
    #include "multiset.h"
    #include "mapping.h"
    #include "object.h"
    #include "opcodes.h"
    #include "pike_error.h"
    #include "rbtree_low.h"
    #include "pike_security.h"
    #include "svalue.h"
    
    #ifdef TEST_MULTISET
    #include "builtin_functions.h"
    #include "constants.h"
    #include "mapping.h"
    #endif
    
    #include "block_alloc.h"
    
    /* FIXME: Optimize finds and searches on type fields? (But not when
     * objects are involved!) Well.. Although cheap I suspect it pays off
     * so extremely seldom that it isn't worth it. /mast */
    
    #include <assert.h>
    
    #define sp Pike_sp
    
    /* The following defines the allocation policy. It's almost the same
     * as for mappings. */
    #define ALLOC_SIZE(size) ((size) ? (size) + 4 : 0)
    #define ENLARGE_SIZE(size) (((size) << 1) + 4)
    #define DO_SHRINK(msd, extra) ((((msd)->size + extra) << 2) + 4 <= (msd)->allocsize)
    
    #if defined (PIKE_DEBUG) || defined (TEST_MULTISET)
    static void debug_dump_ind_data (struct msnode_ind *node,
    				 struct multiset_data *msd);
    static void debug_dump_indval_data (struct msnode_indval *node,
    				    struct multiset_data *msd);
    DECLSPEC(noreturn) static void debug_multiset_fatal (
      struct multiset *l, const char *fmt, ...) ATTRIBUTE((noreturn, format (printf, 2, 3)));
    #define multiset_fatal (fprintf (stderr, "%s:%d: Fatal in multiset: ", \
    				 __FILE__, __LINE__), debug_multiset_fatal)
    #endif
    
    #ifdef PIKE_DEBUG
    
    /* To get good type checking. */
    static INLINE union msnode **msnode_ptr_check (union msnode **x)
      {return x;}
    static INLINE struct msnode_ind *msnode_ind_check (struct msnode_ind *x)
      {return x;}
    static INLINE struct msnode_indval *msnode_indval_check (struct msnode_indval *x)
      {return x;}
    
    #define sub_extra_ref(X) do {						\