172 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| [patch#4 2/8] Code cleanup: new path to VEC in utils.c
 | |
| http://sourceware.org/ml/gdb-patches/2012-04/msg00086.html
 | |
| http://sourceware.org/ml/gdb-cvs/2012-04/msg00111.html
 | |
|  - reduced for the backport
 | |
| 
 | |
| ### src/gdb/ChangeLog	2012/04/17 15:45:05	1.14110
 | |
| ### src/gdb/ChangeLog	2012/04/17 15:47:08	1.14111
 | |
| ## -1,6 +1,34 @@
 | |
|  2012-04-17  Jan Kratochvil  <jan.kratochvil@redhat.com>
 | |
|  
 | |
|  	Code cleanup.
 | |
| +	* charset.c (find_charset_names): Remove variables ix and elt.
 | |
| +	Use free_char_ptr_vec.
 | |
| +	* elfread.c (build_id_to_debug_filename): New variables debugdir_vec,
 | |
| +	back_to and ix.  Use dirnames_to_char_ptr_vec.  Remove variable
 | |
| +	debugdir_end.  New variable debugdir_len.
 | |
| +	* gdb_vecs.h (free_char_ptr_vec, make_cleanup_free_char_ptr_vec)
 | |
| +	(dirnames_to_char_ptr_vec_append, dirnames_to_char_ptr_vec): New
 | |
| +	declarations.
 | |
| +	* progspace.c (clear_program_space_solib_cache): Remove variables ix
 | |
| +	and elt.  Use free_char_ptr_vec.
 | |
| +	* source.c (add_path): Remove variables argv, arg and argv_index.
 | |
| +	New variables dir_vec, back_to, ix and name.
 | |
| +	Use dirnames_to_char_ptr_vec_append.  Use freeargv instead of
 | |
| +	make_cleanup_freeargv.  Remove variable separator.  Simplify the code
 | |
| +	no longer expecting DIRNAME_SEPARATOR.
 | |
| +	(openp): Remove variable p, p1 and len.  New variables dir_vec,
 | |
| +	back_to, ix and dir.  Use dirnames_to_char_ptr_vec.  Simplify the code
 | |
| +	no longer expecting DIRNAME_SEPARATOR.
 | |
| +	* symfile.c (find_separate_debug_file): New variables debugdir_vec,
 | |
| +	back_to and ix.  Use dirnames_to_char_ptr_vec.  Remove variable
 | |
| +	debugdir_end.
 | |
| +	* utils.c (free_char_ptr_vec, do_free_char_ptr_vec)
 | |
| +	(make_cleanup_free_char_ptr_vec, dirnames_to_char_ptr_vec_append)
 | |
| +	(dirnames_to_char_ptr_vec): New functions.
 | |
| +
 | |
| +2012-04-17  Jan Kratochvil  <jan.kratochvil@redhat.com>
 | |
| +
 | |
| +	Code cleanup.
 | |
|  	* source.c (add_path): Remove always true conditional 'p == 0' and
 | |
|  	unindent its code block.
 | |
|  
 | |
| Index: gdb-7.4.50.20120120/gdb/gdb_vecs.h
 | |
| ===================================================================
 | |
| --- gdb-7.4.50.20120120.orig/gdb/gdb_vecs.h	2012-04-18 00:40:12.067086016 +0200
 | |
| +++ gdb-7.4.50.20120120/gdb/gdb_vecs.h	2012-04-18 00:40:23.474056993 +0200
 | |
| @@ -25,4 +25,16 @@
 | |
|  
 | |
|  DEF_VEC_P (char_ptr);
 | |
|  
 | |
| +/* From utils.c: */
 | |
| +
 | |
| +extern void free_char_ptr_vec (VEC (char_ptr) *char_ptr_vec);
 | |
| +
 | |
| +extern struct cleanup *
 | |
| +  make_cleanup_free_char_ptr_vec (VEC (char_ptr) *char_ptr_vec);
 | |
| +
 | |
| +extern void dirnames_to_char_ptr_vec_append (VEC (char_ptr) **vecp,
 | |
| +					     const char *dirnames);
 | |
| +
 | |
| +extern VEC (char_ptr) *dirnames_to_char_ptr_vec (const char *dirnames);
 | |
| +
 | |
|  #endif /* GDB_VECS_H */
 | |
| Index: gdb-7.4.50.20120120/gdb/utils.c
 | |
| ===================================================================
 | |
| --- gdb-7.4.50.20120120.orig/gdb/utils.c	2012-04-18 00:40:12.068086013 +0200
 | |
| +++ gdb-7.4.50.20120120/gdb/utils.c	2012-04-18 00:40:49.862989855 +0200
 | |
| @@ -29,6 +29,7 @@
 | |
|  #ifdef HAVE_SYS_RESOURCE_H
 | |
|  #include <sys/resource.h>
 | |
|  #endif /* HAVE_SYS_RESOURCE_H */
 | |
| +#include "gdb_vecs.h"
 | |
|  
 | |
|  #ifdef TUI
 | |
|  #include "tui/tui.h"		/* For tui_get_command_dimension.   */
 | |
| @@ -3835,6 +3836,95 @@ producer_is_gcc_ge_4 (const char *produc
 | |
|    return minor;
 | |
|  }
 | |
|  
 | |
| +/* Call xfree for each element of CHAR_PTR_VEC and final VEC_free for
 | |
| +   CHAR_PTR_VEC itself.
 | |
| +
 | |
| +   You must not modify CHAR_PTR_VEC after it got registered with this function
 | |
| +   by make_cleanup as the CHAR_PTR_VEC base address may change on its updates.
 | |
| +   Contrary to VEC_free this function does not (cannot) clear the pointer.  */
 | |
| +
 | |
| +void
 | |
| +free_char_ptr_vec (VEC (char_ptr) *char_ptr_vec)
 | |
| +{
 | |
| +  int ix;
 | |
| +  char *name;
 | |
| +
 | |
| +  for (ix = 0; VEC_iterate (char_ptr, char_ptr_vec, ix, name); ++ix)
 | |
| +    xfree (name);
 | |
| +  VEC_free (char_ptr, char_ptr_vec);
 | |
| +}
 | |
| +
 | |
| +/* Helper for make_cleanup_free_char_ptr_vec.  */
 | |
| +
 | |
| +static void
 | |
| +do_free_char_ptr_vec (void *arg)
 | |
| +{
 | |
| +  VEC (char_ptr) *char_ptr_vec = arg;
 | |
| +
 | |
| +  free_char_ptr_vec (char_ptr_vec);
 | |
| +}
 | |
| +
 | |
| +/* Make cleanup handler calling xfree for each element of CHAR_PTR_VEC and
 | |
| +   final VEC_free for CHAR_PTR_VEC itself.
 | |
| +
 | |
| +   You must not modify CHAR_PTR_VEC after this cleanup registration as the
 | |
| +   CHAR_PTR_VEC base address may change on its updates.  Contrary to VEC_free
 | |
| +   this function does not (cannot) clear the pointer.  */
 | |
| +
 | |
| +struct cleanup *
 | |
| +make_cleanup_free_char_ptr_vec (VEC (char_ptr) *char_ptr_vec)
 | |
| +{
 | |
| +  return make_cleanup (do_free_char_ptr_vec, char_ptr_vec);
 | |
| +}
 | |
| +
 | |
| +/* Extended version of dirnames_to_char_ptr_vec - additionally if *VECP is
 | |
| +   non-NULL the new list elements from DIRNAMES are appended to the existing
 | |
| +   *VECP list of entries.  *VECP address will be updated by this call.  */
 | |
| +
 | |
| +void
 | |
| +dirnames_to_char_ptr_vec_append (VEC (char_ptr) **vecp, const char *dirnames)
 | |
| +{
 | |
| +  do
 | |
| +    {
 | |
| +      size_t this_len;
 | |
| +      char *next_dir, *this_dir;
 | |
| +
 | |
| +      next_dir = strchr (dirnames, DIRNAME_SEPARATOR);
 | |
| +      if (next_dir == NULL)
 | |
| +	this_len = strlen (dirnames);
 | |
| +      else
 | |
| +	{
 | |
| +	  this_len = next_dir - dirnames;
 | |
| +	  next_dir++;
 | |
| +	}
 | |
| +
 | |
| +      this_dir = xmalloc (this_len + 1);
 | |
| +      memcpy (this_dir, dirnames, this_len);
 | |
| +      this_dir[this_len] = '\0';
 | |
| +      VEC_safe_push (char_ptr, *vecp, this_dir);
 | |
| +
 | |
| +      dirnames = next_dir;
 | |
| +    }
 | |
| +  while (dirnames != NULL);
 | |
| +}
 | |
| +
 | |
| +/* Split DIRNAMES by DIRNAME_SEPARATOR delimiter and return a list of all the
 | |
| +   elements in their original order.  For empty string ("") DIRNAMES return
 | |
| +   list of one empty string ("") element.
 | |
| +   
 | |
| +   You may modify the returned strings.
 | |
| +   Read free_char_ptr_vec for its cleanup.  */
 | |
| +
 | |
| +VEC (char_ptr) *
 | |
| +dirnames_to_char_ptr_vec (const char *dirnames)
 | |
| +{
 | |
| +  VEC (char_ptr) *retval = NULL;
 | |
| +  
 | |
| +  dirnames_to_char_ptr_vec_append (&retval, dirnames);
 | |
| +
 | |
| +  return retval;
 | |
| +}
 | |
| +
 | |
|  #ifdef HAVE_WAITPID
 | |
|  
 | |
|  #ifdef SIGALRM
 |