Bug 634155: Account for NewCompartment's memory, and change allocation APIs (r=nnethercote)
This changes the allocation API, in the following way:
js_malloc -> {cx->,rt->,OffTheBooks::}malloc
js_calloc -> {cx->,rt->,OffTheBooks::}calloc
js_realloc -> {cx->,rt->,OffTheBooks::}realloc
js_free -> {cx->,rt->,Foreground::,UnwantedForeground::}free
js_new -> {cx->,rt->,OffTheBooks::}new_
js_new_array -> {cx->,rt->,OffTheBooks::}new_array
js_delete -> {cx->,rt->,Foreground::,UnwantedForeground::}delete_
This is to move as many allocations as possible through a JSContext (so that they may be aken into account by gcMallocBytes) and to move as many deallocations to the background as possible (except on error paths).
2011-03-31 12:13:49 +04:00
#!/usr/bin/env python
# Usage: check_source_count.py SEARCH_TERM COUNT ERROR_LOCATION REPLACEMENT [FILES...]
# Checks that FILES contains exactly COUNT matches of SEARCH_TERM. If it does
# not, an error message is printed, quoting ERROR_LOCATION, which should
# probably be the filename and line number of the erroneous call to
# check_source_count.py.
import sys
import os
import re
search_string = sys . argv [ 1 ]
expected_count = int ( sys . argv [ 2 ] )
error_location = sys . argv [ 3 ]
replacement = sys . argv [ 4 ]
files = sys . argv [ 5 : ]
details = { }
count = 0
for f in files :
text = file ( f ) . read ( )
match = re . findall ( search_string , text )
if match :
num = len ( match )
count + = num
details [ f ] = num
if count == expected_count :
print " TEST-PASS | check_source_count.py %s | %d " % ( search_string , expected_count )
else :
print " TEST-UNEXPECTED-FAIL | check_source_count.py %s | " % ( search_string ) ,
if count < expected_count :
2011-06-23 22:07:27 +04:00
print " There are fewer occurrences of / %s / than expected. This may mean that you have removed some, but forgotten to account for it %s . " % ( search_string , error_location )
Bug 634155: Account for NewCompartment's memory, and change allocation APIs (r=nnethercote)
This changes the allocation API, in the following way:
js_malloc -> {cx->,rt->,OffTheBooks::}malloc
js_calloc -> {cx->,rt->,OffTheBooks::}calloc
js_realloc -> {cx->,rt->,OffTheBooks::}realloc
js_free -> {cx->,rt->,Foreground::,UnwantedForeground::}free
js_new -> {cx->,rt->,OffTheBooks::}new_
js_new_array -> {cx->,rt->,OffTheBooks::}new_array
js_delete -> {cx->,rt->,Foreground::,UnwantedForeground::}delete_
This is to move as many allocations as possible through a JSContext (so that they may be aken into account by gcMallocBytes) and to move as many deallocations to the background as possible (except on error paths).
2011-03-31 12:13:49 +04:00
else :
2011-06-23 22:07:27 +04:00
print " There are more occurrences of / %s / than expected. We ' re trying to prevent an increase in the number of %s ' s, using %s if possible. If it in unavoidable, you should update the expected count %s . " % ( search_string , search_string , replacement , error_location )
Bug 634155: Account for NewCompartment's memory, and change allocation APIs (r=nnethercote)
This changes the allocation API, in the following way:
js_malloc -> {cx->,rt->,OffTheBooks::}malloc
js_calloc -> {cx->,rt->,OffTheBooks::}calloc
js_realloc -> {cx->,rt->,OffTheBooks::}realloc
js_free -> {cx->,rt->,Foreground::,UnwantedForeground::}free
js_new -> {cx->,rt->,OffTheBooks::}new_
js_new_array -> {cx->,rt->,OffTheBooks::}new_array
js_delete -> {cx->,rt->,Foreground::,UnwantedForeground::}delete_
This is to move as many allocations as possible through a JSContext (so that they may be aken into account by gcMallocBytes) and to move as many deallocations to the background as possible (except on error paths).
2011-03-31 12:13:49 +04:00
print " Expected: %d ; found: %d " % ( expected_count , count )
for k in sorted ( details ) :
print " Found %d occurences in %s " % ( details [ k ] , k )
sys . exit ( - 1 )