mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 11:14:33 +00:00 
			
		
		
		
	bpo-29673: fix gdb scripts pystack and pystackv (GH-6126)
This commit is contained in:
		
							parent
							
								
									1d87c7b80b
								
							
						
					
					
						commit
						3a9ccee0e5
					
				
					 4 changed files with 10 additions and 8 deletions
				
			
		|  | @ -1250,6 +1250,7 @@ Zero Piraeus | ||||||
| Antoine Pitrou | Antoine Pitrou | ||||||
| Jean-François Piéronne | Jean-François Piéronne | ||||||
| Oleg Plakhotnyuk | Oleg Plakhotnyuk | ||||||
|  | Marcel Plch | ||||||
| Remi Pointel | Remi Pointel | ||||||
| Jon Poler | Jon Poler | ||||||
| Ariel Poliak | Ariel Poliak | ||||||
|  |  | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | Fix pystackv and pystack gdbinit macros. | ||||||
							
								
								
									
										14
									
								
								Misc/gdbinit
									
										
									
									
									
								
							
							
						
						
									
										14
									
								
								Misc/gdbinit
									
										
									
									
									
								
							|  | @ -42,8 +42,8 @@ define pylocals | ||||||
|     set $_i = 0 |     set $_i = 0 | ||||||
|     while $_i < f->f_code->co_nlocals |     while $_i < f->f_code->co_nlocals | ||||||
| 	if f->f_localsplus + $_i != 0 | 	if f->f_localsplus + $_i != 0 | ||||||
| 	    set $_names = co->co_varnames | 	    set $_names = f->f_code->co_varnames | ||||||
| 	    set $_name = _PyUnicode_AsString(PyTuple_GetItem($_names, $_i)) | 	    set $_name = PyUnicode_AsUTF8(PyTuple_GetItem($_names, $_i)) | ||||||
| 	    printf "%s:\n", $_name | 	    printf "%s:\n", $_name | ||||||
|             pyo f->f_localsplus[$_i] |             pyo f->f_localsplus[$_i] | ||||||
| 	end | 	end | ||||||
|  | @ -84,8 +84,8 @@ define pyframev | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| define pyframe | define pyframe | ||||||
|     set $__fn = _PyUnicode_AsString(co->co_filename) |     set $__fn = PyUnicode_AsUTF8(f->f_code->co_filename) | ||||||
|     set $__n = _PyUnicode_AsString(co->co_name) |     set $__n = PyUnicode_AsUTF8(f->f_code->co_name) | ||||||
|     printf "%s (", $__fn |     printf "%s (", $__fn | ||||||
|     lineno |     lineno | ||||||
|     printf "): %s\n", $__n |     printf "): %s\n", $__n | ||||||
|  | @ -110,7 +110,7 @@ end | ||||||
| #end | #end | ||||||
| 
 | 
 | ||||||
| define printframe | define printframe | ||||||
|     if $pc > PyEval_EvalFrameEx && $pc < PyEval_EvalCodeEx |     if $pc > PyEval_EvalFrameEx && $pc < _PyEval_EvalFrameDefault | ||||||
| 	pyframe | 	pyframe | ||||||
|     else |     else | ||||||
|         frame |         frame | ||||||
|  | @ -139,7 +139,7 @@ document pystack | ||||||
| end | end | ||||||
| define pystack | define pystack | ||||||
|     while $pc < Py_Main || $pc > Py_GetArgcArgv |     while $pc < Py_Main || $pc > Py_GetArgcArgv | ||||||
|         if $pc > PyEval_EvalFrameEx && $pc < PyEval_EvalCodeEx |         if $pc > PyEval_EvalFrameEx && $pc < _PyEval_EvalFrameDefault | ||||||
| 	    pyframe | 	    pyframe | ||||||
|         end |         end | ||||||
|         up-silently 1 |         up-silently 1 | ||||||
|  | @ -152,7 +152,7 @@ document pystackv | ||||||
| end | end | ||||||
| define pystackv | define pystackv | ||||||
|     while $pc < Py_Main || $pc > Py_GetArgcArgv |     while $pc < Py_Main || $pc > Py_GetArgcArgv | ||||||
|         if $pc > PyEval_EvalFrameEx && $pc < PyEval_EvalCodeEx |         if $pc > PyEval_EvalFrameEx && $pc < _PyEval_EvalFrameDefault | ||||||
| 	    pyframev | 	    pyframev | ||||||
|         end |         end | ||||||
|         up-silently 1 |         up-silently 1 | ||||||
|  |  | ||||||
|  | @ -3661,7 +3661,7 @@ too_many_positional(PyCodeObject *co, Py_ssize_t given, Py_ssize_t defcount, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* This is gonna seem *real weird*, but if you put some other code between
 | /* This is gonna seem *real weird*, but if you put some other code between
 | ||||||
|    PyEval_EvalFrame() and PyEval_EvalCodeEx() you will need to adjust |    PyEval_EvalFrame() and _PyEval_EvalFrameDefault() you will need to adjust | ||||||
|    the test in the if statements in Misc/gdbinit (pystack and pystackv). */ |    the test in the if statements in Misc/gdbinit (pystack and pystackv). */ | ||||||
| 
 | 
 | ||||||
| PyObject * | PyObject * | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Marcel Plch
						Marcel Plch