Generated by Cython 0.29.26
Yellow lines hint at Python interaction.
Click on a line that starts with a "+
" to see the C code that Cython generated for it.
Raw output: c.c
+0001: # cython: language_level = 3
__pyx_t_5 = __Pyx_PyDict_NewPresized(47); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_collapse_blocks_line_69, __pyx_kp_u_Collapses_a_generic_sequence_of) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory___delitem___line_5705, __pyx_kp_u_Deletes_data_Arguments_key_slice) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory___eq___line_5761, __pyx_kp_u_Equality_comparison_Arguments_ot) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory___getitem___line_5803, __pyx_kp_u_Gets_data_Arguments_key_slice_or) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory___setitem___line_5939, __pyx_kp_u_Sets_data_Arguments_key_slice_or) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory___str___line_6016, __pyx_kp_u_String_representation_If_attr_co) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory__block_index_at_line_6068, __pyx_kp_u_Locates_the_block_enclosing_an_a) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory__block_index_endex_line_6, __pyx_kp_u_Locates_the_first_block_after_an) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory__block_index_start_line_6, __pyx_kp_u_Locates_the_first_block_inside_o) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_append_line_6302, __pyx_kp_u_Appends_a_single_item_Arguments) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_block_span_line_6360, __pyx_kp_u_Span_of_block_data_It_searches_f) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_bound_line_6452, __pyx_kp_u_Bounds_addresses_It_bounds_the_g) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_clear_line_6522, __pyx_kp_u_Clears_an_address_range_Argument) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_content_endex___get___lin, __pyx_kp_u_int_Exclusive_content_end_addres) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_content_endin___get___lin, __pyx_kp_u_int_Inclusive_content_end_addres) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_content_parts___get___lin, __pyx_kp_u_Number_of_blocks_Returns_int_The) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_content_size___get___line, __pyx_kp_u_Actual_content_size_Returns_int) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_content_span___get___line, __pyx_kp_u_tuple_of_int_Memory_content_addr) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_content_start___get___lin, __pyx_kp_u_int_Inclusive_content_start_addr) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_count_line_6884, __pyx_kp_u_Counts_items_Arguments_item_item) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_crop_line_6921, __pyx_kp_u_Keeps_data_within_an_address_ran) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_delete_line_7030, __pyx_kp_u_Deletes_an_address_range_Argumen) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_endex___get___line_7115, __pyx_kp_u_int_Exclusive_end_address_This_p) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_endin___get___line_7160, __pyx_kp_u_int_Inclusive_end_address_This_p) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_equal_span_line_7204, __pyx_kp_u_Span_of_homogeneous_data_It_sear) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_extract_line_7383, __pyx_kp_u_Selects_items_from_a_range_Argum) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_fill_line_7447, __pyx_kp_u_Overwrites_a_range_with_a_patter) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_flood_line_7576, __pyx_kp_u_Fills_emptiness_between_non_touc) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_from_blocks_line_7679, __pyx_kp_u_Creates_a_virtual_memory_from_bl) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_from_bytes_line_7749, __pyx_kp_u_Creates_a_virtual_memory_from_a) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_from_memory_line_7811, __pyx_kp_u_Creates_a_virtual_memory_from_an) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_gaps_line_7883, __pyx_kp_u_Iterates_over_block_gaps_Iterate) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_insert_line_8000, __pyx_kp_u_Inserts_data_Inserts_data_moving) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_intervals_line_8095, __pyx_kp_u_Iterates_over_block_intervals_It) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_items_line_8159, __pyx_kp_u_Iterates_over_address_and_value) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_keys_line_8217, __pyx_kp_u_Iterates_over_addresses_Iterates) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_peek_line_8316, __pyx_kp_u_Gets_the_item_at_an_address_Retu) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_poke_line_8349, __pyx_kp_u_Sets_the_item_at_an_address_Argu) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_pop_line_8430, __pyx_kp_u_Takes_a_value_away_Arguments_add) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_reserve_line_8518, __pyx_kp_u_Inserts_emptiness_Reserves_empti) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_rvalues_line_8702, __pyx_kp_u_Iterates_over_values_reversed_or) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_shift_line_8800, __pyx_kp_u_Shifts_the_items_Arguments_offse) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_span___get___line_8897, __pyx_kp_u_tuple_of_int_Memory_address_span) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_start___get___line_8926, __pyx_kp_u_int_Inclusive_start_address_This) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_values_line_9043, __pyx_kp_u_Iterates_over_values_Iterates_ov) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_view_line_9140, __pyx_kp_u_Creates_a_view_over_a_range_Crea) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_kp_u_Memory_write_line_9193, __pyx_kp_u_Writes_data_Arguments_address_in) < 0) __PYX_ERR(0, 1, __pyx_L1_error) if (PyDict_SetItem(__pyx_d, __pyx_n_s_test, __pyx_t_5) < 0) __PYX_ERR(0, 1, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
0002: # cython: embedsignature = True
0003: # cython: binding = True
0004:
0005: # Copyright (c) 2020-2022, Andrea Zoppi.
0006: # All rights reserved.
0007: #
0008: # Redistribution and use in source and binary forms, with or without
0009: # modification, are permitted provided that the following conditions are met:
0010: #
0011: # 1. Redistributions of source code must retain the above copyright notice,
0012: # this list of conditions and the following disclaimer.
0013: #
0014: # 2. Redistributions in binary form must reproduce the above copyright
0015: # notice, this list of conditions and the following disclaimer in the
0016: # documentation and/or other materials provided with the distribution.
0017: #
0018: # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
0019: # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
0020: # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
0021: # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
0022: # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
0023: # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
0024: # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
0025: # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
0026: # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
0027: # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
0028: # POSSIBILITY OF SUCH DAMAGE.
0029:
0030: r"""Cython implementation."""
0031:
0032: cimport cython
0033: from cpython.bytearray cimport PyByteArray_FromStringAndSize
0034: from cpython.bytes cimport PyBytes_FromStringAndSize
0035:
+0036: from itertools import count as _count
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 36, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_count); __Pyx_GIVEREF(__pyx_n_s_count); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_count); __pyx_t_2 = __Pyx_Import(__pyx_n_s_itertools, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 36, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_count); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 36, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_count_2, __pyx_t_1) < 0) __PYX_ERR(0, 36, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0037: from itertools import islice as _islice
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 37, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_islice); __Pyx_GIVEREF(__pyx_n_s_islice); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_islice); __pyx_t_1 = __Pyx_Import(__pyx_n_s_itertools, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 37, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_islice); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 37, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_islice_2, __pyx_t_2) < 0) __PYX_ERR(0, 37, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0038: from itertools import repeat as _repeat
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 38, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_repeat); __Pyx_GIVEREF(__pyx_n_s_repeat); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_repeat); __pyx_t_2 = __Pyx_Import(__pyx_n_s_itertools, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 38, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_repeat); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 38, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_repeat_2, __pyx_t_1) < 0) __PYX_ERR(0, 38, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0039: from itertools import zip_longest as _zip_longest
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 39, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_zip_longest); __Pyx_GIVEREF(__pyx_n_s_zip_longest); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_zip_longest); __pyx_t_1 = __Pyx_Import(__pyx_n_s_itertools, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 39, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_zip_longest); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 39, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_zip_longest_2, __pyx_t_2) < 0) __PYX_ERR(0, 39, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0040: from typing import Any
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 40, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_Any); __Pyx_GIVEREF(__pyx_n_s_Any); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_Any); __pyx_t_2 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 40, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_Any); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 40, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Any, __pyx_t_1) < 0) __PYX_ERR(0, 40, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0041: from typing import ByteString
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 41, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_ByteString); __Pyx_GIVEREF(__pyx_n_s_ByteString); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_ByteString); __pyx_t_1 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 41, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_ByteString); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 41, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_ByteString, __pyx_t_2) < 0) __PYX_ERR(0, 41, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0042: from typing import Iterable
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 42, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_Iterable); __Pyx_GIVEREF(__pyx_n_s_Iterable); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_Iterable); __pyx_t_2 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 42, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_Iterable); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 42, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Iterable, __pyx_t_1) < 0) __PYX_ERR(0, 42, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0043: from typing import Iterator
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 43, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_Iterator); __Pyx_GIVEREF(__pyx_n_s_Iterator); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_Iterator); __pyx_t_1 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 43, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 43, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Iterator, __pyx_t_2) < 0) __PYX_ERR(0, 43, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0044: from typing import List
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 44, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_List); __Pyx_GIVEREF(__pyx_n_s_List); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_List); __pyx_t_2 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 44, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_List); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 44, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_List, __pyx_t_1) < 0) __PYX_ERR(0, 44, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0045: from typing import Optional
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 45, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_Optional); __Pyx_GIVEREF(__pyx_n_s_Optional); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_Optional); __pyx_t_1 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 45, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 45, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Optional, __pyx_t_2) < 0) __PYX_ERR(0, 45, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0046: from typing import Sequence
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 46, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_Sequence); __Pyx_GIVEREF(__pyx_n_s_Sequence); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_Sequence); __pyx_t_2 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 46, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_Sequence); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 46, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Sequence, __pyx_t_1) < 0) __PYX_ERR(0, 46, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0047: from typing import Tuple
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 47, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_Tuple); __Pyx_GIVEREF(__pyx_n_s_Tuple); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_Tuple); __pyx_t_1 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 47, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 47, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Tuple, __pyx_t_2) < 0) __PYX_ERR(0, 47, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0048: from typing import Type
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_Type); __Pyx_GIVEREF(__pyx_n_s_Type); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_Type); __pyx_t_2 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_Type); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Type, __pyx_t_1) < 0) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0049: from typing import Union
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 49, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_Union); __Pyx_GIVEREF(__pyx_n_s_Union); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_Union); __pyx_t_1 = __Pyx_Import(__pyx_n_s_typing, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 49, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Union); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 49, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Union, __pyx_t_2) < 0) __PYX_ERR(0, 49, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
0050:
+0051: from bytesparse.base import STR_MAX_CONTENT_SIZE
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 51, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_STR_MAX_CONTENT_SIZE); __Pyx_GIVEREF(__pyx_n_s_STR_MAX_CONTENT_SIZE); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_STR_MAX_CONTENT_SIZE); __pyx_t_2 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 51, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_STR_MAX_CONTENT_SIZE); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 51, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_STR_MAX_CONTENT_SIZE, __pyx_t_1) < 0) __PYX_ERR(0, 51, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0052: from bytesparse.base import Address
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 52, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_Address); __Pyx_GIVEREF(__pyx_n_s_Address); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_Address); __pyx_t_1 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 52, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 52, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Address, __pyx_t_2) < 0) __PYX_ERR(0, 52, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0053: from bytesparse.base import AnyBytes
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_AnyBytes); __Pyx_GIVEREF(__pyx_n_s_AnyBytes); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_AnyBytes); __pyx_t_2 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_AnyBytes, __pyx_t_1) < 0) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0054: from bytesparse.base import BlockIndex
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_BlockIndex); __Pyx_GIVEREF(__pyx_n_s_BlockIndex); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_BlockIndex); __pyx_t_1 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_BlockIndex); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_BlockIndex, __pyx_t_2) < 0) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0055: from bytesparse.base import BlockIterable
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 55, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_BlockIterable); __Pyx_GIVEREF(__pyx_n_s_BlockIterable); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_BlockIterable); __pyx_t_2 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 55, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_BlockIterable); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 55, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_BlockIterable, __pyx_t_1) < 0) __PYX_ERR(0, 55, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0056: from bytesparse.base import BlockList
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 56, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_BlockList); __Pyx_GIVEREF(__pyx_n_s_BlockList); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_BlockList); __pyx_t_1 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 56, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_BlockList); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 56, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_BlockList, __pyx_t_2) < 0) __PYX_ERR(0, 56, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0057: from bytesparse.base import ClosedInterval
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 57, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_ClosedInterval); __Pyx_GIVEREF(__pyx_n_s_ClosedInterval); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_ClosedInterval); __pyx_t_2 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 57, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_ClosedInterval); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 57, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_ClosedInterval, __pyx_t_1) < 0) __PYX_ERR(0, 57, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0058: from bytesparse.base import EllipsisType
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 58, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_EllipsisType); __Pyx_GIVEREF(__pyx_n_s_EllipsisType); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_EllipsisType); __pyx_t_1 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 58, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_EllipsisType); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 58, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_EllipsisType, __pyx_t_2) < 0) __PYX_ERR(0, 58, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0059: from bytesparse.base import OpenInterval
__pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 59, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_n_s_OpenInterval); __Pyx_GIVEREF(__pyx_n_s_OpenInterval); PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_OpenInterval); __pyx_t_2 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 59, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_OpenInterval); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 59, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_d, __pyx_n_s_OpenInterval, __pyx_t_1) < 0) __PYX_ERR(0, 59, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0060: from bytesparse.base import Value
__pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 60, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_n_s_Value); __Pyx_GIVEREF(__pyx_n_s_Value); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_Value); __pyx_t_1 = __Pyx_Import(__pyx_n_s_bytesparse_base, __pyx_t_2, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 60, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 60, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_d, __pyx_n_s_Value, __pyx_t_2) < 0) __PYX_ERR(0, 60, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
0061:
0062: # Allocate an empty block, so that an empty view can be returned statically
0063: cdef:
+0064: Block_* _empty_block = Block_Acquire(Block_Alloc(0, 0, False))
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Alloc(0, 0, 0); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 64, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_t_3); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 64, __pyx_L1_error) __pyx_v_11cbytesparse_1c__empty_block = __pyx_t_4;
0065:
0066:
0067: # =====================================================================================================================
0068:
+0069: def collapse_blocks(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_1collapse_blocks(PyObject *__pyx_self, PyObject *__pyx_v_blocks); /*proto*/ static char __pyx_doc_11cbytesparse_1c_collapse_blocks[] = "collapse_blocks(blocks: BlockIterable) -> BlockList\nCollapses a generic sequence of blocks.\n\n Given a generic sequence of blocks, writes them in the same order,\n generating a new sequence of non-contiguous blocks, sorted by address.\n\n Arguments:\n blocks (sequence of blocks):\n Sequence of blocks to collapse.\n\n Returns:\n list of blocks: Collapsed block list.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n |[0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9]|\n +---+---+---+---+---+---+---+---+---+---+\n |[A | B | C | D]| | | | | | |\n +---+---+---+---+---+---+---+---+---+---+\n | | | |[E | F]| | | | | |\n +---+---+---+---+---+---+---+---+---+---+\n |[$]| | | | | | | | | |\n +---+---+---+---+---+---+---+---+---+---+\n | | | | | | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n |[$ | B | C | E | F | 5 | x | y | z | 9]|\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> blocks = [\n ... [0, b'0123456789'],\n ... [0, b'ABCD'],\n ... [3, b'EF'],\n ... [0, b'$'],\n ... [6, b'xyz'],\n ... ]\n >>> collapse_blocks(blocks)\n [[0, b'$BCEF5xyz9']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n |[0 | 1 | 2]| | | | | | | |\n +---+---+---+---+---+---+---+---+---+---+\n | | | | |[A | B]| | | | |\n +---+---+---+---+---+---+---+---+---+---+\n | | | | | | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[$]| | | | | | | | |\n +---+---+---""+---+---+---+---+---+---+---+\n |[0 | $ | 2]| |[A | B | x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> blocks = [\n ... [0, b'012'],\n ... [4, b'AB'],\n ... [6, b'xyz'],\n ... [1, b'$'],\n ... ]\n >>> collapse_blocks(blocks)\n [[0, b'0$2'], [4, b'ABxyz']]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_1collapse_blocks = {"collapse_blocks", (PyCFunction)__pyx_pw_11cbytesparse_1c_1collapse_blocks, METH_O, __pyx_doc_11cbytesparse_1c_collapse_blocks}; static PyObject *__pyx_pw_11cbytesparse_1c_1collapse_blocks(PyObject *__pyx_self, PyObject *__pyx_v_blocks) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("collapse_blocks (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_collapse_blocks(__pyx_self, ((PyObject *)__pyx_v_blocks)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_collapse_blocks(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_blocks) { Memory_ *__pyx_v_memory; PyObject *__pyx_v_collapsed = 0; PyObject *__pyx_v_block_start = NULL; PyObject *__pyx_v_block_data = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("collapse_blocks", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("cbytesparse.c.collapse_blocks", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_collapsed); __Pyx_XDECREF(__pyx_v_block_start); __Pyx_XDECREF(__pyx_v_block_data); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__61 = PyTuple_Pack(5, __pyx_n_s_blocks, __pyx_n_s_memory, __pyx_n_s_collapsed, __pyx_n_s_block_start, __pyx_n_s_block_data); if (unlikely(!__pyx_tuple__61)) __PYX_ERR(0, 69, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__61); __Pyx_GIVEREF(__pyx_tuple__61); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 69, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_1collapse_blocks, 0, __pyx_n_s_collapse_blocks, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__62)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 69, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_d, __pyx_n_s_collapse_blocks, __pyx_t_2) < 0) __PYX_ERR(0, 69, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_codeobj__62 = (PyObject*)__Pyx_PyCode_New(1, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__61, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_collapse_blocks, 69, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__62)) __PYX_ERR(0, 69, __pyx_L1_error)
+0070: blocks: BlockIterable,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_BlockIterable); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 70, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_blocks, __pyx_t_2) < 0) __PYX_ERR(0, 69, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0071: ) -> BlockList:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_BlockList); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 71, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_t_2) < 0) __PYX_ERR(0, 69, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
0072: r"""Collapses a generic sequence of blocks.
0073:
0074: Given a generic sequence of blocks, writes them in the same order,
0075: generating a new sequence of non-contiguous blocks, sorted by address.
0076:
0077: Arguments:
0078: blocks (sequence of blocks):
0079: Sequence of blocks to collapse.
0080:
0081: Returns:
0082: list of blocks: Collapsed block list.
0083:
0084: Examples:
0085: +---+---+---+---+---+---+---+---+---+---+
0086: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
0087: +===+===+===+===+===+===+===+===+===+===+
0088: |[0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9]|
0089: +---+---+---+---+---+---+---+---+---+---+
0090: |[A | B | C | D]| | | | | | |
0091: +---+---+---+---+---+---+---+---+---+---+
0092: | | | |[E | F]| | | | | |
0093: +---+---+---+---+---+---+---+---+---+---+
0094: |[$]| | | | | | | | | |
0095: +---+---+---+---+---+---+---+---+---+---+
0096: | | | | | | |[x | y | z]| |
0097: +---+---+---+---+---+---+---+---+---+---+
0098: |[$ | B | C | E | F | 5 | x | y | z | 9]|
0099: +---+---+---+---+---+---+---+---+---+---+
0100:
0101: >>> blocks = [
0102: ... [0, b'0123456789'],
0103: ... [0, b'ABCD'],
0104: ... [3, b'EF'],
0105: ... [0, b'$'],
0106: ... [6, b'xyz'],
0107: ... ]
0108: >>> collapse_blocks(blocks)
0109: [[0, b'$BCEF5xyz9']]
0110:
0111: ~~~
0112:
0113: +---+---+---+---+---+---+---+---+---+---+
0114: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
0115: +===+===+===+===+===+===+===+===+===+===+
0116: |[0 | 1 | 2]| | | | | | | |
0117: +---+---+---+---+---+---+---+---+---+---+
0118: | | | | |[A | B]| | | | |
0119: +---+---+---+---+---+---+---+---+---+---+
0120: | | | | | | |[x | y | z]| |
0121: +---+---+---+---+---+---+---+---+---+---+
0122: | |[$]| | | | | | | | |
0123: +---+---+---+---+---+---+---+---+---+---+
0124: |[0 | $ | 2]| |[A | B | x | y | z]| |
0125: +---+---+---+---+---+---+---+---+---+---+
0126:
0127: >>> blocks = [
0128: ... [0, b'012'],
0129: ... [4, b'AB'],
0130: ... [6, b'xyz'],
0131: ... [1, b'$'],
0132: ... ]
0133: >>> collapse_blocks(blocks)
0134: [[0, b'0$2'], [4, b'ABxyz']]
0135: """
0136:
0137: cdef:
+0138: Memory_* memory = Memory_Alloc()
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Alloc(); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 138, __pyx_L1_error)
__pyx_v_memory = __pyx_t_1;
+0139: list collapsed = None
__Pyx_INCREF(Py_None);
__pyx_v_collapsed = ((PyObject*)Py_None);
0140:
+0141: try:
/*try:*/ {
+0142: for block_start, block_data in blocks:
if (likely(PyList_CheckExact(__pyx_v_blocks)) || PyTuple_CheckExact(__pyx_v_blocks)) { __pyx_t_2 = __pyx_v_blocks; __Pyx_INCREF(__pyx_t_2); __pyx_t_3 = 0; __pyx_t_4 = NULL; } else { __pyx_t_3 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_v_blocks); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 142, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = Py_TYPE(__pyx_t_2)->tp_iternext; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 142, __pyx_L4_error) } for (;;) { if (likely(!__pyx_t_4)) { if (likely(PyList_CheckExact(__pyx_t_2))) { if (__pyx_t_3 >= PyList_GET_SIZE(__pyx_t_2)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_3); __Pyx_INCREF(__pyx_t_5); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(0, 142, __pyx_L4_error) #else __pyx_t_5 = PySequence_ITEM(__pyx_t_2, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 142, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_5); #endif } else { if (__pyx_t_3 >= PyTuple_GET_SIZE(__pyx_t_2)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_3); __Pyx_INCREF(__pyx_t_5); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(0, 142, __pyx_L4_error) #else __pyx_t_5 = PySequence_ITEM(__pyx_t_2, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 142, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_5); #endif } } else { __pyx_t_5 = __pyx_t_4(__pyx_t_2); if (unlikely(!__pyx_t_5)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); else __PYX_ERR(0, 142, __pyx_L4_error) } break; } __Pyx_GOTREF(__pyx_t_5); } if ((likely(PyTuple_CheckExact(__pyx_t_5))) || (PyList_CheckExact(__pyx_t_5))) { PyObject* sequence = __pyx_t_5; Py_ssize_t size = __Pyx_PySequence_SIZE(sequence); if (unlikely(size != 2)) { if (size > 2) __Pyx_RaiseTooManyValuesError(2); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); __PYX_ERR(0, 142, __pyx_L4_error) } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS if (likely(PyTuple_CheckExact(sequence))) { __pyx_t_6 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_7 = PyTuple_GET_ITEM(sequence, 1); } else { __pyx_t_6 = PyList_GET_ITEM(sequence, 0); __pyx_t_7 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_6); __Pyx_INCREF(__pyx_t_7); #else __pyx_t_6 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 142, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 142, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_7); #endif __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; } else { Py_ssize_t index = -1; __pyx_t_8 = PyObject_GetIter(__pyx_t_5); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 142, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_9 = Py_TYPE(__pyx_t_8)->tp_iternext; index = 0; __pyx_t_6 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_6)) goto __pyx_L8_unpacking_failed; __Pyx_GOTREF(__pyx_t_6); index = 1; __pyx_t_7 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_7)) goto __pyx_L8_unpacking_failed; __Pyx_GOTREF(__pyx_t_7); if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 2) < 0) __PYX_ERR(0, 142, __pyx_L4_error) __pyx_t_9 = NULL; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L9_unpacking_done; __pyx_L8_unpacking_failed:; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); __PYX_ERR(0, 142, __pyx_L4_error) __pyx_L9_unpacking_done:; } __Pyx_XDECREF_SET(__pyx_v_block_start, __pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF_SET(__pyx_v_block_data, __pyx_t_7); __pyx_t_7 = 0; /* … */ } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0143: Memory_Write(memory, block_start, block_data, True)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_Memory_Write(__pyx_v_memory, __pyx_v_block_start, __pyx_v_block_data, 1); if (unlikely(__pyx_t_10 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 143, __pyx_L4_error)
0144:
+0145: collapsed = Memory_ToBlocks(memory)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_ToBlocks(__pyx_v_memory); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 145, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF_SET(__pyx_v_collapsed, ((PyObject*)__pyx_t_2)); __pyx_t_2 = 0; }
0146: finally:
+0147: Memory_Free(memory)
/*finally:*/ { /*normal exit:*/{ __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 147, __pyx_L1_error) goto __pyx_L5; } __pyx_L4_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_17, &__pyx_t_18, &__pyx_t_19); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16) < 0)) __Pyx_ErrFetch(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_15); __Pyx_XGOTREF(__pyx_t_16); __Pyx_XGOTREF(__pyx_t_17); __Pyx_XGOTREF(__pyx_t_18); __Pyx_XGOTREF(__pyx_t_19); __pyx_t_11 = __pyx_lineno; __pyx_t_12 = __pyx_clineno; __pyx_t_13 = __pyx_filename; { __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 147, __pyx_L11_error) } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_XGIVEREF(__pyx_t_19); __Pyx_ExceptionReset(__pyx_t_17, __pyx_t_18, __pyx_t_19); } __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_ErrRestore(__pyx_t_14, __pyx_t_15, __pyx_t_16); __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; __pyx_lineno = __pyx_t_11; __pyx_clineno = __pyx_t_12; __pyx_filename = __pyx_t_13; goto __pyx_L1_error; __pyx_L11_error:; if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_XGIVEREF(__pyx_t_19); __Pyx_ExceptionReset(__pyx_t_17, __pyx_t_18, __pyx_t_19); } __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; goto __pyx_L1_error; } __pyx_L5:; }
0148:
+0149: return collapsed
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_collapsed); __pyx_r = __pyx_v_collapsed; goto __pyx_L0;
0150:
0151:
0152: # =====================================================================================================================
0153:
0154: # FIXME: Not yet provided by the current Cython (0.29.x)
+0155: cdef void* PyMem_Calloc(size_t nelem, size_t elsize):
static void *__pyx_f_11cbytesparse_1c_PyMem_Calloc(size_t __pyx_v_nelem, size_t __pyx_v_elsize) { void *__pyx_v_ptr; size_t __pyx_v_total; void *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("PyMem_Calloc", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
0156: cdef:
0157: void* ptr
0158: size_t total
0159:
+0160: if CannotMulSizeU(nelem, elsize):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotMulSizeU(__pyx_v_nelem, __pyx_v_elsize) != 0); if (__pyx_t_1) { /* … */ }
+0161: return NULL # overflow
__pyx_r = NULL; goto __pyx_L0;
+0162: total = nelem * elsize
__pyx_v_total = (__pyx_v_nelem * __pyx_v_elsize);
0163:
+0164: ptr = PyMem_Malloc(total)
__pyx_v_ptr = PyMem_Malloc(__pyx_v_total);
+0165: if ptr:
__pyx_t_1 = (__pyx_v_ptr != 0); if (__pyx_t_1) { /* … */ }
+0166: memset(ptr, 0, total)
(void)(memset(__pyx_v_ptr, 0, __pyx_v_total));
+0167: return ptr
__pyx_r = __pyx_v_ptr; goto __pyx_L0;
0168:
0169:
0170: # =====================================================================================================================
0171:
+0172: cdef size_t Downsize(size_t allocated, size_t requested) nogil:
static size_t __pyx_f_11cbytesparse_1c_Downsize(size_t __pyx_v_allocated, size_t __pyx_v_requested) { size_t __pyx_v_resized; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0173: # Note: free margin will be either before and after allocated data
0174: cdef size_t resized
0175:
+0176: if requested < allocated >> 1:
__pyx_t_1 = ((__pyx_v_requested < (__pyx_v_allocated >> 1)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
0177: # Major downsize; allocate as per request
+0178: resized = requested
__pyx_v_resized = __pyx_v_requested;
0179:
0180: # Align to next MARGIN; always gives some additional MARGIN
0181: with cython.cdivision(True):
+0182: resized += (2 * MARGIN) - (resized % MARGIN)
__pyx_v_resized = (__pyx_v_resized + ((2 * MARGIN) - (__pyx_v_resized % MARGIN)));
0183: else:
0184: # Do not require reallocation
+0185: resized = allocated
/*else*/ { __pyx_v_resized = __pyx_v_allocated;
0186:
0187: # Align to next MARGIN; always gives some additional MARGIN
+0188: if resized < 2 * MARGIN:
__pyx_t_1 = ((__pyx_v_resized < (2 * MARGIN)) != 0); if (__pyx_t_1) { /* … */ } } __pyx_L3:;
+0189: resized = 2 * MARGIN
__pyx_v_resized = (2 * MARGIN);
0190:
+0191: return resized
__pyx_r = __pyx_v_resized; goto __pyx_L0;
0192:
0193:
+0194: cdef size_t Upsize(size_t allocated, size_t requested) nogil:
static size_t __pyx_f_11cbytesparse_1c_Upsize(size_t __pyx_v_allocated, size_t __pyx_v_requested) { size_t __pyx_v_resized; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0195: # Note: free margin will be either before and after allocated data
+0196: cdef size_t resized = requested
__pyx_v_resized = __pyx_v_requested;
0197:
0198: # Moderate upsize; overallocate proportionally
+0199: if resized <= allocated + (allocated >> 3):
__pyx_t_1 = ((__pyx_v_resized <= (__pyx_v_allocated + (__pyx_v_allocated >> 3))) != 0); if (__pyx_t_1) { /* … */ }
+0200: resized += resized >> 3
__pyx_v_resized = (__pyx_v_resized + (__pyx_v_resized >> 3));
0201:
0202: # Align to next MARGIN; always gives some additional MARGIN
0203: with cython.cdivision(True):
+0204: resized += (2 * MARGIN) - (resized % MARGIN)
__pyx_v_resized = (__pyx_v_resized + ((2 * MARGIN) - (__pyx_v_resized % MARGIN)));
+0205: return resized
__pyx_r = __pyx_v_resized; goto __pyx_L0;
0206:
0207:
0208: # ---------------------------------------------------------------------------------------------------------------------
0209:
+0210: cdef void Reverse(byte_t* buffer, size_t start, size_t endin) nogil:
static void __pyx_f_11cbytesparse_1c_Reverse(byte_t *__pyx_v_buffer, size_t __pyx_v_start, size_t __pyx_v_endin) { byte_t __pyx_v_t; /* … */ /* function exit code */ }
0211: cdef:
0212: byte_t t
0213:
+0214: while start < endin:
while (1) { __pyx_t_1 = ((__pyx_v_start < __pyx_v_endin) != 0); if (!__pyx_t_1) break;
+0215: t = buffer[start]
__pyx_v_t = (__pyx_v_buffer[__pyx_v_start]);
+0216: buffer[start] = buffer[endin]
(__pyx_v_buffer[__pyx_v_start]) = (__pyx_v_buffer[__pyx_v_endin]);
+0217: buffer[endin] = t
(__pyx_v_buffer[__pyx_v_endin]) = __pyx_v_t;
+0218: start += 1
__pyx_v_start = (__pyx_v_start + 1);
+0219: endin -= 1
__pyx_v_endin = (__pyx_v_endin - 1); }
0220:
0221:
+0222: cdef bint IsSequence(object obj) except -1:
static int __pyx_f_11cbytesparse_1c_IsSequence(PyObject *__pyx_v_obj) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("IsSequence", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("cbytesparse.c.IsSequence", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0223: try:
{ /*try:*/ { /* … */ } __pyx_L3_error:; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L1_error; __pyx_L7_try_return:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L0; __pyx_L6_except_return:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L0; }
+0224: len(obj)
__pyx_t_4 = PyObject_Length(__pyx_v_obj); if (unlikely(__pyx_t_4 == ((Py_ssize_t)-1))) __PYX_ERR(0, 224, __pyx_L3_error)
+0225: obj[0:0]
__pyx_t_5 = __Pyx_PyObject_GetSlice(__pyx_v_obj, 0, 0, NULL, NULL, &__pyx_slice_, 1, 1, 1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 225, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; /* … */ __pyx_slice_ = PySlice_New(__pyx_int_0, __pyx_int_0, Py_None); if (unlikely(!__pyx_slice_)) __PYX_ERR(0, 225, __pyx_L1_error) __Pyx_GOTREF(__pyx_slice_); __Pyx_GIVEREF(__pyx_slice_);
+0226: return True
__pyx_r = 1; goto __pyx_L7_try_return;
+0227: except TypeError:
__pyx_t_6 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError); if (__pyx_t_6) { __Pyx_AddTraceback("cbytesparse.c.IsSequence", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_7, &__pyx_t_8) < 0) __PYX_ERR(0, 227, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GOTREF(__pyx_t_7); __Pyx_GOTREF(__pyx_t_8);
+0228: return False
__pyx_r = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L6_except_return; } goto __pyx_L5_except_error; __pyx_L5_except_error:;
0229:
0230:
0231: # =====================================================================================================================
0232:
+0233: cdef bint CannotAddSizeU(size_t a, size_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotAddSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0234: return SIZE_MAX - a < b
__pyx_r = ((SIZE_MAX - __pyx_v_a) < __pyx_v_b); goto __pyx_L0;
0235:
0236:
+0237: cdef vint CheckAddSizeU(size_t a, size_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckAddSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckAddSizeU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckAddSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0238: if CannotAddSizeU(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0239: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 239, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 239, __pyx_L1_error)
0240:
0241:
+0242: cdef size_t AddSizeU(size_t a, size_t b) except? 0xDEAD:
static size_t __pyx_f_11cbytesparse_1c_AddSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { size_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("AddSizeU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.AddSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0243: CheckAddSizeU(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 243, __pyx_L1_error)
+0244: return a + b
__pyx_r = (__pyx_v_a + __pyx_v_b); goto __pyx_L0;
0245:
0246:
+0247: cdef bint CannotSubSizeU(size_t a, size_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotSubSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0248: return a < b
__pyx_r = (__pyx_v_a < __pyx_v_b); goto __pyx_L0;
0249:
0250:
+0251: cdef vint CheckSubSizeU(size_t a, size_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckSubSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckSubSizeU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckSubSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0252: if CannotSubSizeU(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotSubSizeU(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0253: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 253, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 253, __pyx_L1_error)
0254:
0255:
+0256: cdef size_t SubSizeU(size_t a, size_t b) except? 0xDEAD:
static size_t __pyx_f_11cbytesparse_1c_SubSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { size_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("SubSizeU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.SubSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0257: CheckSubSizeU(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckSubSizeU(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 257, __pyx_L1_error)
+0258: return a - b
__pyx_r = (__pyx_v_a - __pyx_v_b); goto __pyx_L0;
0259:
0260:
+0261: cdef bint CannotMulSizeU(size_t a, size_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotMulSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { size_t __pyx_v_r; int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0262: cdef:
+0263: size_t r = a * b
__pyx_v_r = (__pyx_v_a * __pyx_v_b);
+0264: return a and b and (r < a or r < b)
__pyx_t_2 = (__pyx_v_a != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = (__pyx_v_b != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_r < __pyx_v_a) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_r < __pyx_v_b) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0265:
0266:
+0267: cdef vint CheckMulSizeU(size_t a, size_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckMulSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckMulSizeU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckMulSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0268: if CannotMulSizeU(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotMulSizeU(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0269: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 269, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 269, __pyx_L1_error)
0270:
0271:
+0272: cdef size_t MulSizeU(size_t a, size_t b) except? 0xDEAD:
static size_t __pyx_f_11cbytesparse_1c_MulSizeU(size_t __pyx_v_a, size_t __pyx_v_b) { size_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("MulSizeU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.MulSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0273: CheckMulSizeU(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckMulSizeU(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 273, __pyx_L1_error)
+0274: return a * b
__pyx_r = (__pyx_v_a * __pyx_v_b); goto __pyx_L0;
0275:
0276:
0277: # ---------------------------------------------------------------------------------------------------------------------
0278:
+0279: cdef bint CannotAddSizeS(ssize_t a, ssize_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotAddSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0280: return ((b > 0 and a > SSIZE_MAX - b) or
__pyx_t_2 = ((__pyx_v_b > 0) != 0); if (!__pyx_t_2) { goto __pyx_L4_next_or; } else { } __pyx_t_2 = ((__pyx_v_a > (SSIZE_MAX - __pyx_v_b)) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_L4_next_or:;
+0281: (b < 0 and a < SSIZE_MIN - b))
__pyx_t_2 = ((__pyx_v_b < 0) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_a < (SSIZE_MIN - __pyx_v_b)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0282:
0283:
+0284: cdef vint CheckAddSizeS(ssize_t a, ssize_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckAddSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckAddSizeS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckAddSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0285: if CannotAddSizeS(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddSizeS(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0286: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 286, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 286, __pyx_L1_error)
0287:
0288:
+0289: cdef ssize_t AddSizeS(ssize_t a, ssize_t b) except? 0xDEAD:
static Py_ssize_t __pyx_f_11cbytesparse_1c_AddSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("AddSizeS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.AddSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0290: CheckAddSizeS(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeS(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 290, __pyx_L1_error)
+0291: return a + b
__pyx_r = (__pyx_v_a + __pyx_v_b); goto __pyx_L0;
0292:
0293:
+0294: cdef bint CannotSubSizeS(ssize_t a, ssize_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotSubSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0295: return ((b > 0 and a < SSIZE_MIN + b) or
__pyx_t_2 = ((__pyx_v_b > 0) != 0); if (!__pyx_t_2) { goto __pyx_L4_next_or; } else { } __pyx_t_2 = ((__pyx_v_a < (SSIZE_MIN + __pyx_v_b)) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_L4_next_or:;
+0296: (b < 0 and a > SSIZE_MAX + b))
__pyx_t_2 = ((__pyx_v_b < 0) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_a > (SSIZE_MAX + __pyx_v_b)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0297:
0298:
+0299: cdef vint CheckSubSizeS(ssize_t a, ssize_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckSubSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckSubSizeS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckSubSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0300: if CannotSubSizeS(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotSubSizeS(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0301: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 301, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 301, __pyx_L1_error)
0302:
0303:
+0304: cdef ssize_t SubSizeS(ssize_t a, ssize_t b) except? 0xDEAD:
static Py_ssize_t __pyx_f_11cbytesparse_1c_SubSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("SubSizeS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.SubSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0305: CheckSubSizeS(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckSubSizeS(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 305, __pyx_L1_error)
+0306: return a - b
__pyx_r = (__pyx_v_a - __pyx_v_b); goto __pyx_L0;
0307:
0308:
+0309: cdef bint CannotMulSizeS(ssize_t a, ssize_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotMulSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0310: with cython.cdivision(True):
+0311: if a > 0:
__pyx_t_1 = ((__pyx_v_a > 0) != 0); if (__pyx_t_1) { /* … */ }
+0312: if b > 0:
__pyx_t_1 = ((__pyx_v_b > 0) != 0); if (__pyx_t_1) { /* … */ }
+0313: return a > (SSIZE_MAX // b)
__pyx_r = (__pyx_v_a > (SSIZE_MAX / __pyx_v_b)); goto __pyx_L0;
0314: else:
+0315: return b < (SSIZE_MIN // a)
/*else*/ { __pyx_r = (__pyx_v_b < (SSIZE_MIN / __pyx_v_a)); goto __pyx_L0; }
0316: else:
+0317: if b > 0:
/*else*/ { __pyx_t_1 = ((__pyx_v_b > 0) != 0); if (__pyx_t_1) { /* … */ }
+0318: return a < (SSIZE_MIN // b)
__pyx_r = (__pyx_v_a < (SSIZE_MIN / __pyx_v_b)); goto __pyx_L0;
0319: else:
+0320: return a and b < (SSIZE_MAX // a)
/*else*/ { __pyx_t_2 = (__pyx_v_a != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L6_bool_binop_done; } __pyx_t_2 = ((__pyx_v_b < (SSIZE_MAX / __pyx_v_a)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L6_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0; } }
0321:
0322:
+0323: cdef vint CheckMulSizeS(ssize_t a, ssize_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckMulSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckMulSizeS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckMulSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0324: if CannotMulSizeS(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotMulSizeS(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0325: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 325, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 325, __pyx_L1_error)
0326:
0327:
+0328: cdef ssize_t MulSizeS(ssize_t a, ssize_t b) except? 0xDEAD:
static Py_ssize_t __pyx_f_11cbytesparse_1c_MulSizeS(Py_ssize_t __pyx_v_a, Py_ssize_t __pyx_v_b) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("MulSizeS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.MulSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0329: CheckMulSizeS(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckMulSizeS(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 329, __pyx_L1_error)
+0330: return a * b
__pyx_r = (__pyx_v_a * __pyx_v_b); goto __pyx_L0;
0331:
0332:
0333: # =====================================================================================================================
0334:
+0335: cdef bint CannotAddAddrU(addr_t a, addr_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotAddAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0336: return ADDR_MAX - a < b
__pyx_r = ((ADDR_MAX - __pyx_v_a) < __pyx_v_b); goto __pyx_L0;
0337:
0338:
+0339: cdef vint CheckAddAddrU(addr_t a, addr_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckAddAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckAddAddrU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckAddAddrU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0340: if CannotAddAddrU(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddAddrU(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0341: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 341, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 341, __pyx_L1_error)
0342:
0343:
+0344: cdef addr_t AddAddrU(addr_t a, addr_t b) except? 0xDEAD:
static addr_t __pyx_f_11cbytesparse_1c_AddAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("AddAddrU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.AddAddrU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0345: CheckAddAddrU(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 345, __pyx_L1_error)
+0346: return a + b
__pyx_r = (__pyx_v_a + __pyx_v_b); goto __pyx_L0;
0347:
0348:
+0349: cdef bint CannotSubAddrU(addr_t a, addr_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotSubAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0350: return a < b
__pyx_r = (__pyx_v_a < __pyx_v_b); goto __pyx_L0;
0351:
0352:
+0353: cdef vint CheckSubAddrU(addr_t a, addr_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckSubAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckSubAddrU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckSubAddrU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0354: if CannotSubAddrU(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotSubAddrU(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0355: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 355, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 355, __pyx_L1_error)
0356:
0357:
+0358: cdef addr_t SubAddrU(addr_t a, addr_t b) except? 0xDEAD:
static addr_t __pyx_f_11cbytesparse_1c_SubAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("SubAddrU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.SubAddrU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0359: CheckSubAddrU(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 359, __pyx_L1_error)
+0360: return a - b
__pyx_r = (__pyx_v_a - __pyx_v_b); goto __pyx_L0;
0361:
0362:
+0363: cdef bint CannotMulAddrU(addr_t a, addr_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotMulAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { addr_t __pyx_v_r; int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0364: cdef:
+0365: addr_t r = a * b
__pyx_v_r = (__pyx_v_a * __pyx_v_b);
+0366: return a and b and (r < a or r < b)
__pyx_t_2 = (__pyx_v_a != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = (__pyx_v_b != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_r < __pyx_v_a) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_r < __pyx_v_b) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0367:
0368:
+0369: cdef vint CheckMulAddrU(addr_t a, addr_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckMulAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckMulAddrU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckMulAddrU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0370: if CannotMulAddrU(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotMulAddrU(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0371: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 371, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 371, __pyx_L1_error)
0372:
0373:
+0374: cdef addr_t MulAddrU(addr_t a, addr_t b) except? 0xDEAD:
static addr_t __pyx_f_11cbytesparse_1c_MulAddrU(addr_t __pyx_v_a, addr_t __pyx_v_b) { addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("MulAddrU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.MulAddrU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0375: CheckMulAddrU(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckMulAddrU(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 375, __pyx_L1_error)
+0376: return a * b
__pyx_r = (__pyx_v_a * __pyx_v_b); goto __pyx_L0;
0377:
0378:
+0379: cdef bint CannotAddrToSizeU(addr_t a) nogil:
static int __pyx_f_11cbytesparse_1c_CannotAddrToSizeU(addr_t __pyx_v_a) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0380: return a > <addr_t>SIZE_MAX
__pyx_r = (__pyx_v_a > ((addr_t)SIZE_MAX)); goto __pyx_L0;
0381:
0382:
+0383: cdef vint CheckAddrToSizeU(addr_t a) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(addr_t __pyx_v_a) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckAddrToSizeU", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckAddrToSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0384: if CannotAddrToSizeU(a):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddrToSizeU(__pyx_v_a) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0385: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 385, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 385, __pyx_L1_error)
0386:
0387:
+0388: cdef size_t AddrToSizeU(addr_t a) except? 0xDEAD:
static size_t __pyx_f_11cbytesparse_1c_AddrToSizeU(addr_t __pyx_v_a) { size_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("AddrToSizeU", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.AddrToSizeU", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0389: CheckAddrToSizeU(a)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_a); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 389, __pyx_L1_error)
+0390: return <size_t>a
__pyx_r = ((size_t)__pyx_v_a); goto __pyx_L0;
0391:
0392:
0393: # ---------------------------------------------------------------------------------------------------------------------
0394:
+0395: cdef bint CannotAddAddrS(saddr_t a, saddr_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotAddAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0396: return ((b > 0 and a > SADDR_MAX - b) or
__pyx_t_2 = ((__pyx_v_b > 0) != 0); if (!__pyx_t_2) { goto __pyx_L4_next_or; } else { } __pyx_t_2 = ((__pyx_v_a > (SADDR_MAX - __pyx_v_b)) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_L4_next_or:;
+0397: (b < 0 and a < SADDR_MIN - b))
__pyx_t_2 = ((__pyx_v_b < 0) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_a < (SADDR_MIN - __pyx_v_b)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0398:
0399:
+0400: cdef vint CheckAddAddrS(saddr_t a, saddr_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckAddAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckAddAddrS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckAddAddrS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0401: if CannotAddAddrS(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddAddrS(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0402: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 402, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 402, __pyx_L1_error)
0403:
0404:
+0405: cdef saddr_t AddAddrS(saddr_t a, saddr_t b) except? 0xDEAD:
static saddr_t __pyx_f_11cbytesparse_1c_AddAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { saddr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("AddAddrS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.AddAddrS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0406: CheckAddAddrS(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddAddrS(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 406, __pyx_L1_error)
+0407: return a + b
__pyx_r = (__pyx_v_a + __pyx_v_b); goto __pyx_L0;
0408:
0409:
+0410: cdef bint CannotSubAddrS(saddr_t a, saddr_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotSubAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0411: return ((b > 0 and a < SADDR_MIN + b) or
__pyx_t_2 = ((__pyx_v_b > 0) != 0); if (!__pyx_t_2) { goto __pyx_L4_next_or; } else { } __pyx_t_2 = ((__pyx_v_a < (SADDR_MIN + __pyx_v_b)) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_L4_next_or:;
+0412: (b < 0 and a > SADDR_MAX + b))
__pyx_t_2 = ((__pyx_v_b < 0) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_a > (SADDR_MAX + __pyx_v_b)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0413:
0414:
+0415: cdef vint CheckSubAddrS(saddr_t a, saddr_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckSubAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckSubAddrS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckSubAddrS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0416: if CannotSubAddrS(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotSubAddrS(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0417: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 417, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 417, __pyx_L1_error)
0418:
0419:
+0420: cdef saddr_t SubAddrS(saddr_t a, saddr_t b) except? 0xDEAD:
static saddr_t __pyx_f_11cbytesparse_1c_SubAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { saddr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("SubAddrS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.SubAddrS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0421: CheckSubAddrS(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckSubAddrS(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 421, __pyx_L1_error)
+0422: return a - b
__pyx_r = (__pyx_v_a - __pyx_v_b); goto __pyx_L0;
0423:
0424:
+0425: cdef bint CannotMulAddrS(saddr_t a, saddr_t b) nogil:
static int __pyx_f_11cbytesparse_1c_CannotMulAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0426: with cython.cdivision(True):
+0427: if a > 0:
__pyx_t_1 = ((__pyx_v_a > 0) != 0); if (__pyx_t_1) { /* … */ }
+0428: if b > 0:
__pyx_t_1 = ((__pyx_v_b > 0) != 0); if (__pyx_t_1) { /* … */ }
+0429: return a > (SADDR_MAX // b)
__pyx_r = (__pyx_v_a > (SADDR_MAX / __pyx_v_b)); goto __pyx_L0;
0430: else:
+0431: return b < (SADDR_MIN // a)
/*else*/ { __pyx_r = (__pyx_v_b < (SADDR_MIN / __pyx_v_a)); goto __pyx_L0; }
0432: else:
+0433: if b > 0:
/*else*/ { __pyx_t_1 = ((__pyx_v_b > 0) != 0); if (__pyx_t_1) { /* … */ }
+0434: return a < (SADDR_MIN // b)
__pyx_r = (__pyx_v_a < (SADDR_MIN / __pyx_v_b)); goto __pyx_L0;
0435: else:
+0436: return a and b < (SADDR_MAX // a)
/*else*/ { __pyx_t_2 = (__pyx_v_a != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L6_bool_binop_done; } __pyx_t_2 = ((__pyx_v_b < (SADDR_MAX / __pyx_v_a)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L6_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0; } }
0437:
0438:
+0439: cdef vint CheckMulAddrS(saddr_t a, saddr_t b) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckMulAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckMulAddrS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckMulAddrS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0440: if CannotMulAddrS(a, b):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotMulAddrS(__pyx_v_a, __pyx_v_b) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0441: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 441, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 441, __pyx_L1_error)
0442:
0443:
+0444: cdef saddr_t MulAddrS(saddr_t a, saddr_t b) except? 0xDEAD:
static saddr_t __pyx_f_11cbytesparse_1c_MulAddrS(saddr_t __pyx_v_a, saddr_t __pyx_v_b) { saddr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("MulAddrS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.MulAddrS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0445: CheckMulAddrS(a, b)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckMulAddrS(__pyx_v_a, __pyx_v_b); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 445, __pyx_L1_error)
+0446: return a * b
__pyx_r = (__pyx_v_a * __pyx_v_b); goto __pyx_L0;
0447:
0448:
+0449: cdef bint CannotAddrToSizeS(saddr_t a) nogil:
static int __pyx_f_11cbytesparse_1c_CannotAddrToSizeS(saddr_t __pyx_v_a) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0450: return a < <saddr_t>SSIZE_MIN or a > <saddr_t>SSIZE_MAX
__pyx_t_2 = ((__pyx_v_a < ((saddr_t)SSIZE_MIN)) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L3_bool_binop_done; } __pyx_t_2 = ((__pyx_v_a > ((saddr_t)SSIZE_MAX)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L3_bool_binop_done:; __pyx_r = __pyx_t_1; goto __pyx_L0;
0451:
0452:
+0453: cdef vint CheckAddrToSizeS(saddr_t a) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_CheckAddrToSizeS(saddr_t __pyx_v_a) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("CheckAddrToSizeS", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.CheckAddrToSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0454: if CannotAddrToSizeS(a):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddrToSizeS(__pyx_v_a) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0455: raise OverflowError()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 455, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 455, __pyx_L1_error)
0456:
0457:
+0458: cdef ssize_t AddrToSizeS(saddr_t a) except? 0xDEAD:
static Py_ssize_t __pyx_f_11cbytesparse_1c_AddrToSizeS(saddr_t __pyx_v_a) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("AddrToSizeS", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.AddrToSizeS", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0xDEAD; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0459: CheckAddrToSizeS(a)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeS(__pyx_v_a); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 459, __pyx_L1_error)
+0460: return <ssize_t>a
__pyx_r = ((Py_ssize_t)__pyx_v_a); goto __pyx_L0;
0461:
0462:
0463: # =====================================================================================================================
0464:
+0465: cdef Block_* Block_Alloc(addr_t address, size_t size, bint zero) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Alloc(addr_t __pyx_v_address, size_t __pyx_v_size, int __pyx_v_zero) { Block_ *__pyx_v_that; size_t __pyx_v_allocated; size_t __pyx_v_actual; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Alloc", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Alloc", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
0466: cdef:
+0467: Block_* that = NULL
__pyx_v_that = NULL;
0468: size_t allocated
0469: size_t actual
0470:
+0471: if size > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_size > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0472: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 472, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 472, __pyx_L1_error) /* … */ __pyx_tuple__2 = PyTuple_Pack(1, __pyx_kp_u_size_overflow); if (unlikely(!__pyx_tuple__2)) __PYX_ERR(0, 472, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__2); __Pyx_GIVEREF(__pyx_tuple__2);
0473:
0474: # Allocate as per request
+0475: allocated = Upsize(0, size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Upsize(0, __pyx_v_size);
+0476: if allocated > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0477: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 477, __pyx_L1_error)
0478:
+0479: actual = Block_HEADING + (allocated * sizeof(byte_t))
__pyx_v_actual = (Block_HEADING + (__pyx_v_allocated * (sizeof(byte_t))));
+0480: if zero:
__pyx_t_1 = (__pyx_v_zero != 0); if (__pyx_t_1) { /* … */ goto __pyx_L5; }
+0481: that = <Block_*>PyMem_Calloc(actual, 1)
__pyx_v_that = ((Block_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(__pyx_v_actual, 1));
0482: else:
+0483: that = <Block_*>PyMem_Malloc(actual)
/*else*/ {
__pyx_v_that = ((Block_ *)PyMem_Malloc(__pyx_v_actual));
}
__pyx_L5:;
+0484: if that == NULL:
__pyx_t_1 = ((__pyx_v_that == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0485: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 485, __pyx_L1_error)
0486:
+0487: that.address = address
__pyx_v_that->address = __pyx_v_address;
+0488: that.references = 1 # acquired by default
__pyx_v_that->references = 1;
+0489: that.allocated = allocated
__pyx_v_that->allocated = __pyx_v_allocated;
+0490: that.start = MARGIN # leave some initial room
__pyx_v_that->start = MARGIN;
+0491: that.endex = that.start + size
__pyx_v_that->endex = (__pyx_v_that->start + __pyx_v_size);
+0492: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
0493:
0494:
+0495: cdef Block_* Block_Free(Block_* that):
static Block_ *__pyx_f_11cbytesparse_1c_Block_Free(Block_ *__pyx_v_that) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Free", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0496: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (__pyx_t_1) { /* … */ }
+0497: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
+0498: return NULL
__pyx_r = NULL; goto __pyx_L0;
0499:
0500:
+0501: cdef Block_* Block_Create(addr_t address, size_t size, const byte_t* buffer) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Create(addr_t __pyx_v_address, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Block_ *__pyx_v_that; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Create", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Block_Create", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0502: if not size or buffer:
__pyx_t_2 = ((!(__pyx_v_size != 0)) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L4_bool_binop_done; } __pyx_t_2 = (__pyx_v_buffer != 0); __pyx_t_1 = __pyx_t_2; __pyx_L4_bool_binop_done:; if (likely(__pyx_t_1)) { /* … */ }
+0503: that = Block_Alloc(address, size, False)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Alloc(__pyx_v_address, __pyx_v_size, 0); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 503, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+0504: memcpy(&that.data[that.start], buffer, size * sizeof(byte_t))
(void)(memcpy((&(__pyx_v_that->data[__pyx_v_that->start])), __pyx_v_buffer, (__pyx_v_size * (sizeof(byte_t)))));
+0505: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
0506: else:
+0507: raise ValueError('null pointer')
/*else*/ { __pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__3, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 507, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 507, __pyx_L1_error) } /* … */ __pyx_tuple__3 = PyTuple_Pack(1, __pyx_kp_u_null_pointer); if (unlikely(!__pyx_tuple__3)) __PYX_ERR(0, 507, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__3); __Pyx_GIVEREF(__pyx_tuple__3);
0508:
0509:
+0510: cdef Block_* Block_Copy(const Block_* that) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Copy(Block_ const *__pyx_v_that) { Block_ *__pyx_v_ptr; size_t __pyx_v_size; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Copy", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Copy", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
0511: cdef:
0512: Block_* ptr
0513: size_t size
0514:
+0515: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (likely(__pyx_t_1)) { /* … */ }
+0516: size = Block_HEADING + (that.allocated * sizeof(byte_t))
__pyx_v_size = (Block_HEADING + (__pyx_v_that->allocated * (sizeof(byte_t))));
+0517: ptr = <Block_*>PyMem_Malloc(size)
__pyx_v_ptr = ((Block_ *)PyMem_Malloc(__pyx_v_size));
+0518: if ptr == NULL:
__pyx_t_1 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0519: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 519, __pyx_L1_error)
0520:
+0521: memcpy(ptr, that, size)
(void)(memcpy(__pyx_v_ptr, __pyx_v_that, __pyx_v_size));
+0522: ptr.references = 1 # acquired by default
__pyx_v_ptr->references = 1;
+0523: return ptr
__pyx_r = __pyx_v_ptr; goto __pyx_L0;
0524: else:
+0525: raise ValueError('null pointer')
/*else*/ { __pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__3, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 525, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 525, __pyx_L1_error) }
0526:
0527:
+0528: cdef Block_* Block_FromObject(addr_t address, object obj, bint nonnull) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_FromObject(addr_t __pyx_v_address, PyObject *__pyx_v_obj, int __pyx_v_nonnull) { byte_t __pyx_v_value; __Pyx_memviewslice __pyx_v_view = { 0, 0, { 0 }, { 0 }, { 0 } }; size_t __pyx_v_size; byte_t const *__pyx_v_ptr; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_FromObject", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_XDECREF(__pyx_t_13); __Pyx_AddTraceback("cbytesparse.c.Block_FromObject", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
0529: cdef:
0530: byte_t value
0531: const byte_t[:] view
0532: size_t size
0533: const byte_t* ptr
0534:
+0535: if isinstance(obj, int):
__pyx_t_1 = PyInt_Check(__pyx_v_obj);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
}
+0536: value = <byte_t>obj
__pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_v_obj); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 536, __pyx_L1_error) __pyx_v_value = ((byte_t)__pyx_t_3);
+0537: return Block_Create(address, 1, &value)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Create(__pyx_v_address, 1, (&__pyx_v_value)); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 537, __pyx_L1_error)
__pyx_r = __pyx_t_4;
goto __pyx_L0;
0538: else:
+0539: try:
/*else*/ { { /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L9_try_end; __pyx_L4_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); /* … */ __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ExceptionReset(__pyx_t_5, __pyx_t_6, __pyx_t_7); goto __pyx_L1_error; __pyx_L5_exception_handled:; __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ExceptionReset(__pyx_t_5, __pyx_t_6, __pyx_t_7); __pyx_L9_try_end:; }
+0540: view = obj
__pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_obj, 0); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(0, 540, __pyx_L4_error) __pyx_v_view = __pyx_t_8; __pyx_t_8.memview = NULL; __pyx_t_8.data = NULL;
+0541: except TypeError:
__pyx_t_9 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError); if (__pyx_t_9) { __Pyx_AddTraceback("cbytesparse.c.Block_FromObject", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12) < 0) __PYX_ERR(0, 541, __pyx_L6_except_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11); __Pyx_GOTREF(__pyx_t_12);
+0542: view = bytes(obj)
__pyx_t_13 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_v_obj); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 542, __pyx_L6_except_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_t_13, 0); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(0, 542, __pyx_L6_except_error) __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __pyx_v_view = __pyx_t_8; __pyx_t_8.memview = NULL; __pyx_t_8.data = NULL; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; goto __pyx_L5_exception_handled; } goto __pyx_L6_except_error; __pyx_L6_except_error:;
+0543: size = len(view)
__pyx_t_14 = __Pyx_MemoryView_Len(__pyx_v_view);
__pyx_v_size = __pyx_t_14;
+0544: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
0545: with cython.boundscheck(False):
+0546: ptr = &view[0]
__pyx_t_15 = 0; if (__pyx_t_15 < 0) __pyx_t_15 += __pyx_v_view.shape[0]; __pyx_v_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_view.data + __pyx_t_15 * __pyx_v_view.strides[0]) ))));
+0547: return Block_Create(address, size, ptr)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Create(__pyx_v_address, __pyx_v_size, __pyx_v_ptr); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 547, __pyx_L1_error)
__pyx_r = __pyx_t_4;
goto __pyx_L0;
0548: else:
+0549: if nonnull:
/*else*/ { __pyx_t_2 = (__pyx_v_nonnull != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+0550: raise ValueError('invalid block data size')
__pyx_t_12 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__4, NULL); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 550, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_Raise(__pyx_t_12, 0, 0, 0); __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; __PYX_ERR(0, 550, __pyx_L1_error) /* … */ __pyx_tuple__4 = PyTuple_Pack(1, __pyx_kp_u_invalid_block_data_size); if (unlikely(!__pyx_tuple__4)) __PYX_ERR(0, 550, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__4); __Pyx_GIVEREF(__pyx_tuple__4);
0551: else:
+0552: return Block_Alloc(address, 0, False)
/*else*/ {
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Alloc(__pyx_v_address, 0, 0); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 552, __pyx_L1_error)
__pyx_r = __pyx_t_4;
goto __pyx_L0;
}
}
}
0553:
0554:
+0555: cdef Block_* Block_Acquire(Block_* that) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Acquire(Block_ *__pyx_v_that) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Acquire", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Acquire", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0556: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (likely(__pyx_t_1)) { /* … */ }
+0557: if that.references < SIZE_MAX:
__pyx_t_1 = ((__pyx_v_that->references < SIZE_MAX) != 0); if (likely(__pyx_t_1)) { /* … */ }
+0558: that.references += 1
__pyx_v_that->references = (__pyx_v_that->references + 1);
+0559: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
0560: else:
+0561: raise OverflowError()
/*else*/ { __pyx_t_2 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 561, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 561, __pyx_L1_error) }
0562: else:
+0563: raise RuntimeError('null pointer')
/*else*/ { __pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_RuntimeError, __pyx_tuple__3, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 563, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 563, __pyx_L1_error) }
0564:
0565:
+0566: cdef Block_* Block_Release_(Block_* that):
static Block_ *__pyx_f_11cbytesparse_1c_Block_Release_(Block_ *__pyx_v_that) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Release_", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0567: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (__pyx_t_1) { /* … */ }
+0568: if that.references:
__pyx_t_1 = (__pyx_v_that->references != 0); if (__pyx_t_1) { /* … */ }
+0569: that.references -= 1
__pyx_v_that->references = (__pyx_v_that->references - 1);
0570:
+0571: if that.references:
__pyx_t_1 = (__pyx_v_that->references != 0); if (__pyx_t_1) { /* … */ }
+0572: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
0573: else:
+0574: PyMem_Free(that)
/*else*/ {
PyMem_Free(__pyx_v_that);
}
0575:
+0576: return NULL
__pyx_r = NULL; goto __pyx_L0;
0577:
0578:
+0579: cdef Block_* Block_Release(Block_* that):
static Block_ *__pyx_f_11cbytesparse_1c_Block_Release(Block_ *__pyx_v_that) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Release", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0580: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (__pyx_t_1) { /* … */ }
+0581: if that.references:
__pyx_t_1 = (__pyx_v_that->references != 0); if (__pyx_t_1) { /* … */ }
+0582: that.references -= 1
__pyx_v_that->references = (__pyx_v_that->references - 1);
0583:
+0584: if not that.references:
__pyx_t_1 = ((!(__pyx_v_that->references != 0)) != 0); if (__pyx_t_1) { /* … */ }
+0585: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
0586:
+0587: return NULL
__pyx_r = NULL; goto __pyx_L0;
0588:
0589:
+0590: cdef size_t Block_Length(const Block_* that) nogil:
static size_t __pyx_f_11cbytesparse_1c_Block_Length(Block_ const *__pyx_v_that) { size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0591: return that.endex - that.start
__pyx_r = (__pyx_v_that->endex - __pyx_v_that->start); goto __pyx_L0;
0592:
0593:
+0594: cdef addr_t Block_Start(const Block_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Block_Start(Block_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0595: return that.address
__pyx_r = __pyx_v_that->address; goto __pyx_L0;
0596:
0597:
+0598: cdef addr_t Block_Endex(const Block_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Block_Endex(Block_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0599: return that.address + (that.endex - that.start)
__pyx_r = (__pyx_v_that->address + (__pyx_v_that->endex - __pyx_v_that->start)); goto __pyx_L0;
0600:
0601:
+0602: cdef addr_t Block_Endin(const Block_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Block_Endin(Block_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0603: return that.address + (that.endex - that.start) - 1
__pyx_r = ((__pyx_v_that->address + (__pyx_v_that->endex - __pyx_v_that->start)) - 1); goto __pyx_L0;
0604:
0605:
+0606: cdef addr_t Block_BoundAddress(const Block_* that, addr_t address) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Block_BoundAddress(Block_ const *__pyx_v_that, addr_t __pyx_v_address) { addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0607: cdef:
+0608: addr_t block_start = that.address
__pyx_t_1 = __pyx_v_that->address; __pyx_v_block_start = __pyx_t_1;
+0609: addr_t block_endex = block_start + that.endex - that.start
__pyx_v_block_endex = ((__pyx_v_block_start + __pyx_v_that->endex) - __pyx_v_that->start);
0610:
+0611: if address < block_start:
__pyx_t_2 = ((__pyx_v_address < __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+0612: address = block_start # trim to start
__pyx_v_address = __pyx_v_block_start;
+0613: elif address > block_endex:
__pyx_t_2 = ((__pyx_v_address > __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } __pyx_L3:;
+0614: address = block_endex # trim to end
__pyx_v_address = __pyx_v_block_endex;
+0615: return address
__pyx_r = __pyx_v_address; goto __pyx_L0;
0616:
0617:
+0618: cdef size_t Block_BoundAddressToOffset(const Block_* that, addr_t address) nogil:
static size_t __pyx_f_11cbytesparse_1c_Block_BoundAddressToOffset(Block_ const *__pyx_v_that, addr_t __pyx_v_address) { addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0619: cdef:
+0620: addr_t block_start = that.address
__pyx_t_1 = __pyx_v_that->address; __pyx_v_block_start = __pyx_t_1;
+0621: addr_t block_endex = block_start + that.endex - that.start
__pyx_v_block_endex = ((__pyx_v_block_start + __pyx_v_that->endex) - __pyx_v_that->start);
0622:
+0623: if address < block_start:
__pyx_t_2 = ((__pyx_v_address < __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+0624: address = block_start # trim to start
__pyx_v_address = __pyx_v_block_start;
+0625: elif address > block_endex:
__pyx_t_2 = ((__pyx_v_address > __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } __pyx_L3:;
+0626: address = block_endex # trim to end
__pyx_v_address = __pyx_v_block_endex;
+0627: return <size_t>(address - block_start)
__pyx_r = ((size_t)(__pyx_v_address - __pyx_v_block_start)); goto __pyx_L0;
0628:
0629:
+0630: cdef size_t Block_BoundOffset(const Block_* that, size_t offset) nogil:
static size_t __pyx_f_11cbytesparse_1c_Block_BoundOffset(Block_ const *__pyx_v_that, size_t __pyx_v_offset) { size_t __pyx_v_size; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0631: cdef:
+0632: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
0633:
+0634: if offset > size:
__pyx_t_1 = ((__pyx_v_offset > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0635: offset = size # trim to end
__pyx_v_offset = __pyx_v_size;
+0636: return offset
__pyx_r = __pyx_v_offset; goto __pyx_L0;
0637:
0638:
+0639: cdef (addr_t, addr_t) Block_BoundAddressSlice(const Block_* that, addr_t start, addr_t endex) nogil:
static __pyx_ctuple_addr_t__and_addr_t __pyx_f_11cbytesparse_1c_Block_BoundAddressSlice(Block_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; __pyx_ctuple_addr_t__and_addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0640: cdef:
+0641: addr_t block_start = that.address
__pyx_t_1 = __pyx_v_that->address; __pyx_v_block_start = __pyx_t_1;
+0642: addr_t block_endex = block_start + (that.endex - that.start)
__pyx_v_block_endex = (__pyx_v_block_start + (__pyx_v_that->endex - __pyx_v_that->start));
0643:
+0644: if start < block_start:
__pyx_t_2 = ((__pyx_v_start < __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+0645: start = block_start # trim to start
__pyx_v_start = __pyx_v_block_start;
+0646: elif start > block_endex:
__pyx_t_2 = ((__pyx_v_start > __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } __pyx_L3:;
+0647: start = block_endex # trim to end
__pyx_v_start = __pyx_v_block_endex;
0648:
+0649: if endex < block_start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+0650: endex = block_start # trim to start
__pyx_v_endex = __pyx_v_block_start;
+0651: elif endex > block_endex:
__pyx_t_2 = ((__pyx_v_endex > __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } __pyx_L4:;
+0652: endex = block_endex # trim to end
__pyx_v_endex = __pyx_v_block_endex;
0653:
+0654: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+0655: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0656:
+0657: return start, endex
__pyx_t_3.f0 = __pyx_v_start; __pyx_t_3.f1 = __pyx_v_endex; __pyx_r = __pyx_t_3; goto __pyx_L0;
0658:
0659:
+0660: cdef (size_t, size_t) Block_BoundAddressSliceToOffset(const Block_* that, addr_t start, addr_t endex) nogil:
static __pyx_ctuple_size_t__and_size_t __pyx_f_11cbytesparse_1c_Block_BoundAddressSliceToOffset(Block_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; __pyx_ctuple_size_t__and_size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0661: cdef:
+0662: addr_t block_start = that.address
__pyx_t_1 = __pyx_v_that->address; __pyx_v_block_start = __pyx_t_1;
+0663: addr_t block_endex = block_start + (that.endex - that.start)
__pyx_v_block_endex = (__pyx_v_block_start + (__pyx_v_that->endex - __pyx_v_that->start));
0664:
+0665: if start < block_start:
__pyx_t_2 = ((__pyx_v_start < __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+0666: start = block_start # trim to start
__pyx_v_start = __pyx_v_block_start;
+0667: elif start > block_endex:
__pyx_t_2 = ((__pyx_v_start > __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } __pyx_L3:;
+0668: start = block_endex # trim to end
__pyx_v_start = __pyx_v_block_endex;
0669:
+0670: if endex < block_start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+0671: endex = block_start # trim to start
__pyx_v_endex = __pyx_v_block_start;
+0672: elif endex > block_endex:
__pyx_t_2 = ((__pyx_v_endex > __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } __pyx_L4:;
+0673: endex = block_endex # trim to end
__pyx_v_endex = __pyx_v_block_endex;
0674:
+0675: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+0676: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0677:
+0678: return <size_t>(start - block_start), <size_t>(endex - block_start)
__pyx_t_3.f0 = ((size_t)(__pyx_v_start - __pyx_v_block_start)); __pyx_t_3.f1 = ((size_t)(__pyx_v_endex - __pyx_v_block_start)); __pyx_r = __pyx_t_3; goto __pyx_L0;
0679:
0680:
+0681: cdef (size_t, size_t) Block_BoundOffsetSlice(const Block_* that, size_t start, size_t endex) nogil:
static __pyx_ctuple_size_t__and_size_t __pyx_f_11cbytesparse_1c_Block_BoundOffsetSlice(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex) { size_t __pyx_v_size; __pyx_ctuple_size_t__and_size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0682: cdef:
+0683: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
0684:
+0685: if start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0686: start = size # trim to end
__pyx_v_start = __pyx_v_size;
0687:
+0688: if endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0689: endex = size # trim to end
__pyx_v_endex = __pyx_v_size;
0690:
+0691: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0692: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0693:
+0694: return start, endex
__pyx_t_2.f0 = __pyx_v_start; __pyx_t_2.f1 = __pyx_v_endex; __pyx_r = __pyx_t_2; goto __pyx_L0;
0695:
0696:
+0697: cdef vint Block_CheckMutable(const Block_* that) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Block_CheckMutable(Block_ const *__pyx_v_that) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_CheckMutable", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_CheckMutable", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+0698: if that.references > 1:
__pyx_t_1 = ((__pyx_v_that->references > 1) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+0699: raise RuntimeError('Existing exports of data: object cannot be re-sized')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_RuntimeError, __pyx_tuple__5, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 699, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 699, __pyx_L1_error) /* … */ __pyx_tuple__5 = PyTuple_Pack(1, __pyx_kp_u_Existing_exports_of_data_object); if (unlikely(!__pyx_tuple__5)) __PYX_ERR(0, 699, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__5); __Pyx_GIVEREF(__pyx_tuple__5);
0700:
0701:
+0702: cdef bint Block_Eq_(const Block_* that, size_t size, const byte_t* buffer) nogil:
static int __pyx_f_11cbytesparse_1c_Block_Eq_(Block_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+0703: if size != that.endex - that.start:
__pyx_t_1 = ((__pyx_v_size != (__pyx_v_that->endex - __pyx_v_that->start)) != 0); if (__pyx_t_1) { /* … */ }
+0704: return False
__pyx_r = 0; goto __pyx_L0;
0705:
+0706: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+0707: if memcmp(&that.data[that.start], buffer, size):
__pyx_t_1 = (memcmp((&(__pyx_v_that->data[__pyx_v_that->start])), __pyx_v_buffer, __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0708: return False
__pyx_r = 0; goto __pyx_L0;
0709:
+0710: return True
__pyx_r = 1; goto __pyx_L0;
0711:
0712:
+0713: cdef bint Block_Eq(const Block_* that, const Block_* other) nogil:
static int __pyx_f_11cbytesparse_1c_Block_Eq(Block_ const *__pyx_v_that, Block_ const *__pyx_v_other) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0714: # if that.address != other.address:
0715: # return False
0716:
+0717: return Block_Eq_(that, other.endex - other.start, &other.data[other.start])
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Eq_(__pyx_v_that, (__pyx_v_other->endex - __pyx_v_other->start), (&(__pyx_v_other->data[__pyx_v_other->start]))); goto __pyx_L0;
0718:
0719:
+0720: cdef int Block_Cmp_(const Block_* that, size_t size, const byte_t* buffer) nogil:
static int __pyx_f_11cbytesparse_1c_Block_Cmp_(Block_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { size_t __pyx_v_size2; size_t __pyx_v_minsize; byte_t const *__pyx_v_buffer2; int __pyx_v_sign; int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0721: cdef:
+0722: size_t size2 = that.endex - that.start
__pyx_v_size2 = (__pyx_v_that->endex - __pyx_v_that->start);
+0723: size_t minsize = size2 if size2 < size else size
if (((__pyx_v_size2 < __pyx_v_size) != 0)) { __pyx_t_1 = __pyx_v_size2; } else { __pyx_t_1 = __pyx_v_size; } __pyx_v_minsize = __pyx_t_1;
+0724: const byte_t* buffer2 = &that.data[that.start]
__pyx_v_buffer2 = (&(__pyx_v_that->data[__pyx_v_that->start]));
+0725: int sign = memcmp(buffer2, buffer, minsize)
__pyx_v_sign = memcmp(__pyx_v_buffer2, __pyx_v_buffer, __pyx_v_minsize);
0726:
+0727: if size2 == size:
__pyx_t_2 = ((__pyx_v_size2 == __pyx_v_size) != 0); if (__pyx_t_2) { /* … */ }
+0728: return sign
__pyx_r = __pyx_v_sign; goto __pyx_L0;
+0729: elif sign:
__pyx_t_2 = (__pyx_v_sign != 0); if (__pyx_t_2) { /* … */ }
+0730: return sign
__pyx_r = __pyx_v_sign; goto __pyx_L0;
0731: else:
+0732: return -1 if size2 < size else +1
/*else*/ { if (((__pyx_v_size2 < __pyx_v_size) != 0)) { __pyx_t_3 = -1; } else { __pyx_t_3 = 1; } __pyx_r = __pyx_t_3; goto __pyx_L0; }
0733:
0734:
+0735: cdef int Block_Cmp(const Block_* that, const Block_* other) nogil:
static int __pyx_f_11cbytesparse_1c_Block_Cmp(Block_ const *__pyx_v_that, Block_ const *__pyx_v_other) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0736: # if that.address != other.address:
0737: # return -1 if that.address < other.address else +1
0738:
+0739: return Block_Cmp_(that, other.endex - other.start, &other.data[other.start])
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Cmp_(__pyx_v_that, (__pyx_v_other->endex - __pyx_v_other->start), (&(__pyx_v_other->data[__pyx_v_other->start]))); goto __pyx_L0;
0740:
0741:
+0742: cdef ssize_t Block_Find__(const Block_* that, size_t start, size_t endex, byte_t value) nogil:
static Py_ssize_t __pyx_f_11cbytesparse_1c_Block_Find__(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, byte_t __pyx_v_value) { size_t __pyx_v_size; byte_t const *__pyx_v_ptr; byte_t const *__pyx_v_end; Py_ssize_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0743: cdef:
+0744: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
0745: const byte_t* ptr
0746: const byte_t* end
0747:
+0748: if start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0749: start = size # trim to end
__pyx_v_start = __pyx_v_size;
+0750: if endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0751: endex = size # trim to end
__pyx_v_endex = __pyx_v_size;
+0752: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0753: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0754:
+0755: ptr = &that.data[that.start + start]
__pyx_v_ptr = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]));
+0756: end = &that.data[that.start + endex]
__pyx_v_end = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_endex)]));
0757:
+0758: while ptr != end:
while (1) { __pyx_t_1 = ((__pyx_v_ptr != __pyx_v_end) != 0); if (!__pyx_t_1) break;
+0759: if ptr[0] == value:
__pyx_t_1 = (((__pyx_v_ptr[0]) == __pyx_v_value) != 0); if (__pyx_t_1) { /* … */ }
+0760: return <ssize_t>(<ptrdiff_t>ptr - <ptrdiff_t>&that.data[that.start])
__pyx_r = ((Py_ssize_t)(((ptrdiff_t)__pyx_v_ptr) - ((ptrdiff_t)(&(__pyx_v_that->data[__pyx_v_that->start]))))); goto __pyx_L0;
+0761: ptr += 1
__pyx_v_ptr = (__pyx_v_ptr + 1); }
+0762: return -1
__pyx_r = -1L; goto __pyx_L0;
0763:
0764:
+0765: cdef ssize_t Block_Find_(const Block_* that, size_t start, size_t endex,
static Py_ssize_t __pyx_f_11cbytesparse_1c_Block_Find_(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { size_t __pyx_v_size2; byte_t const *__pyx_v_ptr; byte_t const *__pyx_v_end; Py_ssize_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0766: size_t size, const byte_t* buffer) nogil:
0767: cdef:
0768: size_t size2
0769: const byte_t* ptr
0770: const byte_t* end
0771:
+0772: if size == 1: # faster code for single byte
__pyx_t_1 = ((__pyx_v_size == 1) != 0); if (__pyx_t_1) { /* … */ }
+0773: return Block_Find__(that, start, endex, buffer[0])
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Find__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, (__pyx_v_buffer[0])); goto __pyx_L0;
0774:
+0775: elif size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+0776: size2 = that.endex - that.start
__pyx_v_size2 = (__pyx_v_that->endex - __pyx_v_that->start);
0777:
+0778: if start > size2:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0779: start = size2 # trim to end
__pyx_v_start = __pyx_v_size2;
+0780: if endex > size2:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0781: endex = size2 # trim to end
__pyx_v_endex = __pyx_v_size2;
+0782: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0783: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0784:
+0785: if size <= size2 and size <= endex - start:
__pyx_t_2 = ((__pyx_v_size <= __pyx_v_size2) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L8_bool_binop_done; } __pyx_t_2 = ((__pyx_v_size <= (__pyx_v_endex - __pyx_v_start)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L8_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+0786: size2 = endex - size + 1
__pyx_v_size2 = ((__pyx_v_endex - __pyx_v_size) + 1);
0787:
+0788: if start > size2:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0789: start = size2 # trim to end
__pyx_v_start = __pyx_v_size2;
+0790: if endex > size2:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0791: endex = size2 # trim to end
__pyx_v_endex = __pyx_v_size2;
0792:
+0793: ptr = &that.data[that.start + start]
__pyx_v_ptr = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]));
+0794: end = &that.data[that.start + endex]
__pyx_v_end = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_endex)]));
0795:
+0796: while ptr != end:
while (1) { __pyx_t_1 = ((__pyx_v_ptr != __pyx_v_end) != 0); if (!__pyx_t_1) break;
+0797: if ptr[0] == buffer[0]: # faster pruning
__pyx_t_1 = (((__pyx_v_ptr[0]) == (__pyx_v_buffer[0])) != 0); if (__pyx_t_1) { /* … */ }
+0798: if not memcmp(ptr, buffer, size):
__pyx_t_1 = ((!(memcmp(__pyx_v_ptr, __pyx_v_buffer, __pyx_v_size) != 0)) != 0); if (__pyx_t_1) { /* … */ }
+0799: return <ssize_t>(<ptrdiff_t>ptr - <ptrdiff_t>&that.data[that.start])
__pyx_r = ((Py_ssize_t)(((ptrdiff_t)__pyx_v_ptr) - ((ptrdiff_t)(&(__pyx_v_that->data[__pyx_v_that->start]))))); goto __pyx_L0;
+0800: ptr += 1
__pyx_v_ptr = (__pyx_v_ptr + 1); }
+0801: return -1
__pyx_r = -1L; goto __pyx_L0;
0802:
0803:
+0804: cdef ssize_t Block_Find(const Block_* that, ssize_t start, ssize_t endex,
static Py_ssize_t __pyx_f_11cbytesparse_1c_Block_Find(Block_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Py_ssize_t __pyx_v_ssize; Py_ssize_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0805: size_t size, const byte_t* buffer) nogil:
0806: cdef:
+0807: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
0808:
+0809: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+0810: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+0811: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+0812: start = 0 # trim to start
__pyx_v_start = 0;
0813:
+0814: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+0815: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+0816: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+0817: endex = 0 # trim to start
__pyx_v_endex = 0;
0818:
+0819: return Block_Find_(that, <size_t>start, <size_t>endex, size, buffer)
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Find_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_size, __pyx_v_buffer); goto __pyx_L0;
0820:
0821:
+0822: cdef ssize_t Block_ReverseFind__(const Block_* that, size_t start, size_t endex, byte_t value) nogil:
static Py_ssize_t __pyx_f_11cbytesparse_1c_Block_ReverseFind__(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, byte_t __pyx_v_value) { size_t __pyx_v_size; byte_t const *__pyx_v_ptr; byte_t const *__pyx_v_end; Py_ssize_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0823: cdef:
+0824: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
0825: const byte_t* ptr
0826: const byte_t* end
0827:
+0828: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+0829: if start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0830: start = size # trim to end
__pyx_v_start = __pyx_v_size;
+0831: if endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0832: endex = size # trim to end
__pyx_v_endex = __pyx_v_size;
+0833: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0834: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0835:
+0836: end = &that.data[that.start + start]
__pyx_v_end = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]));
+0837: ptr = &that.data[that.start + endex]
__pyx_v_ptr = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_endex)]));
0838:
+0839: while ptr != end:
while (1) { __pyx_t_1 = ((__pyx_v_ptr != __pyx_v_end) != 0); if (!__pyx_t_1) break;
+0840: ptr -= 1
__pyx_v_ptr = (__pyx_v_ptr - 1);
+0841: if ptr[0] == value:
__pyx_t_1 = (((__pyx_v_ptr[0]) == __pyx_v_value) != 0); if (__pyx_t_1) { /* … */ } }
+0842: return <ssize_t>(<ptrdiff_t>ptr - <ptrdiff_t>&that.data[that.start])
__pyx_r = ((Py_ssize_t)(((ptrdiff_t)__pyx_v_ptr) - ((ptrdiff_t)(&(__pyx_v_that->data[__pyx_v_that->start]))))); goto __pyx_L0;
+0843: return -1
__pyx_r = -1L; goto __pyx_L0;
0844:
0845:
+0846: cdef ssize_t Block_ReverseFind_(const Block_* that, size_t start, size_t endex,
static Py_ssize_t __pyx_f_11cbytesparse_1c_Block_ReverseFind_(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { size_t __pyx_v_size2; byte_t const *__pyx_v_ptr; byte_t const *__pyx_v_end; Py_ssize_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0847: size_t size, const byte_t* buffer) nogil:
0848: cdef:
0849: size_t size2
0850: const byte_t* ptr
0851: const byte_t* end
0852:
+0853: if size == 1: # faster code for single byte
__pyx_t_1 = ((__pyx_v_size == 1) != 0); if (__pyx_t_1) { /* … */ }
+0854: return Block_ReverseFind__(that, start, endex, buffer[0])
__pyx_r = __pyx_f_11cbytesparse_1c_Block_ReverseFind__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, (__pyx_v_buffer[0])); goto __pyx_L0;
0855:
+0856: elif size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+0857: size2 = that.endex - that.start
__pyx_v_size2 = (__pyx_v_that->endex - __pyx_v_that->start);
0858:
+0859: if start > size2:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0860: start = size2 # trim to end
__pyx_v_start = __pyx_v_size2;
+0861: if endex > size2:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0862: endex = size2 # trim to end
__pyx_v_endex = __pyx_v_size2;
+0863: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0864: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0865:
+0866: if size <= size2 and size <= endex - start:
__pyx_t_2 = ((__pyx_v_size <= __pyx_v_size2) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L8_bool_binop_done; } __pyx_t_2 = ((__pyx_v_size <= (__pyx_v_endex - __pyx_v_start)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L8_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+0867: size2 = endex - size + 1
__pyx_v_size2 = ((__pyx_v_endex - __pyx_v_size) + 1);
0868:
+0869: if start > size2:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0870: start = size2 # trim to end
__pyx_v_start = __pyx_v_size2;
+0871: if endex > size2:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0872: endex = size2 # trim to end
__pyx_v_endex = __pyx_v_size2;
0873:
+0874: end = &that.data[that.start + start]
__pyx_v_end = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]));
+0875: ptr = &that.data[that.start + endex]
__pyx_v_ptr = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_endex)]));
0876:
+0877: while ptr != end:
while (1) { __pyx_t_1 = ((__pyx_v_ptr != __pyx_v_end) != 0); if (!__pyx_t_1) break;
+0878: ptr -= 1
__pyx_v_ptr = (__pyx_v_ptr - 1);
+0879: if ptr[0] == buffer[0]: # faster pruning
__pyx_t_1 = (((__pyx_v_ptr[0]) == (__pyx_v_buffer[0])) != 0); if (__pyx_t_1) { /* … */ } }
+0880: if not memcmp(ptr, buffer, size):
__pyx_t_1 = ((!(memcmp(__pyx_v_ptr, __pyx_v_buffer, __pyx_v_size) != 0)) != 0); if (__pyx_t_1) { /* … */ }
+0881: return <ssize_t>(<ptrdiff_t>ptr - <ptrdiff_t>&that.data[that.start])
__pyx_r = ((Py_ssize_t)(((ptrdiff_t)__pyx_v_ptr) - ((ptrdiff_t)(&(__pyx_v_that->data[__pyx_v_that->start]))))); goto __pyx_L0;
+0882: return -1
__pyx_r = -1L; goto __pyx_L0;
0883:
0884:
+0885: cdef ssize_t Block_ReverseFind(const Block_* that, ssize_t start, ssize_t endex,
static Py_ssize_t __pyx_f_11cbytesparse_1c_Block_ReverseFind(Block_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Py_ssize_t __pyx_v_ssize; Py_ssize_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0886: size_t size, const byte_t* buffer) nogil:
0887: cdef:
+0888: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
0889:
+0890: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+0891: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+0892: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+0893: start = 0 # trim to start
__pyx_v_start = 0;
0894:
+0895: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+0896: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+0897: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+0898: endex = 0 # trim to start
__pyx_v_endex = 0;
0899:
+0900: return Block_ReverseFind_(that, <size_t>start, <size_t>endex, size, buffer)
__pyx_r = __pyx_f_11cbytesparse_1c_Block_ReverseFind_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_size, __pyx_v_buffer); goto __pyx_L0;
0901:
0902:
+0903: cdef size_t Block_Count__(const Block_* that, size_t start, size_t endex, byte_t value) nogil:
static size_t __pyx_f_11cbytesparse_1c_Block_Count__(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, byte_t __pyx_v_value) { size_t __pyx_v_count; size_t __pyx_v_size; byte_t const *__pyx_v_ptr; byte_t const *__pyx_v_end; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0904: cdef:
+0905: size_t count = 0
__pyx_v_count = 0;
+0906: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
0907: const byte_t* ptr
0908: const byte_t* end
0909:
+0910: if start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0911: start = size # trim to end
__pyx_v_start = __pyx_v_size;
+0912: if endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+0913: endex = size # trim to end
__pyx_v_endex = __pyx_v_size;
+0914: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0915: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0916:
+0917: ptr = &that.data[that.start + start]
__pyx_v_ptr = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]));
+0918: end = &that.data[that.start + endex]
__pyx_v_end = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_endex)]));
0919:
+0920: while ptr != end:
while (1) { __pyx_t_1 = ((__pyx_v_ptr != __pyx_v_end) != 0); if (!__pyx_t_1) break;
+0921: if ptr[0] == value:
__pyx_t_1 = (((__pyx_v_ptr[0]) == __pyx_v_value) != 0); if (__pyx_t_1) { /* … */ }
+0922: count += 1
__pyx_v_count = (__pyx_v_count + 1);
+0923: ptr += 1
__pyx_v_ptr = (__pyx_v_ptr + 1); }
+0924: return count
__pyx_r = __pyx_v_count; goto __pyx_L0;
0925:
0926:
+0927: cdef size_t Block_Count_(const Block_* that, size_t start, size_t endex,
static size_t __pyx_f_11cbytesparse_1c_Block_Count_(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { size_t __pyx_v_count; size_t __pyx_v_size2; byte_t const *__pyx_v_ptr; byte_t const *__pyx_v_end; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0928: size_t size, const byte_t* buffer) nogil:
0929: cdef:
+0930: size_t count = 0
__pyx_v_count = 0;
0931: size_t size2
0932: const byte_t* ptr
0933: const byte_t* end
0934:
+0935: if size == 1: # faster code for single byte
__pyx_t_1 = ((__pyx_v_size == 1) != 0); if (__pyx_t_1) { /* … */ }
+0936: return Block_Count__(that, start, endex, buffer[0])
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Count__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, (__pyx_v_buffer[0])); goto __pyx_L0;
0937:
+0938: elif size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+0939: size2 = that.endex - that.start
__pyx_v_size2 = (__pyx_v_that->endex - __pyx_v_that->start);
0940:
+0941: if start > size2:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0942: start = size2 # trim to end
__pyx_v_start = __pyx_v_size2;
+0943: if endex > size2:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0944: endex = size2 # trim to end
__pyx_v_endex = __pyx_v_size2;
+0945: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+0946: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
0947:
+0948: if size <= size2 and size <= endex - start:
__pyx_t_2 = ((__pyx_v_size <= __pyx_v_size2) != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L8_bool_binop_done; } __pyx_t_2 = ((__pyx_v_size <= (__pyx_v_endex - __pyx_v_start)) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L8_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+0949: size2 = endex - size + 1
__pyx_v_size2 = ((__pyx_v_endex - __pyx_v_size) + 1);
0950:
+0951: if start > size2:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0952: start = size2 # trim to end
__pyx_v_start = __pyx_v_size2;
+0953: if endex > size2:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+0954: endex = size2 # trim to end
__pyx_v_endex = __pyx_v_size2;
0955:
+0956: ptr = &that.data[that.start + start]
__pyx_v_ptr = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]));
+0957: end = &that.data[that.start + endex]
__pyx_v_end = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_endex)]));
0958:
+0959: while ptr < end:
while (1) { __pyx_t_1 = ((__pyx_v_ptr < __pyx_v_end) != 0); if (!__pyx_t_1) break;
+0960: if ptr[0] == buffer[0]: # faster pruning
__pyx_t_1 = (((__pyx_v_ptr[0]) == (__pyx_v_buffer[0])) != 0); if (__pyx_t_1) { /* … */ }
+0961: if not memcmp(ptr, buffer, size):
__pyx_t_1 = ((!(memcmp(__pyx_v_ptr, __pyx_v_buffer, __pyx_v_size) != 0)) != 0); if (__pyx_t_1) { /* … */ }
+0962: ptr += size - 1
__pyx_v_ptr = (__pyx_v_ptr + (__pyx_v_size - 1));
+0963: count += 1
__pyx_v_count = (__pyx_v_count + 1);
+0964: ptr += 1
__pyx_v_ptr = (__pyx_v_ptr + 1); }
+0965: return count
__pyx_r = __pyx_v_count; goto __pyx_L0;
0966:
0967:
+0968: cdef size_t Block_Count(const Block_* that, ssize_t start, ssize_t endex,
static size_t __pyx_f_11cbytesparse_1c_Block_Count(Block_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Py_ssize_t __pyx_v_ssize; size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
0969: size_t size, const byte_t* buffer) nogil:
0970: cdef:
+0971: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
0972:
+0973: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+0974: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+0975: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+0976: start = 0 # trim to start
__pyx_v_start = 0;
0977:
+0978: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+0979: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+0980: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+0981: endex = 0 # trim to start
__pyx_v_endex = 0;
0982:
+0983: return Block_Count_(that, <size_t>start, <size_t>endex, size, buffer)
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Count_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_size, __pyx_v_buffer); goto __pyx_L0;
0984:
0985:
+0986: cdef Block_* Block_Reserve_(Block_* that, size_t offset, size_t size, bint zero) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Reserve_(Block_ *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size, int __pyx_v_zero) { size_t __pyx_v_actual; size_t __pyx_v_used; size_t __pyx_v_allocated; Block_ *__pyx_v_ptr; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Reserve_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Block_Reserve_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
0987: cdef:
0988: size_t actual
0989: size_t used
0990: size_t margin
0991: size_t allocated
0992: Block_* ptr
0993:
+0994: Block_CheckMutable(that)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_CheckMutable(__pyx_v_that); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 994, __pyx_L1_error)
0995:
+0996: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+0997: if ((size > SIZE_HMAX or
__pyx_t_3 = ((__pyx_v_size > SIZE_HMAX) != 0); if (!__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L5_bool_binop_done; } /* … */ if (unlikely(__pyx_t_2)) { /* … */ }
+0998: CannotAddSizeU(that.endex, size) or
__pyx_t_3 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_that->endex, __pyx_v_size) != 0); if (!__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L5_bool_binop_done; }
+0999: that.endex + size > SIZE_HMAX)):
__pyx_t_3 = (((__pyx_v_that->endex + __pyx_v_size) > SIZE_HMAX) != 0); __pyx_t_2 = __pyx_t_3; __pyx_L5_bool_binop_done:;
+1000: raise OverflowError('size overflow')
__pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1000, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 1000, __pyx_L1_error)
1001:
+1002: used = that.endex - that.start
__pyx_v_used = (__pyx_v_that->endex - __pyx_v_that->start);
+1003: if offset > used:
__pyx_t_2 = ((__pyx_v_offset > __pyx_v_used) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1004: raise IndexError('index out of range')
__pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1004, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 1004, __pyx_L1_error) /* … */ __pyx_tuple__6 = PyTuple_Pack(1, __pyx_kp_u_index_out_of_range); if (unlikely(!__pyx_tuple__6)) __PYX_ERR(0, 1004, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__6); __Pyx_GIVEREF(__pyx_tuple__6);
1005:
1006: # Prefer the side where there is less data to shift, which also favors the extremes
+1007: if offset >= (used >> 1):
__pyx_t_2 = ((__pyx_v_offset >= (__pyx_v_used >> 1)) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L9; }
+1008: if size > that.allocated - that.endex:
__pyx_t_2 = ((__pyx_v_size > (__pyx_v_that->allocated - __pyx_v_that->endex)) != 0); if (__pyx_t_2) { /* … */ }
1009: # Calculate the upsized allocation
+1010: allocated = Upsize(that.allocated, that.allocated + size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Upsize(__pyx_v_that->allocated, (__pyx_v_that->allocated + __pyx_v_size));
+1011: if allocated > SIZE_HMAX:
__pyx_t_2 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1012: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 1012, __pyx_L1_error)
1013:
1014: # Reallocate, including the header
+1015: ptr = <Block_*>PyMem_Realloc(that, Block_HEADING + (allocated * sizeof(byte_t)))
__pyx_v_ptr = ((Block_ *)PyMem_Realloc(__pyx_v_that, (Block_HEADING + (__pyx_v_allocated * (sizeof(byte_t))))));
+1016: if ptr == NULL:
__pyx_t_2 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1017: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 1017, __pyx_L1_error)
1018:
1019: # Reassign to that
+1020: that = ptr
__pyx_v_that = __pyx_v_ptr;
+1021: that.allocated = allocated # update
__pyx_v_that->allocated = __pyx_v_allocated;
1022:
1023: # Shift elements to make room for reservation at the requested offset
+1024: CheckAddSizeU(offset, that.start)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_that->start); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1024, __pyx_L1_error)
+1025: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+1026: used = that.endex - offset
__pyx_v_used = (__pyx_v_that->endex - __pyx_v_offset);
+1027: if used:
__pyx_t_2 = (__pyx_v_used != 0); if (__pyx_t_2) { /* … */ }
+1028: memmove(&that.data[offset + size],
(void)(memmove((&(__pyx_v_that->data[(__pyx_v_offset + __pyx_v_size)])), (&(__pyx_v_that->data[__pyx_v_offset])), (__pyx_v_used * (sizeof(byte_t)))));
1029: &that.data[offset],
1030: used * sizeof(byte_t))
+1031: if zero:
__pyx_t_2 = (__pyx_v_zero != 0); if (__pyx_t_2) { /* … */ }
+1032: memset(&that.data[offset], 0, size * sizeof(byte_t)) # pad with zeros
(void)(memset((&(__pyx_v_that->data[__pyx_v_offset])), 0, (__pyx_v_size * (sizeof(byte_t)))));
+1033: that.endex += size
__pyx_v_that->endex = (__pyx_v_that->endex + __pyx_v_size);
1034:
1035: else:
+1036: if size <= that.start:
/*else*/ { __pyx_t_2 = ((__pyx_v_size <= __pyx_v_that->start) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L15; }
1037: # Shift elements to make room for reservation at the requested offset
+1038: that.start -= size
__pyx_v_that->start = (__pyx_v_that->start - __pyx_v_size);
+1039: if offset:
__pyx_t_2 = (__pyx_v_offset != 0); if (__pyx_t_2) { /* … */ }
+1040: memmove(&that.data[that.start],
(void)(memmove((&(__pyx_v_that->data[__pyx_v_that->start])), (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_size)])), (__pyx_v_offset * (sizeof(byte_t)))));
1041: &that.data[that.start + size],
1042: offset * sizeof(byte_t))
+1043: if zero:
__pyx_t_2 = (__pyx_v_zero != 0); if (__pyx_t_2) { /* … */ }
+1044: memset(&that.data[that.start + offset], 0, size * sizeof(byte_t)) # pad with zeros
(void)(memset((&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)])), 0, (__pyx_v_size * (sizeof(byte_t)))));
1045:
1046: else:
1047: # Calculate the upsized allocation
+1048: CheckAddSizeU(that.allocated, size)
/*else*/ {
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->allocated, __pyx_v_size); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1048, __pyx_L1_error)
+1049: allocated = Upsize(that.allocated, that.allocated + size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Upsize(__pyx_v_that->allocated, (__pyx_v_that->allocated + __pyx_v_size));
+1050: if allocated > SIZE_HMAX:
__pyx_t_2 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1051: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 1051, __pyx_L1_error)
1052:
1053: # Allocate a new chunk, including the header
+1054: actual = Block_HEADING + (allocated * sizeof(byte_t))
__pyx_v_actual = (Block_HEADING + (__pyx_v_allocated * (sizeof(byte_t))));
+1055: if zero:
__pyx_t_2 = (__pyx_v_zero != 0); if (__pyx_t_2) { /* … */ goto __pyx_L19; }
+1056: ptr = <Block_*>PyMem_Calloc(actual, 1)
__pyx_v_ptr = ((Block_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(__pyx_v_actual, 1));
1057: else:
+1058: ptr = <Block_*>PyMem_Malloc(actual)
/*else*/ {
__pyx_v_ptr = ((Block_ *)PyMem_Malloc(__pyx_v_actual));
}
__pyx_L19:;
+1059: if ptr == NULL:
__pyx_t_2 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1060: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 1060, __pyx_L1_error)
1061:
1062: # Prepare the new chunk aligning towards the end
+1063: ptr.address = that.address
__pyx_t_5 = __pyx_v_that->address; __pyx_v_ptr->address = __pyx_t_5;
+1064: ptr.references = that.references # transfer ownership
__pyx_t_6 = __pyx_v_that->references; __pyx_v_ptr->references = __pyx_t_6;
+1065: ptr.allocated = allocated
__pyx_v_ptr->allocated = __pyx_v_allocated;
+1066: ptr.endex = ptr.allocated - MARGIN # leave some room
__pyx_v_ptr->endex = (__pyx_v_ptr->allocated - MARGIN);
+1067: ptr.start = ptr.endex - used - size
__pyx_v_ptr->start = ((__pyx_v_ptr->endex - __pyx_v_used) - __pyx_v_size);
1068:
1069: # Shift/copy elements to make room for reservation at the requested offset
+1070: if offset:
__pyx_t_2 = (__pyx_v_offset != 0); if (__pyx_t_2) { /* … */ }
+1071: used -= offset # prepare for later
__pyx_v_used = (__pyx_v_used - __pyx_v_offset);
+1072: memcpy(&ptr.data[ptr.start],
(void)(memcpy((&(__pyx_v_ptr->data[__pyx_v_ptr->start])), (&(__pyx_v_that->data[__pyx_v_that->start])), (__pyx_v_offset * (sizeof(byte_t)))));
1073: &that.data[that.start],
1074: offset * sizeof(byte_t))
+1075: if used:
__pyx_t_2 = (__pyx_v_used != 0); if (__pyx_t_2) { /* … */ }
+1076: memcpy(&ptr.data[ptr.start + offset + size],
(void)(memcpy((&(__pyx_v_ptr->data[((__pyx_v_ptr->start + __pyx_v_offset) + __pyx_v_size)])), (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)])), (__pyx_v_used * (sizeof(byte_t)))));
1077: &that.data[that.start + offset],
1078: used * sizeof(byte_t))
1079:
1080: # Reassign to that
+1081: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
+1082: that = ptr
__pyx_v_that = __pyx_v_ptr; } __pyx_L15:; } __pyx_L9:;
1083:
+1084: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1085:
1086:
+1087: cdef Block_* Block_Delete_(Block_* that, size_t offset, size_t size) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Delete_(Block_ *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size) { size_t __pyx_v_allocated; Block_ *__pyx_v_ptr; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Delete_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Block_Delete_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1088: cdef:
1089: size_t allocated
1090: Block_* ptr
1091:
+1092: Block_CheckMutable(that)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_CheckMutable(__pyx_v_that); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1092, __pyx_L1_error)
1093:
+1094: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+1095: if ((size > SIZE_HMAX or
__pyx_t_3 = ((__pyx_v_size > SIZE_HMAX) != 0); if (!__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L5_bool_binop_done; } /* … */ if (unlikely(__pyx_t_2)) { /* … */ }
+1096: CannotAddSizeU(offset, size) or
__pyx_t_3 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_offset, __pyx_v_size) != 0); if (!__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L5_bool_binop_done; }
+1097: offset + size > SIZE_HMAX or
__pyx_t_3 = (((__pyx_v_offset + __pyx_v_size) > SIZE_HMAX) != 0); if (!__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L5_bool_binop_done; }
+1098: CannotAddSizeU(offset, that.start) or
__pyx_t_3 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_offset, __pyx_v_that->start) != 0); if (!__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L5_bool_binop_done; }
+1099: that.start > SIZE_HMAX)):
__pyx_t_3 = ((__pyx_v_that->start > SIZE_HMAX) != 0); __pyx_t_2 = __pyx_t_3; __pyx_L5_bool_binop_done:;
+1100: raise OverflowError('size overflow')
__pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1100, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 1100, __pyx_L1_error)
1101:
+1102: if that.endex < that.start + offset + size:
__pyx_t_2 = ((__pyx_v_that->endex < ((__pyx_v_that->start + __pyx_v_offset) + __pyx_v_size)) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1103: raise IndexError('index out of range')
__pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1103, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 1103, __pyx_L1_error)
1104:
1105: # Calculate the downsized allocation
+1106: allocated = Downsize(that.allocated, that.allocated - size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Downsize(__pyx_v_that->allocated, (__pyx_v_that->allocated - __pyx_v_size));
+1107: if allocated > SIZE_HMAX:
__pyx_t_2 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1108: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 1108, __pyx_L1_error)
1109:
+1110: if offset == 0:
__pyx_t_2 = ((__pyx_v_offset == 0) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L12; }
+1111: if allocated == that.allocated:
__pyx_t_2 = ((__pyx_v_allocated == __pyx_v_that->allocated) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L13; }
1112: # Just skip initial if not reallocated and no offset
+1113: that.start += size
__pyx_v_that->start = (__pyx_v_that->start + __pyx_v_size);
1114: else:
1115: # Shift elements to make for the deleted gap at the beginning
+1116: offset += that.start
/*else*/ { __pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+1117: memmove(&that.data[MARGIN], # realign to initial MARGIN
(void)(memmove((&(__pyx_v_that->data[MARGIN])), (&(__pyx_v_that->data[(__pyx_v_offset + __pyx_v_size)])), ((__pyx_v_that->endex - (__pyx_v_offset + __pyx_v_size)) * (sizeof(byte_t)))));
1118: &that.data[offset + size],
1119: (that.endex - (offset + size)) * sizeof(byte_t))
+1120: size = that.endex - that.start - size
__pyx_v_size = ((__pyx_v_that->endex - __pyx_v_that->start) - __pyx_v_size);
+1121: that.start = MARGIN
__pyx_v_that->start = MARGIN;
+1122: that.endex = MARGIN + size
__pyx_v_that->endex = (MARGIN + __pyx_v_size); } __pyx_L13:;
1123: else:
1124: # Shift elements to make for the deleted gap at the requested offset
+1125: offset += that.start
/*else*/ { __pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+1126: memmove(&that.data[offset],
(void)(memmove((&(__pyx_v_that->data[__pyx_v_offset])), (&(__pyx_v_that->data[(__pyx_v_offset + __pyx_v_size)])), ((__pyx_v_that->endex - (__pyx_v_offset + __pyx_v_size)) * (sizeof(byte_t)))));
1127: &that.data[offset + size],
1128: (that.endex - (offset + size)) * sizeof(byte_t))
+1129: that.endex -= size
__pyx_v_that->endex = (__pyx_v_that->endex - __pyx_v_size); } __pyx_L12:;
1130:
+1131: if allocated != that.allocated:
__pyx_t_2 = ((__pyx_v_allocated != __pyx_v_that->allocated) != 0); if (__pyx_t_2) { /* … */ }
1132: # Reallocate, including the header
+1133: ptr = <Block_*>PyMem_Realloc(that, Block_HEADING + (allocated * sizeof(byte_t)))
__pyx_v_ptr = ((Block_ *)PyMem_Realloc(__pyx_v_that, (Block_HEADING + (__pyx_v_allocated * (sizeof(byte_t))))));
+1134: if ptr == NULL:
__pyx_t_2 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1135: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 1135, __pyx_L1_error)
1136:
1137: # Reassign to that
+1138: that = ptr
__pyx_v_that = __pyx_v_ptr;
+1139: that.allocated = allocated
__pyx_v_that->allocated = __pyx_v_allocated;
1140:
+1141: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1142:
1143:
+1144: cdef Block_* Block_Clear(Block_* that) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Clear(Block_ *__pyx_v_that) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Clear", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1145: return Block_Delete_(that, 0, that.endex - that.start)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_Delete_(__pyx_v_that, 0, (__pyx_v_that->endex - __pyx_v_that->start)); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1145, __pyx_L1_error)
__pyx_r = __pyx_t_1;
goto __pyx_L0;
1146:
1147:
+1148: cdef byte_t* Block_At_(Block_* that, size_t offset) nogil:
static byte_t *__pyx_f_11cbytesparse_1c_Block_At_(Block_ *__pyx_v_that, size_t __pyx_v_offset) { byte_t *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+1149: return &that.data[that.start + offset]
__pyx_r = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)])); goto __pyx_L0;
1150:
1151:
+1152: cdef const byte_t* Block_At__(const Block_* that, size_t offset) nogil:
static byte_t const *__pyx_f_11cbytesparse_1c_Block_At__(Block_ const *__pyx_v_that, size_t __pyx_v_offset) { byte_t const *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+1153: return &that.data[that.start + offset]
__pyx_r = (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)])); goto __pyx_L0;
1154:
1155:
+1156: cdef byte_t Block_Get__(const Block_* that, size_t offset) nogil:
static byte_t __pyx_f_11cbytesparse_1c_Block_Get__(Block_ const *__pyx_v_that, size_t __pyx_v_offset) { byte_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+1157: return that.data[that.start + offset]
__pyx_r = (__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)]); goto __pyx_L0;
1158:
1159:
+1160: cdef int Block_Get_(const Block_* that, size_t offset) except -1:
static int __pyx_f_11cbytesparse_1c_Block_Get_(Block_ const *__pyx_v_that, size_t __pyx_v_offset) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Get_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Block_Get_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1161: CheckAddSizeU(that.start, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1161, __pyx_L1_error)
+1162: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
1163:
+1164: if offset < that.endex:
__pyx_t_2 = ((__pyx_v_offset < __pyx_v_that->endex) != 0); if (likely(__pyx_t_2)) { /* … */ }
+1165: return <int><unsigned>that.data[offset]
__pyx_r = ((int)((unsigned int)(__pyx_v_that->data[__pyx_v_offset]))); goto __pyx_L0;
1166: else:
+1167: raise IndexError('index out of range')
/*else*/ { __pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1167, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 1167, __pyx_L1_error) }
1168:
1169:
+1170: cdef int Block_Get(const Block_* that, ssize_t offset) except -1:
static int __pyx_f_11cbytesparse_1c_Block_Get(Block_ const *__pyx_v_that, Py_ssize_t __pyx_v_offset) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Get", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Get", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1171: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
+1172: offset += <ssize_t>(that.endex - that.start) # anchor to end
__pyx_v_offset = (__pyx_v_offset + ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start)));
+1173: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1174: raise IndexError('index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1174, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1174, __pyx_L1_error)
1175:
+1176: return Block_Get_(that, <size_t>offset)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Get_(__pyx_v_that, ((size_t)__pyx_v_offset)); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(0, 1176, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
1177:
1178:
+1179: cdef byte_t Block_Set__(Block_* that, size_t offset, byte_t value) nogil:
static byte_t __pyx_f_11cbytesparse_1c_Block_Set__(Block_ *__pyx_v_that, size_t __pyx_v_offset, byte_t __pyx_v_value) { byte_t __pyx_v_backup; byte_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
1180: cdef:
1181: byte_t backup
1182:
+1183: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+1184: backup = that.data[offset]
__pyx_v_backup = (__pyx_v_that->data[__pyx_v_offset]);
+1185: that.data[offset] = value
(__pyx_v_that->data[__pyx_v_offset]) = __pyx_v_value;
+1186: return backup
__pyx_r = __pyx_v_backup; goto __pyx_L0;
1187:
1188:
+1189: cdef int Block_Set_(Block_* that, size_t offset, byte_t value) except -1:
static int __pyx_f_11cbytesparse_1c_Block_Set_(Block_ *__pyx_v_that, size_t __pyx_v_offset, byte_t __pyx_v_value) { int __pyx_v_backup; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Set_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Block_Set_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1190: cdef:
1191: int backup
1192:
1193: # Block_CheckMutable(that)
+1194: CheckAddSizeU(that.start, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1194, __pyx_L1_error)
+1195: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
1196:
+1197: if offset < that.endex:
__pyx_t_2 = ((__pyx_v_offset < __pyx_v_that->endex) != 0); if (likely(__pyx_t_2)) { /* … */ }
+1198: backup = <int><unsigned>that.data[offset]
__pyx_v_backup = ((int)((unsigned int)(__pyx_v_that->data[__pyx_v_offset])));
+1199: that.data[offset] = value
(__pyx_v_that->data[__pyx_v_offset]) = __pyx_v_value;
+1200: return backup
__pyx_r = __pyx_v_backup; goto __pyx_L0;
1201: else:
+1202: raise IndexError('index out of range')
/*else*/ { __pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1202, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 1202, __pyx_L1_error) }
1203:
1204:
+1205: cdef int Block_Set(Block_* that, ssize_t offset, byte_t value) except -1:
static int __pyx_f_11cbytesparse_1c_Block_Set(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_offset, byte_t __pyx_v_value) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Set", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Set", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1206: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
+1207: offset += <ssize_t>(that.endex - that.start) # anchor to end
__pyx_v_offset = (__pyx_v_offset + ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start)));
+1208: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1209: raise IndexError('index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1209, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1209, __pyx_L1_error)
1210:
+1211: return Block_Set_(that, <size_t>offset, value)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Set_(__pyx_v_that, ((size_t)__pyx_v_offset), __pyx_v_value); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(0, 1211, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
1212:
1213:
+1214: cdef Block_* Block_Pop__(Block_* that, byte_t* value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Pop__(Block_ *__pyx_v_that, byte_t *__pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Pop__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Block_Pop__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1215: # Block_CheckMutable(that)
1216:
+1217: if that.start < that.endex:
__pyx_t_1 = ((__pyx_v_that->start < __pyx_v_that->endex) != 0); if (likely(__pyx_t_1)) { /* … */ }
+1218: if value:
__pyx_t_1 = (__pyx_v_value != 0); if (__pyx_t_1) { /* … */ }
+1219: value[0] = that.data[that.endex - 1] # backup
(__pyx_v_value[0]) = (__pyx_v_that->data[(__pyx_v_that->endex - 1)]);
1220:
+1221: return Block_Delete_(that, that.endex - that.start - 1, 1)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Delete_(__pyx_v_that, ((__pyx_v_that->endex - __pyx_v_that->start) - 1), 1); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1221, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
1222: else:
+1223: raise IndexError('pop index out of range')
/*else*/ { __pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__7, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1223, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 1223, __pyx_L1_error) } /* … */ __pyx_tuple__7 = PyTuple_Pack(1, __pyx_kp_u_pop_index_out_of_range); if (unlikely(!__pyx_tuple__7)) __PYX_ERR(0, 1223, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__7); __Pyx_GIVEREF(__pyx_tuple__7);
1224:
1225:
+1226: cdef Block_* Block_Pop_(Block_* that, size_t offset, byte_t* value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Pop_(Block_ *__pyx_v_that, size_t __pyx_v_offset, byte_t *__pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Pop_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Block_Pop_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1227: # Block_CheckMutable(that)
+1228: CheckAddSizeU(that.start, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1228, __pyx_L1_error)
1229:
+1230: if that.start + offset < that.endex:
__pyx_t_2 = (((__pyx_v_that->start + __pyx_v_offset) < __pyx_v_that->endex) != 0); if (likely(__pyx_t_2)) { /* … */ }
+1231: if value:
__pyx_t_2 = (__pyx_v_value != 0); if (__pyx_t_2) { /* … */ }
+1232: value[0] = that.data[that.start + offset] # backup
(__pyx_v_value[0]) = (__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)]);
1233:
+1234: return Block_Delete_(that, offset, 1)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Delete_(__pyx_v_that, __pyx_v_offset, 1); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1234, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
1235: else:
+1236: raise IndexError('pop index out of range')
/*else*/ { __pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__7, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 1236, __pyx_L1_error) }
1237:
1238:
+1239: cdef Block_* Block_Pop(Block_* that, ssize_t offset, byte_t* value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Pop(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_offset, byte_t *__pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Pop", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1240: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
+1241: offset += <ssize_t>(that.endex - that.start) # anchor to end
__pyx_v_offset = (__pyx_v_offset + ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start)));
+1242: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1243: raise IndexError('pop index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__7, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1243, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1243, __pyx_L1_error)
1244:
+1245: return Block_Pop_(that, <size_t>offset, value)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Pop_(__pyx_v_that, ((size_t)__pyx_v_offset), __pyx_v_value); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1245, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
1246:
1247:
+1248: cdef Block_* Block_PopLeft(Block_* that, byte_t* value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_PopLeft(Block_ *__pyx_v_that, byte_t *__pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_PopLeft", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_PopLeft", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1249: return Block_Pop_(that, 0, value)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_Pop_(__pyx_v_that, 0, __pyx_v_value); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1249, __pyx_L1_error)
__pyx_r = __pyx_t_1;
goto __pyx_L0;
1250:
1251:
+1252: cdef Block_* Block_Insert_(Block_* that, size_t offset, byte_t value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Insert_(Block_ *__pyx_v_that, size_t __pyx_v_offset, byte_t __pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Insert_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Insert_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1253: # Insert the value at the requested offset
+1254: that = Block_Reserve_(that, offset, 1, False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, __pyx_v_offset, 1, 0); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1254, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+1255: that.data[that.start + offset] = value
(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_offset)]) = __pyx_v_value;
+1256: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1257:
1258:
+1259: cdef Block_* Block_Insert(Block_* that, ssize_t offset, byte_t value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Insert(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_offset, byte_t __pyx_v_value) { Py_ssize_t __pyx_v_size; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Insert", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Insert", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1260: cdef:
+1261: ssize_t size = <ssize_t>(that.endex - that.start)
__pyx_v_size = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1262:
+1263: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+1264: offset += size # anchor to end
__pyx_v_offset = (__pyx_v_offset + __pyx_v_size);
+1265: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
1266: # raise IndexError('index out of range')
+1267: offset = 0 # as per bytearray.insert
__pyx_v_offset = 0;
1268:
+1269: elif offset > size:
__pyx_t_1 = ((__pyx_v_offset > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L3:;
1270: # raise IndexError('index out of range')
+1271: offset = size # as per bytearray.insert
__pyx_v_offset = __pyx_v_size;
1272:
+1273: return Block_Insert_(that, <size_t>offset, value)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Insert_(__pyx_v_that, ((size_t)__pyx_v_offset), __pyx_v_value); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1273, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
1274:
1275:
+1276: cdef Block_* Block_Append(Block_* that, byte_t value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Append(Block_ *__pyx_v_that, byte_t __pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Append", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Append", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1277: # Insert the value after the end
+1278: that = Block_Reserve_(that, that.endex - that.start, 1, False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, (__pyx_v_that->endex - __pyx_v_that->start), 1, 0); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1278, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+1279: that.data[that.endex - 1] = value
(__pyx_v_that->data[(__pyx_v_that->endex - 1)]) = __pyx_v_value;
+1280: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1281:
1282:
+1283: cdef Block_* Block_AppendLeft(Block_* that, byte_t value) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_AppendLeft(Block_ *__pyx_v_that, byte_t __pyx_v_value) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_AppendLeft", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_AppendLeft", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1284: # Insert the value after the end
+1285: that = Block_Reserve_(that, 0, 1, False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, 0, 1, 0); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1285, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+1286: that.data[that.start] = value
(__pyx_v_that->data[__pyx_v_that->start]) = __pyx_v_value;
+1287: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1288:
1289:
+1290: cdef Block_* Block_Extend_(Block_* that, size_t size, const byte_t* buffer) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Extend_(Block_ *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Extend_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Extend_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1291: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1292: that = Block_Reserve_(that, that.endex - that.start, size, False)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, (__pyx_v_that->endex - __pyx_v_that->start), __pyx_v_size, 0); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1292, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1293: memmove(&that.data[that.endex - size], buffer, size * sizeof(byte_t))
(void)(memmove((&(__pyx_v_that->data[(__pyx_v_that->endex - __pyx_v_size)])), __pyx_v_buffer, (__pyx_v_size * (sizeof(byte_t)))));
+1294: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1295:
1296:
+1297: cdef Block_* Block_Extend(Block_* that, const Block_* more) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Extend(Block_ *__pyx_v_that, Block_ const *__pyx_v_more) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Extend", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Extend", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1298: that = Block_Extend_(that, Block_Length(more), Block_At__(more, 0))
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_Extend_(__pyx_v_that, __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_more), __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_more, 0)); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1298, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+1299: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1300:
1301:
+1302: cdef Block_* Block_ExtendLeft_(Block_* that, size_t size, const byte_t* buffer) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_ExtendLeft_(Block_ *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_ExtendLeft_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_ExtendLeft_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1303: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1304: that = Block_Reserve_(that, 0, size, False)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, 0, __pyx_v_size, 0); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1304, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1305: memmove(&that.data[that.start], buffer, size * sizeof(byte_t))
(void)(memmove((&(__pyx_v_that->data[__pyx_v_that->start])), __pyx_v_buffer, (__pyx_v_size * (sizeof(byte_t)))));
+1306: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1307:
1308:
+1309: cdef Block_* Block_ExtendLeft(Block_* that, const Block_* more) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_ExtendLeft(Block_ *__pyx_v_that, Block_ const *__pyx_v_more) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_ExtendLeft", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_ExtendLeft", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1310: that = Block_ExtendLeft_(that, Block_Length(more), Block_At__(more, 0))
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Block_ExtendLeft_(__pyx_v_that, __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_more), __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_more, 0)); if (unlikely(__pyx_t_1 == ((Block_ *)NULL))) __PYX_ERR(0, 1310, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+1311: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1312:
1313:
+1314: cdef void Block_RotateLeft__(Block_* that, size_t offset) nogil:
static void __pyx_f_11cbytesparse_1c_Block_RotateLeft__(Block_ *__pyx_v_that, size_t __pyx_v_offset) { size_t __pyx_v_size; byte_t *__pyx_v_data; byte_t __pyx_v_first; /* … */ /* function exit code */ }
1315: cdef:
+1316: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
+1317: byte_t* data = &that.data[that.start]
__pyx_v_data = (&(__pyx_v_that->data[__pyx_v_that->start]));
1318: byte_t first
1319:
+1320: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1321: if offset == 1:
__pyx_t_1 = ((__pyx_v_offset == 1) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+1322: first = data[0]
__pyx_v_first = (__pyx_v_data[0]);
+1323: size -= 1
__pyx_v_size = (__pyx_v_size - 1);
+1324: while size:
while (1) { __pyx_t_1 = (__pyx_v_size != 0); if (!__pyx_t_1) break;
+1325: data[0] = data[1]
(__pyx_v_data[0]) = (__pyx_v_data[1]);
+1326: data += 1
__pyx_v_data = (__pyx_v_data + 1);
+1327: size -= 1
__pyx_v_size = (__pyx_v_size - 1); }
+1328: data[0] = first
(__pyx_v_data[0]) = __pyx_v_first;
1329:
+1330: elif offset:
__pyx_t_1 = (__pyx_v_offset != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+1331: Reverse(data, 0, offset - 1)
__pyx_f_11cbytesparse_1c_Reverse(__pyx_v_data, 0, (__pyx_v_offset - 1));
+1332: Reverse(data, offset, size - 1)
__pyx_f_11cbytesparse_1c_Reverse(__pyx_v_data, __pyx_v_offset, (__pyx_v_size - 1));
+1333: Reverse(data, 0, size - 1)
__pyx_f_11cbytesparse_1c_Reverse(__pyx_v_data, 0, (__pyx_v_size - 1));
1334:
1335:
+1336: cdef void Block_RotateLeft_(Block_* that, size_t offset) nogil:
static void __pyx_f_11cbytesparse_1c_Block_RotateLeft_(Block_ *__pyx_v_that, size_t __pyx_v_offset) { size_t __pyx_v_size; /* … */ /* function exit code */ }
1337: cdef:
+1338: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1339:
+1340: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1341: if offset >= size:
__pyx_t_1 = ((__pyx_v_offset >= __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
1342: with cython.cdivision(True):
+1343: offset = offset % size # no "%=" to avoid zero check
__pyx_v_offset = (__pyx_v_offset % __pyx_v_size);
1344:
+1345: Block_RotateLeft__(that, offset)
__pyx_f_11cbytesparse_1c_Block_RotateLeft__(__pyx_v_that, __pyx_v_offset);
1346:
1347:
+1348: cdef void Block_RotateRight__(Block_* that, size_t offset) nogil:
static void __pyx_f_11cbytesparse_1c_Block_RotateRight__(Block_ *__pyx_v_that, size_t __pyx_v_offset) { size_t __pyx_v_size; byte_t *__pyx_v_data; byte_t __pyx_v_last; /* … */ /* function exit code */ }
1349: cdef:
+1350: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
+1351: byte_t* data = &that.data[that.start]
__pyx_v_data = (&(__pyx_v_that->data[__pyx_v_that->start]));
1352: byte_t last
1353:
+1354: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1355: if offset == 1:
__pyx_t_1 = ((__pyx_v_offset == 1) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+1356: size -= 1
__pyx_v_size = (__pyx_v_size - 1);
+1357: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1358: data += size
__pyx_v_data = (__pyx_v_data + __pyx_v_size);
+1359: last = data[0]
__pyx_v_last = (__pyx_v_data[0]);
+1360: while size:
while (1) { __pyx_t_1 = (__pyx_v_size != 0); if (!__pyx_t_1) break;
+1361: size -= 1
__pyx_v_size = (__pyx_v_size - 1);
+1362: data -= 1
__pyx_v_data = (__pyx_v_data - 1);
+1363: data[1] = data[0]
(__pyx_v_data[1]) = (__pyx_v_data[0]); }
+1364: data[0] = last
(__pyx_v_data[0]) = __pyx_v_last;
1365:
+1366: elif offset:
__pyx_t_1 = (__pyx_v_offset != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+1367: offset = size - offset
__pyx_v_offset = (__pyx_v_size - __pyx_v_offset);
+1368: Reverse(data, 0, offset - 1)
__pyx_f_11cbytesparse_1c_Reverse(__pyx_v_data, 0, (__pyx_v_offset - 1));
+1369: Reverse(data, offset, size - 1)
__pyx_f_11cbytesparse_1c_Reverse(__pyx_v_data, __pyx_v_offset, (__pyx_v_size - 1));
+1370: Reverse(data, 0, size - 1)
__pyx_f_11cbytesparse_1c_Reverse(__pyx_v_data, 0, (__pyx_v_size - 1));
1371:
1372:
+1373: cdef void Block_RotateRight_(Block_* that, size_t offset) nogil:
static void __pyx_f_11cbytesparse_1c_Block_RotateRight_(Block_ *__pyx_v_that, size_t __pyx_v_offset) { size_t __pyx_v_size; /* … */ /* function exit code */ }
1374: cdef:
+1375: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1376:
+1377: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1378: if offset >= size:
__pyx_t_1 = ((__pyx_v_offset >= __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
1379: with cython.cdivision(True):
+1380: offset = offset % size # no "%=" to avoid zero check
__pyx_v_offset = (__pyx_v_offset % __pyx_v_size);
1381:
+1382: Block_RotateRight__(that, offset)
__pyx_f_11cbytesparse_1c_Block_RotateRight__(__pyx_v_that, __pyx_v_offset);
1383:
1384:
+1385: cdef void Block_Rotate(Block_* that, ssize_t offset) nogil:
static void __pyx_f_11cbytesparse_1c_Block_Rotate(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_offset) { /* … */ /* function exit code */ }
+1386: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+1387: Block_RotateLeft_(that, <size_t>-offset)
__pyx_f_11cbytesparse_1c_Block_RotateLeft_(__pyx_v_that, ((size_t)(-__pyx_v_offset)));
1388: else:
+1389: Block_RotateRight_(that, <size_t>offset)
/*else*/ { __pyx_f_11cbytesparse_1c_Block_RotateRight_(__pyx_v_that, ((size_t)__pyx_v_offset)); } __pyx_L3:;
1390:
1391:
+1392: cdef Block_* Block_Repeat(Block_* that, size_t times) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Repeat(Block_ *__pyx_v_that, size_t __pyx_v_times) { size_t __pyx_v_size; byte_t *__pyx_v_src; byte_t *__pyx_v_dst; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Repeat", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Block_Repeat", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1393: cdef:
1394: size_t size
1395: byte_t* src
1396: byte_t* dst
1397:
+1398: if times == 1:
__pyx_t_1 = ((__pyx_v_times == 1) != 0); if (__pyx_t_1) { /* … */ }
+1399: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1400:
+1401: elif times < 1:
__pyx_t_1 = ((__pyx_v_times < 1) != 0); if (__pyx_t_1) { /* … */ }
+1402: return Block_Clear(that)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Clear(__pyx_v_that); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1402, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
1403:
1404: else:
+1405: size = that.endex - that.start
/*else*/ { __pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1406: with cython.cdivision(True):
+1407: if size > SIZE_HMAX // times:
__pyx_t_1 = ((__pyx_v_size > (SIZE_HMAX / __pyx_v_times)) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1408: raise OverflowError()
__pyx_t_3 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1408, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 1408, __pyx_L1_error)
1409:
+1410: times -= 1
__pyx_v_times = (__pyx_v_times - 1);
+1411: that = Block_Reserve_(that, size, size * times, False)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, __pyx_v_size, (__pyx_v_size * __pyx_v_times), 0); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1411, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1412: src = &that.data[that.start]
__pyx_v_src = (&(__pyx_v_that->data[__pyx_v_that->start]));
+1413: dst = src
__pyx_v_dst = __pyx_v_src;
1414:
+1415: while times:
while (1) { __pyx_t_1 = (__pyx_v_times != 0); if (!__pyx_t_1) break;
+1416: times -= 1
__pyx_v_times = (__pyx_v_times - 1);
+1417: dst += size
__pyx_v_dst = (__pyx_v_dst + __pyx_v_size);
+1418: memcpy(dst, src, size) # whole repetition
(void)(memcpy(__pyx_v_dst, __pyx_v_src, __pyx_v_size)); }
1419:
+1420: return that
__pyx_r = __pyx_v_that; goto __pyx_L0; }
1421:
1422:
+1423: cdef Block_* Block_RepeatToSize(Block_* that, size_t size) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_RepeatToSize(Block_ *__pyx_v_that, size_t __pyx_v_size) { size_t __pyx_v_size2; size_t __pyx_v_times; byte_t *__pyx_v_src; byte_t *__pyx_v_dst; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_RepeatToSize", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_RepeatToSize", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1424: cdef:
1425: size_t size2
1426: size_t times
1427: byte_t* src
1428: byte_t* dst
1429:
+1430: size2 = that.endex - that.start
__pyx_v_size2 = (__pyx_v_that->endex - __pyx_v_that->start);
1431:
+1432: if size2 == 0:
__pyx_t_1 = ((__pyx_v_size2 == 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1433: raise RuntimeError('empty')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_RuntimeError, __pyx_tuple__8, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1433, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1433, __pyx_L1_error) /* … */ __pyx_tuple__8 = PyTuple_Pack(1, __pyx_n_u_empty); if (unlikely(!__pyx_tuple__8)) __PYX_ERR(0, 1433, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__8); __Pyx_GIVEREF(__pyx_tuple__8);
1434:
+1435: if size == size2:
__pyx_t_1 = ((__pyx_v_size == __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+1436: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1437:
+1438: elif size < size2:
__pyx_t_1 = ((__pyx_v_size < __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+1439: return Block_DelSlice_(that, size, size2)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_DelSlice_(__pyx_v_that, __pyx_v_size, __pyx_v_size2); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1439, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
1440:
1441: else: # size > size2
+1442: that = Block_Reserve_(that, size2, size - size2, False)
/*else*/ {
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, __pyx_v_size2, (__pyx_v_size - __pyx_v_size2), 0); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1442, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
1443:
+1444: if that.start + 1 == that.endex: # single byte
__pyx_t_1 = (((__pyx_v_that->start + 1) == __pyx_v_that->endex) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L5; }
+1445: dst = &that.data[that.start]
__pyx_v_dst = (&(__pyx_v_that->data[__pyx_v_that->start]));
+1446: memset(dst, dst[0], size)
(void)(memset(__pyx_v_dst, (__pyx_v_dst[0]), __pyx_v_size));
1447:
1448: else: # multiple bytes
+1449: with cython.cdivision(True):
/*else*/ {
+1450: times = size // size2
__pyx_v_times = (__pyx_v_size / __pyx_v_size2);
1451:
1452: # Copy the final partial chunk
+1453: src = &that.data[that.start]
__pyx_v_src = (&(__pyx_v_that->data[__pyx_v_that->start]));
+1454: dst = &that.data[that.start + (size2 * times)]
__pyx_v_dst = (&(__pyx_v_that->data[(__pyx_v_that->start + (__pyx_v_size2 * __pyx_v_times))]));
+1455: memcpy(dst, src, size - (size2 * times))
(void)(memcpy(__pyx_v_dst, __pyx_v_src, (__pyx_v_size - (__pyx_v_size2 * __pyx_v_times))));
1456:
1457: # Copy the multiple times, skipping the first one
+1458: dst = src + size2
__pyx_v_dst = (__pyx_v_src + __pyx_v_size2);
+1459: times -= 1
__pyx_v_times = (__pyx_v_times - 1);
+1460: while times:
while (1) { __pyx_t_1 = (__pyx_v_times != 0); if (!__pyx_t_1) break;
+1461: memcpy(dst, src, size2)
(void)(memcpy(__pyx_v_dst, __pyx_v_src, __pyx_v_size2));
+1462: dst += size2
__pyx_v_dst = (__pyx_v_dst + __pyx_v_size2);
+1463: times -= 1
__pyx_v_times = (__pyx_v_times - 1); } } __pyx_L5:;
1464:
+1465: return that
__pyx_r = __pyx_v_that; goto __pyx_L0; }
1466:
1467:
+1468: cdef vint Block_Read_(const Block_* that, size_t offset, size_t size, byte_t* buffer) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Block_Read_(Block_ const *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size, byte_t *__pyx_v_buffer) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Read_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_Read_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1469: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1470: if size > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_size > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1471: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1471, __pyx_L1_error)
1472:
+1473: CheckAddSizeU(offset, that.start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_that->start); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1473, __pyx_L1_error)
+1474: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
1475:
+1476: CheckAddSizeU(offset, size)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_size); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1476, __pyx_L1_error)
+1477: if that.endex < offset + size:
__pyx_t_1 = ((__pyx_v_that->endex < (__pyx_v_offset + __pyx_v_size)) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1478: raise IndexError('index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1478, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1478, __pyx_L1_error)
1479:
+1480: memmove(buffer, &that.data[offset], size * sizeof(byte_t))
(void)(memmove(__pyx_v_buffer, (&(__pyx_v_that->data[__pyx_v_offset])), (__pyx_v_size * (sizeof(byte_t)))));
1481:
1482:
+1483: cdef Block_* Block_Write_(Block_* that, size_t offset, size_t size, const byte_t* buffer) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_Write_(Block_ *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Write_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_Write_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1484: # Block_CheckMutable(that)
1485:
+1486: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+1487: CheckAddSizeU(that.start, offset)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1487, __pyx_L1_error)
+1488: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
1489:
+1490: CheckAddSizeU(offset, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1490, __pyx_L1_error)
+1491: if that.endex < offset + size:
__pyx_t_1 = ((__pyx_v_that->endex < (__pyx_v_offset + __pyx_v_size)) != 0); if (__pyx_t_1) { /* … */ }
+1492: that = Block_Reserve_(that, that.endex - that.start, (offset + size) - that.endex, False)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, (__pyx_v_that->endex - __pyx_v_that->start), ((__pyx_v_offset + __pyx_v_size) - __pyx_v_that->endex), 0); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1492, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
1493:
+1494: memmove(&that.data[offset], buffer, size * sizeof(byte_t))
(void)(memmove((&(__pyx_v_that->data[__pyx_v_offset])), __pyx_v_buffer, (__pyx_v_size * (sizeof(byte_t)))));
+1495: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1496:
1497:
+1498: cdef vint Block_ReadSlice_(const Block_* that, size_t start, size_t endex,
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Block_ReadSlice_(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t *__pyx_v_size_, byte_t *__pyx_v_buffer) { size_t __pyx_v_size; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_ReadSlice_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_ReadSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1499: size_t* size_, byte_t* buffer) except -1:
1500: cdef:
+1501: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1502:
+1503: size_[0] = 0
(__pyx_v_size_[0]) = 0;
1504:
+1505: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1506: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1506, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1506, __pyx_L1_error)
+1507: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1508: start = size # trim source start
__pyx_v_start = __pyx_v_size;
1509:
+1510: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1511: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1511, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1511, __pyx_L1_error)
+1512: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+1513: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
+1514: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+1515: endex = size # trim source end
__pyx_v_endex = __pyx_v_size;
1516:
+1517: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
+1518: Block_Read_(that, start, size, buffer)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Read_(__pyx_v_that, __pyx_v_start, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1518, __pyx_L1_error)
+1519: size_[0] = size
(__pyx_v_size_[0]) = __pyx_v_size;
1520:
1521:
+1522: cdef vint Block_ReadSlice(const Block_* that, ssize_t start, ssize_t endex,
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Block_ReadSlice(Block_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t *__pyx_v_size_, byte_t *__pyx_v_buffer) { Py_ssize_t __pyx_v_ssize; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_ReadSlice", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_ReadSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1523: size_t* size_, byte_t* buffer) except -1:
1524: cdef:
+1525: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1526:
+1527: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1528: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+1529: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1530: start = 0 # trim source start
__pyx_v_start = 0;
1531:
+1532: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+1533: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+1534: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1535: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
1536:
+1537: Block_ReadSlice_(that, <size_t>start, <size_t>endex, size_, buffer)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_ReadSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_size_, __pyx_v_buffer); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1537, __pyx_L1_error)
1538:
1539:
+1540: cdef Block_* Block_GetSlice_(const Block_* that, size_t start, size_t endex) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_GetSlice_(Block_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex) { size_t __pyx_v_size; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_GetSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_GetSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1541: cdef:
+1542: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1543:
+1544: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1545: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1545, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1545, __pyx_L1_error)
+1546: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1547: start = size # trim source start
__pyx_v_start = __pyx_v_size;
1548:
+1549: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1550: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1550, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1550, __pyx_L1_error)
+1551: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+1552: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
+1553: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+1554: endex = size # trim source end
__pyx_v_endex = __pyx_v_size;
1555:
+1556: return Block_Create(that.address + start, endex - start, &that.data[that.start + start])
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Create((__pyx_v_that->address + __pyx_v_start), (__pyx_v_endex - __pyx_v_start), (&(__pyx_v_that->data[(__pyx_v_that->start + __pyx_v_start)]))); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1556, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
1557:
1558:
+1559: cdef Block_* Block_GetSlice(const Block_* that, ssize_t start, ssize_t endex) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_GetSlice(Block_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex) { Py_ssize_t __pyx_v_ssize; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_GetSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_GetSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1560: cdef:
+1561: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1562:
+1563: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1564: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+1565: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1566: start = 0 # trim source start
__pyx_v_start = 0;
1567:
+1568: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+1569: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+1570: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1571: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
1572:
+1573: return Block_GetSlice_(that, <size_t>start, <size_t>endex)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_GetSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex)); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1573, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
1574:
1575:
+1576: cdef Block_* Block_WriteSlice_(Block_* that, size_t start, size_t endex,
static Block_ *__pyx_f_11cbytesparse_1c_Block_WriteSlice_(Block_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { size_t __pyx_v_size2; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_WriteSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_WriteSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1577: size_t size, const byte_t* buffer) except NULL:
1578: cdef:
1579: size_t size2 # source size
1580:
+1581: size2 = size
__pyx_v_size2 = __pyx_v_size;
+1582: size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1583:
+1584: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1585: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1585, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1585, __pyx_L1_error)
+1586: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1587: start = size # trim target start
__pyx_v_start = __pyx_v_size;
1588:
+1589: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1590: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1590, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1590, __pyx_L1_error)
+1591: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1592: endex = size # trim target end
__pyx_v_endex = __pyx_v_size;
1593:
+1594: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1595: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
+1596: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
1597:
+1598: if size2 > size: # enlarge target at range end
__pyx_t_1 = ((__pyx_v_size2 > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L6; }
+1599: that = Block_Reserve_(that, endex, size2 - size, False)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size2 - __pyx_v_size), 0); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1599, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
1600:
+1601: elif size > size2: # shrink target at range end
__pyx_t_1 = ((__pyx_v_size > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ } __pyx_L6:;
+1602: endex -= size - size2
__pyx_v_endex = (__pyx_v_endex - (__pyx_v_size - __pyx_v_size2));
+1603: that = Block_Delete_(that, endex, size - size2)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Delete_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size - __pyx_v_size2)); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1603, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
1604:
+1605: that = Block_Write_(that, start, size2, buffer)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Write_(__pyx_v_that, __pyx_v_start, __pyx_v_size2, __pyx_v_buffer); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1605, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+1606: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1607:
1608:
+1609: cdef Block_* Block_WriteSlice(Block_* that, ssize_t start, ssize_t endex,
static Block_ *__pyx_f_11cbytesparse_1c_Block_WriteSlice(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Py_ssize_t __pyx_v_ssize; Py_ssize_t __pyx_v_ssize2; Py_ssize_t __pyx_v_start2; Py_ssize_t __pyx_v_endex2; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_WriteSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_WriteSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1610: size_t size, const byte_t* buffer) except NULL:
1611: cdef:
1612: ssize_t ssize # target size
1613: ssize_t ssize2 # source size
1614: ssize_t start2 # source start
1615: ssize_t endex2 # source end
1616:
+1617: start2 = 0
__pyx_v_start2 = 0;
+1618: endex2 = <ssize_t>size
__pyx_v_endex2 = ((Py_ssize_t)__pyx_v_size);
1619:
+1620: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1621:
+1622: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1623: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+1624: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
1625: # start2 -= start # skip initial source data # as per bytearray
+1626: start = 0 # trim target start
__pyx_v_start = 0;
+1627: if start2 > endex2:
__pyx_t_1 = ((__pyx_v_start2 > __pyx_v_endex2) != 0); if (__pyx_t_1) { /* … */ }
+1628: start2 = endex2 # clamp source start
__pyx_v_start2 = __pyx_v_endex2;
1629:
+1630: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+1631: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+1632: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1633: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
1634:
+1635: if endex2 < start2:
__pyx_t_1 = ((__pyx_v_endex2 < __pyx_v_start2) != 0); if (__pyx_t_1) { /* … */ }
+1636: endex2 = start2 # clamp negative source length
__pyx_v_endex2 = __pyx_v_start2;
+1637: ssize2 = endex2 - start2
__pyx_v_ssize2 = (__pyx_v_endex2 - __pyx_v_start2);
1638:
+1639: that = Block_WriteSlice_(that, <size_t>start, <size_t>endex, <size_t>ssize2, &buffer[start2])
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_WriteSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), ((size_t)__pyx_v_ssize2), (&(__pyx_v_buffer[__pyx_v_start2]))); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1639, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1640: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1641:
1642:
+1643: cdef Block_* Block_SetSlice_(Block_* that, size_t start, size_t endex,
static Block_ *__pyx_f_11cbytesparse_1c_Block_SetSlice_(Block_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, Block_ const *__pyx_v_src, size_t __pyx_v_start2, size_t __pyx_v_endex2) { size_t __pyx_v_size; size_t __pyx_v_size2; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_SetSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_SetSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1644: const Block_* src, size_t start2, size_t endex2) except NULL:
1645: cdef:
1646: size_t size # target size
1647: size_t size2 # source size
1648:
+1649: size2 = src.endex - src.start
__pyx_v_size2 = (__pyx_v_src->endex - __pyx_v_src->start);
1650:
+1651: if start2 > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start2 > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1652: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1652, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1652, __pyx_L1_error)
+1653: elif start2 > size2:
__pyx_t_1 = ((__pyx_v_start2 > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+1654: start2 = size2 # trim source start
__pyx_v_start2 = __pyx_v_size2;
1655:
+1656: if endex2 > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex2 > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1657: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1657, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1657, __pyx_L1_error)
+1658: elif endex2 > size2:
__pyx_t_1 = ((__pyx_v_endex2 > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+1659: endex2 = size2 # trim source end
__pyx_v_endex2 = __pyx_v_size2;
1660:
+1661: if endex2 < start2:
__pyx_t_1 = ((__pyx_v_endex2 < __pyx_v_start2) != 0); if (__pyx_t_1) { /* … */ }
+1662: endex2 = start2 # clamp negative source length
__pyx_v_endex2 = __pyx_v_start2;
+1663: size2 = endex2 - start2
__pyx_v_size2 = (__pyx_v_endex2 - __pyx_v_start2);
1664:
+1665: size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1666:
+1667: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1668: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1668, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1668, __pyx_L1_error)
+1669: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1670: start = size # trim target start
__pyx_v_start = __pyx_v_size;
1671:
+1672: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1673: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1673, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1673, __pyx_L1_error)
+1674: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1675: endex = size # trim target end
__pyx_v_endex = __pyx_v_size;
1676:
+1677: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1678: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
+1679: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
1680:
+1681: if size2 > size: # enlarge target at range end
__pyx_t_1 = ((__pyx_v_size2 > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L9; }
+1682: that = Block_Reserve_(that, endex, size2 - size, False)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size2 - __pyx_v_size), 0); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1682, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
1683:
+1684: elif size > size2: # shrink target at range end
__pyx_t_1 = ((__pyx_v_size > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ } __pyx_L9:;
+1685: endex -= size - size2
__pyx_v_endex = (__pyx_v_endex - (__pyx_v_size - __pyx_v_size2));
+1686: that = Block_Delete_(that, endex, size - size2)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Delete_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size - __pyx_v_size2)); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1686, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
1687:
+1688: that = Block_Write_(that, start, size2, &src.data[src.start + start2])
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Write_(__pyx_v_that, __pyx_v_start, __pyx_v_size2, (&(__pyx_v_src->data[(__pyx_v_src->start + __pyx_v_start2)]))); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1688, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+1689: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1690:
1691:
+1692: cdef Block_* Block_SetSlice(Block_* that, ssize_t start, ssize_t endex,
static Block_ *__pyx_f_11cbytesparse_1c_Block_SetSlice(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, Block_ const *__pyx_v_src, Py_ssize_t __pyx_v_start2, Py_ssize_t __pyx_v_endex2) { Py_ssize_t __pyx_v_ssize; Py_ssize_t __pyx_v_ssize2; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_SetSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_SetSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1693: const Block_* src, ssize_t start2, ssize_t endex2) except NULL:
1694: cdef:
1695: ssize_t ssize # target size
1696: ssize_t ssize2 # source size
1697:
+1698: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
+1699: ssize2 = <ssize_t>(src.endex - src.start)
__pyx_v_ssize2 = ((Py_ssize_t)(__pyx_v_src->endex - __pyx_v_src->start));
1700:
+1701: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1702: start += ssize # anchor to target end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+1703: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
1704: # start2 -= start # skip initial source data # as per bytearray
+1705: start = 0 # trim target start
__pyx_v_start = 0;
1706:
+1707: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+1708: endex += ssize # anchor to target end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+1709: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1710: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
1711:
+1712: if start2 < 0:
__pyx_t_1 = ((__pyx_v_start2 < 0) != 0); if (__pyx_t_1) { /* … */ }
+1713: start2 += ssize2 # anchor to source end
__pyx_v_start2 = (__pyx_v_start2 + __pyx_v_ssize2);
+1714: if start2 < 0:
__pyx_t_1 = ((__pyx_v_start2 < 0) != 0); if (__pyx_t_1) { /* … */ }
+1715: start2 = 0 # trim source start
__pyx_v_start2 = 0;
1716:
+1717: if endex2 < 0:
__pyx_t_1 = ((__pyx_v_endex2 < 0) != 0); if (__pyx_t_1) { /* … */ }
+1718: endex2 += ssize2 # anchor to source end
__pyx_v_endex2 = (__pyx_v_endex2 + __pyx_v_ssize2);
+1719: if endex2 < start2:
__pyx_t_1 = ((__pyx_v_endex2 < __pyx_v_start2) != 0); if (__pyx_t_1) { /* … */ }
+1720: endex2 = start2 # clamp negative source length
__pyx_v_endex2 = __pyx_v_start2;
1721:
+1722: that = Block_SetSlice_(that, <size_t>start, <size_t>endex, src, <size_t>start2, <size_t>endex2)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_SetSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_src, ((size_t)__pyx_v_start2), ((size_t)__pyx_v_endex2)); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1722, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1723: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1724:
1725:
+1726: cdef Block_* Block_DelSlice_(Block_* that, size_t start, size_t endex) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_DelSlice_(Block_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex) { size_t __pyx_v_size; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_DelSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_DelSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1727: cdef:
1728: size_t size
1729:
+1730: size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1731:
+1732: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1733: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1733, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1733, __pyx_L1_error)
+1734: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1735: start = size # trim start
__pyx_v_start = __pyx_v_size;
1736:
+1737: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1738: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1738, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1738, __pyx_L1_error)
+1739: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+1740: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
+1741: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+1742: endex = size # trim end
__pyx_v_endex = __pyx_v_size;
1743:
+1744: that = Block_Delete_(that, start, (endex - start))
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Delete_(__pyx_v_that, __pyx_v_start, (__pyx_v_endex - __pyx_v_start)); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1744, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+1745: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1746:
1747:
+1748: cdef Block_* Block_DelSlice(Block_* that, ssize_t start, ssize_t endex) except NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Block_DelSlice(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex) { Py_ssize_t __pyx_v_ssize; Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_DelSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Block_DelSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1749: cdef:
1750: ssize_t ssize
1751:
+1752: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1753:
+1754: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1755: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+1756: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1757: start = 0 # trim start
__pyx_v_start = 0;
1758:
+1759: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+1760: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+1761: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1762: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
1763:
+1764: that = Block_DelSlice_(that, <size_t>start, <size_t>endex)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_DelSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex)); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1764, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1765: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
1766:
1767:
+1768: cdef bytes Block_Bytes(const Block_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Block_Bytes(Block_ const *__pyx_v_that) { char *__pyx_v_ptr; Py_ssize_t __pyx_v_size; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Bytes", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Block_Bytes", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1769: cdef:
+1770: char* ptr = <char*><void*>&that.data[that.start]
__pyx_v_ptr = ((char *)((void *)(&(__pyx_v_that->data[__pyx_v_that->start]))));
+1771: ssize_t size = <ssize_t>(that.endex - that.start)
__pyx_v_size = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1772:
+1773: return PyBytes_FromStringAndSize(ptr, size)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyBytes_FromStringAndSize(__pyx_v_ptr, __pyx_v_size); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1773, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0;
1774:
1775:
+1776: cdef bytearray Block_Bytearray(const Block_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Block_Bytearray(Block_ const *__pyx_v_that) { char *__pyx_v_ptr; Py_ssize_t __pyx_v_size; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_Bytearray", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Block_Bytearray", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1777: cdef:
+1778: char* ptr = <char*><void*>&that.data[that.start]
__pyx_v_ptr = ((char *)((void *)(&(__pyx_v_that->data[__pyx_v_that->start]))));
+1779: ssize_t size = <ssize_t>(that.endex - that.start)
__pyx_v_size = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1780:
+1781: return PyByteArray_FromStringAndSize(ptr, size)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyByteArray_FromStringAndSize(__pyx_v_ptr, __pyx_v_size); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1781, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0;
1782:
1783:
+1784: cdef BlockView Block_View(Block_* that):
static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_f_11cbytesparse_1c_Block_View(Block_ *__pyx_v_that) { struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_view = 0; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_View", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Block_View", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_view); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1785: cdef:
1786: BlockView view
1787:
+1788: view = BlockView()
__pyx_t_1 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_BlockView)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1788, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_view = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_1); __pyx_t_1 = 0;
+1789: that = Block_Acquire(that)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_that); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1789, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+1790: view._block = that
__pyx_v_view->_block = __pyx_v_that;
+1791: view._start = that.start
__pyx_t_3 = __pyx_v_that->start; __pyx_v_view->_start = __pyx_t_3;
+1792: view._endex = that.endex
__pyx_t_3 = __pyx_v_that->endex; __pyx_v_view->_endex = __pyx_t_3;
+1793: return view
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_view)); __pyx_r = __pyx_v_view; goto __pyx_L0;
1794:
1795:
+1796: cdef BlockView Block_ViewSlice_(Block_* that, size_t start, size_t endex):
static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_f_11cbytesparse_1c_Block_ViewSlice_(Block_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex) { size_t __pyx_v_size; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_view = 0; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_ViewSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_ViewSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_view); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1797: cdef:
+1798: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
1799: BlockView view
1800:
+1801: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1802: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1802, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1802, __pyx_L1_error)
+1803: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+1804: start = size # trim source start
__pyx_v_start = __pyx_v_size;
1805:
+1806: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1807: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1807, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1807, __pyx_L1_error)
+1808: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+1809: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
+1810: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+1811: endex = size # trim source end
__pyx_v_endex = __pyx_v_size;
1812:
+1813: view = BlockView()
__pyx_t_2 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_BlockView)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1813, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_view = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_2); __pyx_t_2 = 0;
+1814: that = Block_Acquire(that)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_that); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 1814, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+1815: view._block = that
__pyx_v_view->_block = __pyx_v_that;
+1816: view._start = that.start + start
__pyx_v_view->_start = (__pyx_v_that->start + __pyx_v_start);
+1817: view._endex = that.start + endex
__pyx_v_view->_endex = (__pyx_v_that->start + __pyx_v_endex);
+1818: return view
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_view)); __pyx_r = __pyx_v_view; goto __pyx_L0;
1819:
1820:
+1821: cdef BlockView Block_ViewSlice(Block_* that, ssize_t start, ssize_t endex):
static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_f_11cbytesparse_1c_Block_ViewSlice(Block_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex) { Py_ssize_t __pyx_v_ssize; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Block_ViewSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Block_ViewSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1822: cdef:
1823: ssize_t ssize
1824:
+1825: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
1826:
+1827: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1828: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+1829: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+1830: start = 0 # trim source start
__pyx_v_start = 0;
1831:
+1832: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+1833: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+1834: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+1835: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
1836:
+1837: return Block_ViewSlice_(that, <size_t>start, <size_t>endex)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Block_ViewSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex))); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1837, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_2); __pyx_t_2 = 0; goto __pyx_L0;
1838:
1839:
1840: # ---------------------------------------------------------------------------------------------------------------------
1841:
+1842: cdef class BlockView:
struct __pyx_vtabstruct_11cbytesparse_1c_BlockView { __pyx_t_11cbytesparse_1c_vint (*check_)(struct __pyx_obj_11cbytesparse_1c_BlockView *); __pyx_t_11cbytesparse_1c_vint (*dispose_)(struct __pyx_obj_11cbytesparse_1c_BlockView *); }; static struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *__pyx_vtabptr_11cbytesparse_1c_BlockView;
1843: r"""Block viewer.
1844:
1845: Memory view around an underlying block slice, implementing Python's `buffer`
1846: protocol API.
1847: """
1848:
+1849: cdef vint check_(self: BlockView) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_9BlockView_check_(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("check_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.BlockView.check_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1850: if self._block == NULL:
__pyx_t_1 = ((__pyx_v_self->_block == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+1851: raise RuntimeError('null internal data pointer')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_RuntimeError, __pyx_tuple__9, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1851, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 1851, __pyx_L1_error) /* … */ __pyx_tuple__9 = PyTuple_Pack(1, __pyx_kp_u_null_internal_data_pointer); if (unlikely(!__pyx_tuple__9)) __PYX_ERR(0, 1851, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__9); __Pyx_GIVEREF(__pyx_tuple__9);
1852:
+1853: cdef vint dispose_(self: BlockView) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_9BlockView_dispose_(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("dispose_", 0); /* … */ /* function exit code */ __pyx_r = 0; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1854: self._memview = None
__Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); __Pyx_GOTREF(__pyx_v_self->_memview); __Pyx_DECREF(__pyx_v_self->_memview); __pyx_v_self->_memview = Py_None;
1855:
+1856: if self._block:
__pyx_t_1 = (__pyx_v_self->_block != 0); if (__pyx_t_1) { /* … */ }
+1857: self._block = Block_Release(self._block)
__pyx_v_self->_block = __pyx_f_11cbytesparse_1c_Block_Release(__pyx_v_self->_block);
1858:
+1859: def __bool__(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_9BlockView_1__bool__(PyObject *__pyx_v_self); /*proto*/ static int __pyx_pw_11cbytesparse_1c_9BlockView_1__bool__(PyObject *__pyx_v_self) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bool__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView___bool__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_9BlockView___bool__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bool__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.BlockView.__bool__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1860: self: BlockView,
1861: ) -> bool:
1862: r"""Has any data.
1863:
1864: Returns:
1865: bool: Non-null slice length.
1866: """
1867:
+1868: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1868, __pyx_L1_error)
+1869: return self._start < self._endex
__pyx_r = (__pyx_v_self->_start < __pyx_v_self->_endex); goto __pyx_L0;
1870:
+1871: def __bytes__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_3__bytes__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_9BlockView_2__bytes__[] = "BlockView.__bytes__(self: BlockView) -> bytes\nConverts into bytes.\n\n Returns:\n bytes: :class:`bytes` clone of the viewed slice.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_9BlockView_3__bytes__ = {"__bytes__", (PyCFunction)__pyx_pw_11cbytesparse_1c_9BlockView_3__bytes__, METH_NOARGS, __pyx_doc_11cbytesparse_1c_9BlockView_2__bytes__}; static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_3__bytes__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bytes__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_2__bytes__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_2__bytes__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { byte_t *__pyx_v_data; size_t __pyx_v_size; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bytes__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.BlockView.__bytes__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__63 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_data, __pyx_n_s_size); if (unlikely(!__pyx_tuple__63)) __PYX_ERR(0, 1871, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__63); __Pyx_GIVEREF(__pyx_tuple__63); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1871, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_BlockView) < 0) __PYX_ERR(0, 1871, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_bytes_2) < 0) __PYX_ERR(0, 1871, __pyx_L1_error) __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_9BlockView_3__bytes__, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_BlockView___bytes, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__64)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1871, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_BlockView->tp_dict, __pyx_n_s_bytes, __pyx_t_1) < 0) __PYX_ERR(0, 1871, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_BlockView); __pyx_codeobj__64 = (PyObject*)__Pyx_PyCode_New(1, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__63, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_bytes, 1871, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__64)) __PYX_ERR(0, 1871, __pyx_L1_error)
1872: self: BlockView,
1873: ) -> bytes:
1874: r"""Converts into bytes.
1875:
1876: Returns:
1877: bytes: :class:`bytes` clone of the viewed slice.
1878: """
1879: cdef:
1880: byte_t *data
1881: size_t size
1882:
+1883: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1883, __pyx_L1_error)
1884:
+1885: data = &self._block.data[self._start]
__pyx_v_data = (&(__pyx_v_self->_block->data[__pyx_v_self->_start]));
+1886: size = self._endex - self._start
__pyx_v_size = (__pyx_v_self->_endex - __pyx_v_self->_start);
+1887: if size > SIZE_HMAX:
__pyx_t_2 = ((__pyx_v_size > SIZE_HMAX) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+1888: raise OverflowError()
__pyx_t_3 = __Pyx_PyObject_CallNoArg(__pyx_builtin_OverflowError); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 1888, __pyx_L1_error)
1889:
+1890: return PyBytes_FromStringAndSize(<char*><void*>data, <ssize_t>size)
__Pyx_XDECREF(__pyx_r); __pyx_t_3 = PyBytes_FromStringAndSize(((char *)((void *)__pyx_v_data)), ((Py_ssize_t)__pyx_v_size)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1890, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = ((PyObject*)__pyx_t_3); __pyx_t_3 = 0; goto __pyx_L0;
1891:
+1892: def __cinit__(self: BlockView):
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_9BlockView_5__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static int __pyx_pw_11cbytesparse_1c_9BlockView_5__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__ (wrapper)", 0); if (unlikely(PyTuple_GET_SIZE(__pyx_args) > 0)) { __Pyx_RaiseArgtupleInvalid("__cinit__", 1, 0, 0, PyTuple_GET_SIZE(__pyx_args)); return -1;} if (unlikely(__pyx_kwds) && unlikely(PyDict_Size(__pyx_kwds) > 0) && unlikely(!__Pyx_CheckKeywordStrings(__pyx_kwds, "__cinit__", 0))) return -1; __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_4__cinit__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_9BlockView_4__cinit__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__", 0); /* … */ /* function exit code */ __pyx_r = 0; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+1893: self._block = NULL
__pyx_v_self->_block = NULL;
1894:
+1895: def __dealloc__(self: BlockView):
/* Python wrapper */ static void __pyx_pw_11cbytesparse_1c_9BlockView_7__dealloc__(PyObject *__pyx_v_self); /*proto*/ static void __pyx_pw_11cbytesparse_1c_9BlockView_7__dealloc__(PyObject *__pyx_v_self) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__dealloc__ (wrapper)", 0); __pyx_pf_11cbytesparse_1c_9BlockView_6__dealloc__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); } static void __pyx_pf_11cbytesparse_1c_9BlockView_6__dealloc__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__dealloc__", 0); /* … */ /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __Pyx_WriteUnraisable("cbytesparse.c.BlockView.__dealloc__", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0); __pyx_L0:; __Pyx_RefNannyFinishContext(); }
+1896: self.dispose_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->dispose_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1896, __pyx_L1_error)
1897:
+1898: def __getattr__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_9__getattr__(PyObject *__pyx_v_self, PyObject *__pyx_v_attr); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_9__getattr__(PyObject *__pyx_v_self, PyObject *__pyx_v_attr) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getattr__ (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_attr), (&PyUnicode_Type), 1, "attr", 1))) __PYX_ERR(0, 1900, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_8__getattr__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self), ((PyObject*)__pyx_v_attr)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_8__getattr__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self, PyObject *__pyx_v_attr) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getattr__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.BlockView.__getattr__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1899: self: BlockView,
1900: attr: str,
1901: ) -> Any:
1902:
+1903: return getattr(self.memview, attr)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_memview); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1903, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetAttr(__pyx_t_1, __pyx_v_attr); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1903, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
1904:
+1905: def __getbuffer__(self: BlockView, Py_buffer* buffer, int flags):
/* Python wrapper */ static CYTHON_UNUSED int __pyx_pw_11cbytesparse_1c_9BlockView_11__getbuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_buffer, int __pyx_v_flags); /*proto*/ static CYTHON_UNUSED int __pyx_pw_11cbytesparse_1c_9BlockView_11__getbuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_buffer, int __pyx_v_flags) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getbuffer__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_10__getbuffer__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self), ((Py_buffer *)__pyx_v_buffer), ((int)__pyx_v_flags)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_9BlockView_10__getbuffer__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self, Py_buffer *__pyx_v_buffer, int __pyx_v_flags) { int __pyx_v_CONTIGUOUS; int __pyx_r; if (__pyx_v_buffer == NULL) { PyErr_SetString(PyExc_BufferError, "PyObject_GetBuffer: view==NULL argument is obsolete"); return -1; } __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getbuffer__", 0); __pyx_v_buffer->obj = Py_None; __Pyx_INCREF(Py_None); __Pyx_GIVEREF(__pyx_v_buffer->obj); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.BlockView.__getbuffer__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; if (__pyx_v_buffer->obj != NULL) { __Pyx_GOTREF(__pyx_v_buffer->obj); __Pyx_DECREF(__pyx_v_buffer->obj); __pyx_v_buffer->obj = 0; } goto __pyx_L2; __pyx_L0:; if (__pyx_v_buffer->obj == Py_None) { __Pyx_GOTREF(__pyx_v_buffer->obj); __Pyx_DECREF(__pyx_v_buffer->obj); __pyx_v_buffer->obj = 0; } __pyx_L2:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1906: cdef:
+1907: int CONTIGUOUS = PyBUF_C_CONTIGUOUS | PyBUF_F_CONTIGUOUS | PyBUF_ANY_CONTIGUOUS
__pyx_v_CONTIGUOUS = ((PyBUF_C_CONTIGUOUS | PyBUF_F_CONTIGUOUS) | PyBUF_ANY_CONTIGUOUS);
1908:
1909: # if flags & PyBUF_WRITABLE:
1910: # raise ValueError('read only access')
1911:
+1912: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1912, __pyx_L1_error)
1913:
+1914: self._block = Block_Acquire(self._block)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_self->_block); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 1914, __pyx_L1_error)
__pyx_v_self->_block = __pyx_t_2;
1915:
+1916: buffer.buf = &self._block.data[self._start]
__pyx_v_buffer->buf = (&(__pyx_v_self->_block->data[__pyx_v_self->_start]));
+1917: buffer.obj = self
__Pyx_INCREF(((PyObject *)__pyx_v_self)); __Pyx_GIVEREF(((PyObject *)__pyx_v_self)); __Pyx_GOTREF(__pyx_v_buffer->obj); __Pyx_DECREF(__pyx_v_buffer->obj); __pyx_v_buffer->obj = ((PyObject *)__pyx_v_self);
+1918: buffer.len = self._endex - self._start
__pyx_v_buffer->len = (__pyx_v_self->_endex - __pyx_v_self->_start);
+1919: buffer.itemsize = 1
__pyx_v_buffer->itemsize = 1;
+1920: buffer.readonly = not (flags & PyBUF_WRITABLE)
__pyx_v_buffer->readonly = (!((__pyx_v_flags & PyBUF_WRITABLE) != 0));
+1921: buffer.ndim = 1
__pyx_v_buffer->ndim = 1;
+1922: buffer.format = <char*>'B' if flags & (PyBUF_FORMAT | CONTIGUOUS) else NULL
if (((__pyx_v_flags & (PyBUF_FORMAT | __pyx_v_CONTIGUOUS)) != 0)) { __pyx_t_3 = ((char *)((char *)"B")); } else { __pyx_t_3 = NULL; } __pyx_v_buffer->format = __pyx_t_3;
+1923: buffer.shape = &buffer.len if flags & (PyBUF_ND | CONTIGUOUS) else NULL
if (((__pyx_v_flags & (PyBUF_ND | __pyx_v_CONTIGUOUS)) != 0)) { __pyx_t_4 = (&__pyx_v_buffer->len); } else { __pyx_t_4 = NULL; } __pyx_v_buffer->shape = __pyx_t_4;
+1924: buffer.strides = &buffer.itemsize if flags & (PyBUF_STRIDES | CONTIGUOUS) else NULL
if (((__pyx_v_flags & (PyBUF_STRIDES | __pyx_v_CONTIGUOUS)) != 0)) { __pyx_t_4 = (&__pyx_v_buffer->itemsize); } else { __pyx_t_4 = NULL; } __pyx_v_buffer->strides = __pyx_t_4;
+1925: buffer.suboffsets = NULL
__pyx_v_buffer->suboffsets = NULL;
+1926: buffer.internal = NULL
__pyx_v_buffer->internal = NULL;
1927:
+1928: def __getitem__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_13__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_item); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_13__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_item) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_12__getitem__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self), ((PyObject *)__pyx_v_item)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_12__getitem__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self, PyObject *__pyx_v_item) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.BlockView.__getitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1929: self: BlockView,
1930: item: Any,
1931: ) -> Any:
1932:
+1933: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1933, __pyx_L1_error)
+1934: return self.memview[item]
__Pyx_XDECREF(__pyx_r); __pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_memview); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1934, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_v_item); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1934, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
1935:
+1936: def __len__(
/* Python wrapper */ static Py_ssize_t __pyx_pw_11cbytesparse_1c_9BlockView_15__len__(PyObject *__pyx_v_self); /*proto*/ static char __pyx_doc_11cbytesparse_1c_9BlockView_14__len__[] = "int: Slice length."; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_9BlockView_14__len__; #endif static Py_ssize_t __pyx_pw_11cbytesparse_1c_9BlockView_15__len__(PyObject *__pyx_v_self) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__len__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_14__len__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static Py_ssize_t __pyx_pf_11cbytesparse_1c_9BlockView_14__len__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__len__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.BlockView.__len__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
1937: self: BlockView,
1938: ) -> Address:
1939: r"""int: Slice length."""
1940:
+1941: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1941, __pyx_L1_error)
+1942: return self._endex - self._start
__pyx_r = (__pyx_v_self->_endex - __pyx_v_self->_start); goto __pyx_L0;
1943:
+1944: def __releasebuffer__(self: BlockView, Py_buffer* buffer):
/* Python wrapper */ static CYTHON_UNUSED void __pyx_pw_11cbytesparse_1c_9BlockView_17__releasebuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_buffer); /*proto*/ static CYTHON_UNUSED void __pyx_pw_11cbytesparse_1c_9BlockView_17__releasebuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_buffer) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__releasebuffer__ (wrapper)", 0); __pyx_pf_11cbytesparse_1c_9BlockView_16__releasebuffer__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self), ((Py_buffer *)__pyx_v_buffer)); /* function exit code */ __Pyx_RefNannyFinishContext(); } static void __pyx_pf_11cbytesparse_1c_9BlockView_16__releasebuffer__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self, CYTHON_UNUSED Py_buffer *__pyx_v_buffer) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__releasebuffer__", 0); /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); }
+1945: if self._block:
__pyx_t_1 = (__pyx_v_self->_block != 0); if (__pyx_t_1) { /* … */ }
+1946: self._block = Block_Release_(self._block)
__pyx_v_self->_block = __pyx_f_11cbytesparse_1c_Block_Release_(__pyx_v_self->_block);
1947:
+1948: def __repr__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_19__repr__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_19__repr__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__repr__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_18__repr__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_18__repr__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__repr__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.BlockView.__repr__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1949: self: BlockView,
1950: ) -> str:
1951:
+1952: return repr(self.__str__())
__Pyx_XDECREF(__pyx_r); __pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_str); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1952, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_2, function); } } __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1952, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Repr(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1952, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
1953:
+1954: def __str__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_21__str__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_21__str__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__str__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_20__str__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_20__str__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { Block_ const *__pyx_v_block; size_t __pyx_v_size; addr_t __pyx_v_start; addr_t __pyx_v_endex; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__str__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_10); __Pyx_AddTraceback("cbytesparse.c.BlockView.__str__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1955: self: BlockView,
1956: ) -> str:
1957: cdef:
+1958: const Block_* block = self._block
__pyx_t_1 = __pyx_v_self->_block; __pyx_v_block = __pyx_t_1;
+1959: size_t size = self._endex - self._start
__pyx_v_size = (__pyx_v_self->_endex - __pyx_v_self->_start);
1960: addr_t start
1961: addr_t endex
1962:
+1963: self.check_()
__pyx_t_2 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1963, __pyx_L1_error)
1964:
+1965: if size > STR_MAX_CONTENT_SIZE:
__pyx_t_3 = __Pyx_PyInt_FromSize_t(__pyx_v_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1965, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_STR_MAX_CONTENT_SIZE); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1965, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_5 = PyObject_RichCompare(__pyx_t_3, __pyx_t_4, Py_GT); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1965, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_6 < 0)) __PYX_ERR(0, 1965, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_6) { /* … */ }
+1966: start = block.address
__pyx_t_7 = __pyx_v_block->address; __pyx_v_start = __pyx_t_7;
+1967: CheckAddAddrU(start, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start, __pyx_v_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1967, __pyx_L1_error)
+1968: endex = start + size
__pyx_v_endex = (__pyx_v_start + __pyx_v_size);
+1969: return f'<{type(self).__name__}[0x{start:X}:0x{endex:X}]@0x{<uintptr_t><void*>self:X}>'
__Pyx_XDECREF(__pyx_r); __pyx_t_5 = PyTuple_New(9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_8 = 0; __pyx_t_9 = 127; __Pyx_INCREF(__pyx_kp_u__10); __pyx_t_8 += 1; __Pyx_GIVEREF(__pyx_kp_u__10); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_kp_u__10); __pyx_t_4 = __Pyx_PyObject_GetAttrStr(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))), __pyx_n_s_name); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __Pyx_PyObject_FormatSimple(__pyx_t_4, __pyx_empty_unicode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_9 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3) > __pyx_t_9) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3) : __pyx_t_9; __pyx_t_8 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_3); __pyx_t_3 = 0; __Pyx_INCREF(__pyx_kp_u_0x); __pyx_t_8 += 3; __Pyx_GIVEREF(__pyx_kp_u_0x); PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_kp_u_0x); __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_start); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyObject_Format(__pyx_t_3, __pyx_n_u_X); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_9 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_9) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_9; __pyx_t_8 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_5, 3, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u_0x_2); __pyx_t_8 += 3; __Pyx_GIVEREF(__pyx_kp_u_0x_2); PyTuple_SET_ITEM(__pyx_t_5, 4, __pyx_kp_u_0x_2); __pyx_t_4 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_endex); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __Pyx_PyObject_Format(__pyx_t_4, __pyx_n_u_X); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_9 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3) > __pyx_t_9) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3) : __pyx_t_9; __pyx_t_8 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 5, __pyx_t_3); __pyx_t_3 = 0; __Pyx_INCREF(__pyx_kp_u_0x_3); __pyx_t_8 += 4; __Pyx_GIVEREF(__pyx_kp_u_0x_3); PyTuple_SET_ITEM(__pyx_t_5, 6, __pyx_kp_u_0x_3); __pyx_t_3 = __Pyx_PyInt_FromSize_t(((uintptr_t)((void *)__pyx_v_self))); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyObject_Format(__pyx_t_3, __pyx_n_u_X); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_9 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_9) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_9; __pyx_t_8 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_5, 7, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u__11); __pyx_t_8 += 1; __Pyx_GIVEREF(__pyx_kp_u__11); PyTuple_SET_ITEM(__pyx_t_5, 8, __pyx_kp_u__11); __pyx_t_4 = __Pyx_PyUnicode_Join(__pyx_t_5, 9, __pyx_t_8, __pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1969, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0;
1970: else:
+1971: return self.__bytes__().decode('ascii')
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_bytes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1971, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_10 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_3); if (likely(__pyx_t_10)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_10); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_3, function); } } __pyx_t_5 = (__pyx_t_10) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_10) : __Pyx_PyObject_CallNoArg(__pyx_t_3); __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1971, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_n_s_decode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1971, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_5 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3); if (likely(__pyx_t_5)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_5); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_3, function); } } __pyx_t_4 = (__pyx_t_5) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_5, __pyx_n_u_ascii) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_n_u_ascii); __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1971, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; }
1972:
1973: @property
+1974: def acquired(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_8acquired_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_8acquired_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_8acquired___get__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_8acquired___get__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.BlockView.acquired.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
1975: self: BlockView,
1976: ) -> bool:
1977: r"""bool: Underlying block currently acquired."""
1978:
+1979: return self._block != NULL
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyBool_FromLong((__pyx_v_self->_block != NULL)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1979, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
1980:
+1981: def check(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_23check(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_9BlockView_22check[] = "BlockView.check(self: BlockView) -> None\nChecks for data consistency."; static PyMethodDef __pyx_mdef_11cbytesparse_1c_9BlockView_23check = {"check", (PyCFunction)__pyx_pw_11cbytesparse_1c_9BlockView_23check, METH_NOARGS, __pyx_doc_11cbytesparse_1c_9BlockView_22check}; static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_23check(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("check (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_22check(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_22check(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("check", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.BlockView.check", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__65 = PyTuple_Pack(1, __pyx_n_s_self); if (unlikely(!__pyx_tuple__65)) __PYX_ERR(0, 1981, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__65); __Pyx_GIVEREF(__pyx_tuple__65); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1981, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_BlockView) < 0) __PYX_ERR(0, 1981, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_9BlockView_23check, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_BlockView_check, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__66)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1981, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_BlockView->tp_dict, __pyx_n_s_check, __pyx_t_2) < 0) __PYX_ERR(0, 1981, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_BlockView); __pyx_codeobj__66 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__65, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_check, 1981, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__66)) __PYX_ERR(0, 1981, __pyx_L1_error)
1982: self: BlockView,
+1983: ) -> None:
if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 1981, __pyx_L1_error)
1984: r"""Checks for data consistency."""
1985:
+1986: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1986, __pyx_L1_error)
1987:
+1988: def dispose(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_25dispose(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_9BlockView_24dispose[] = "BlockView.dispose(self: BlockView) -> None\nForces object disposal.\n\n Useful to make sure that any memory blocks are unreferenced before automatic\n garbage collection.\n\n Any access to the object after calling this function could raise exceptions.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_9BlockView_25dispose = {"dispose", (PyCFunction)__pyx_pw_11cbytesparse_1c_9BlockView_25dispose, METH_NOARGS, __pyx_doc_11cbytesparse_1c_9BlockView_24dispose}; static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_25dispose(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("dispose (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_24dispose(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_24dispose(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("dispose", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.BlockView.dispose", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__67 = PyTuple_Pack(1, __pyx_n_s_self); if (unlikely(!__pyx_tuple__67)) __PYX_ERR(0, 1988, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__67); __Pyx_GIVEREF(__pyx_tuple__67); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1988, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_BlockView) < 0) __PYX_ERR(0, 1988, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_9BlockView_25dispose, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_BlockView_dispose, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__68)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1988, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_BlockView->tp_dict, __pyx_n_s_dispose, __pyx_t_1) < 0) __PYX_ERR(0, 1988, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_BlockView); __pyx_codeobj__68 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__67, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_dispose, 1988, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__68)) __PYX_ERR(0, 1988, __pyx_L1_error)
1989: self: BlockView,
+1990: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 1988, __pyx_L1_error)
1991: r"""Forces object disposal.
1992:
1993: Useful to make sure that any memory blocks are unreferenced before automatic
1994: garbage collection.
1995:
1996: Any access to the object after calling this function could raise exceptions.
1997: """
1998:
+1999: self.dispose_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->dispose_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 1999, __pyx_L1_error)
2000:
2001: @property
+2002: def endex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_5endex_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_5endex_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_5endex___get__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_5endex___get__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.BlockView.endex.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
2003: self: BlockView,
2004: ) -> Address:
2005: r"""int: Slice exclusive end address."""
2006:
+2007: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2007, __pyx_L1_error)
+2008: return self._block.address + self._endex - self._start
__Pyx_XDECREF(__pyx_r); __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(((__pyx_v_self->_block->address + __pyx_v_self->_endex) - __pyx_v_self->_start)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2008, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
2009:
2010: @property
+2011: def endin(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_5endin_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_5endin_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_5endin___get__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_5endin___get__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.BlockView.endin.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
2012: self: BlockView,
2013: ) -> Address:
2014: r"""int: Slice inclusive end address."""
2015:
+2016: return self.endex - 1
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2016, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_PyInt_SubtractObjC(__pyx_t_1, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2016, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
2017:
2018: @property
+2019: def memview(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_7memview_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_7memview_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_7memview___get__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_7memview___get__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { byte_t *__pyx_v_data; size_t __pyx_v_size; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(((PyObject *)__pyx_t_4)); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.BlockView.memview.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
2020: self: BlockView,
2021: ) -> memoryview:
2022: r"""memoryview: Python :class:`memoryview` wrapper."""
2023: cdef:
2024: byte_t *data
2025: size_t size
2026: byte_t[:] view
2027:
+2028: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2028, __pyx_L1_error)
2029:
+2030: if self._memview is None:
__pyx_t_2 = (__pyx_v_self->_memview == Py_None); __pyx_t_3 = (__pyx_t_2 != 0); if (__pyx_t_3) { /* … */ }
+2031: data = &self._block.data[self._start]
__pyx_v_data = (&(__pyx_v_self->_block->data[__pyx_v_self->_start]));
+2032: size = self._endex - self._start
__pyx_v_size = (__pyx_v_self->_endex - __pyx_v_self->_start);
2033:
+2034: if size > 0:
__pyx_t_3 = ((__pyx_v_size > 0) != 0); if (__pyx_t_3) { /* … */ goto __pyx_L4; }
+2035: self._memview = <byte_t[:size]>data
if (!__pyx_v_data) { PyErr_SetString(PyExc_ValueError,"Cannot create cython.array from NULL pointer"); __PYX_ERR(0, 2035, __pyx_L1_error) } __pyx_t_6 = __pyx_format_from_typeinfo(&__Pyx_TypeInfo_nn_byte_t); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 2035, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = Py_BuildValue((char*) "(" __PYX_BUILD_PY_SSIZE_T ")", ((Py_ssize_t)__pyx_v_size)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 2035, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_4 = __pyx_array_new(__pyx_t_5, sizeof(byte_t), PyBytes_AS_STRING(__pyx_t_6), (char *) "c", (char *) __pyx_v_data); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2035, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_GIVEREF(((PyObject *)__pyx_t_4)); __Pyx_GOTREF(__pyx_v_self->_memview); __Pyx_DECREF(__pyx_v_self->_memview); __pyx_v_self->_memview = ((PyObject *)__pyx_t_4); __pyx_t_4 = 0;
2036: else:
+2037: self._memview = b''
/*else*/ { __Pyx_INCREF(__pyx_kp_b__12); __Pyx_GIVEREF(__pyx_kp_b__12); __Pyx_GOTREF(__pyx_v_self->_memview); __Pyx_DECREF(__pyx_v_self->_memview); __pyx_v_self->_memview = __pyx_kp_b__12; } __pyx_L4:;
2038:
+2039: return self._memview
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_self->_memview); __pyx_r = __pyx_v_self->_memview; goto __pyx_L0;
2040:
2041: @property
+2042: def start(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_5start_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_9BlockView_5start_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_9BlockView_5start___get__(((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_9BlockView_5start___get__(struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.BlockView.start.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
2043: self: BlockView,
2044: ) -> Address:
2045: r"""int: Slice inclusive start address."""
2046:
+2047: self.check_()
__pyx_t_1 = ((struct __pyx_vtabstruct_11cbytesparse_1c_BlockView *)__pyx_v_self->__pyx_vtab)->check_(__pyx_v_self); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2047, __pyx_L1_error)
+2048: return self._block.address
__Pyx_XDECREF(__pyx_r); __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_self->_block->address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2048, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
2049:
2050:
2051: # =====================================================================================================================
2052:
+2053: cdef Rack_* Rack_Alloc(size_t size) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Alloc(size_t __pyx_v_size) { Rack_ *__pyx_v_that; size_t __pyx_v_allocated; size_t __pyx_v_actual; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Alloc", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_Alloc", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2054: cdef:
+2055: Rack_* that = NULL
__pyx_v_that = NULL;
2056: size_t allocated
2057: size_t actual
2058:
+2059: if size > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_size > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2060: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2060, __pyx_L1_error)
2061:
2062: # Allocate as per request
+2063: allocated = Upsize(0, size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Upsize(0, __pyx_v_size);
+2064: if allocated > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2065: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2065, __pyx_L1_error)
2066:
+2067: actual = Rack_HEADING + (allocated * sizeof(Block_*))
__pyx_v_actual = (Rack_HEADING + (__pyx_v_allocated * (sizeof(Block_ *))));
+2068: that = <Rack_*>PyMem_Calloc(actual, 1)
__pyx_v_that = ((Rack_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(__pyx_v_actual, 1));
+2069: if that == NULL:
__pyx_t_1 = ((__pyx_v_that == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2070: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2070, __pyx_L1_error)
2071:
+2072: that.allocated = allocated
__pyx_v_that->allocated = __pyx_v_allocated;
+2073: that.start = MARGIN # leave some initial room
__pyx_v_that->start = MARGIN;
+2074: that.endex = that.start + size
__pyx_v_that->endex = (__pyx_v_that->start + __pyx_v_size);
+2075: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2076:
2077:
+2078: cdef Rack_* Rack_Free(Rack_* that):
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Free(Rack_ *__pyx_v_that) { size_t __pyx_v_index; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Free", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2079: cdef:
2080: size_t index
2081:
+2082: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (__pyx_t_1) { /* … */ }
2083: # Decrement data referencing
+2084: for index in range(that.start, that.endex):
__pyx_t_2 = __pyx_v_that->endex; __pyx_t_3 = __pyx_t_2; for (__pyx_t_4 = __pyx_v_that->start; __pyx_t_4 < __pyx_t_3; __pyx_t_4+=1) { __pyx_v_index = __pyx_t_4;
+2085: that.blocks[index] = Block_Release(that.blocks[index])
(__pyx_v_that->blocks[__pyx_v_index]) = __pyx_f_11cbytesparse_1c_Block_Release((__pyx_v_that->blocks[__pyx_v_index])); }
+2086: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
+2087: return NULL
__pyx_r = NULL; goto __pyx_L0;
2088:
2089:
+2090: cdef Rack_* Rack_ShallowCopy(const Rack_* other) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_ShallowCopy(Rack_ const *__pyx_v_other) { Rack_ *__pyx_v_that; size_t __pyx_v_start1; size_t __pyx_v_start2; size_t __pyx_v_offset; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_ShallowCopy", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_AddTraceback("cbytesparse.c.Rack_ShallowCopy", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2091: cdef:
+2092: Rack_* that = Rack_Alloc(other.endex - other.start)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Alloc((__pyx_v_other->endex - __pyx_v_other->start)); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2092, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2093: size_t start1 = that.start
__pyx_t_2 = __pyx_v_that->start; __pyx_v_start1 = __pyx_t_2;
+2094: size_t start2 = other.start
__pyx_t_2 = __pyx_v_other->start; __pyx_v_start2 = __pyx_t_2;
2095: size_t offset
2096:
+2097: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L8_try_end; __pyx_L3_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5); goto __pyx_L1_error; __pyx_L8_try_end:; }
+2098: for offset in range(that.endex - that.start):
__pyx_t_2 = (__pyx_v_that->endex - __pyx_v_that->start); __pyx_t_6 = __pyx_t_2; for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) { __pyx_v_offset = __pyx_t_7;
+2099: that.blocks[start1 + offset] = Block_Acquire(other.blocks[start2 + offset])
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_other->blocks[(__pyx_v_start2 + __pyx_v_offset)])); if (unlikely(__pyx_t_8 == ((Block_ *)NULL))) __PYX_ERR(0, 2099, __pyx_L3_error)
(__pyx_v_that->blocks[(__pyx_v_start1 + __pyx_v_offset)]) = __pyx_t_8;
}
+2100: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Rack_ShallowCopy", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_9, &__pyx_t_10, &__pyx_t_11) < 0) __PYX_ERR(0, 2100, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11);
+2101: that = Rack_Free(that)
__pyx_v_that = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_that);
+2102: raise
__Pyx_GIVEREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_ErrRestoreWithState(__pyx_t_9, __pyx_t_10, __pyx_t_11); __pyx_t_9 = 0; __pyx_t_10 = 0; __pyx_t_11 = 0; __PYX_ERR(0, 2102, __pyx_L5_except_error) } __pyx_L5_except_error:;
+2103: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2104:
2105:
+2106: cdef Rack_* Rack_Copy(const Rack_* other) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Copy(Rack_ const *__pyx_v_other) { Rack_ *__pyx_v_that; size_t __pyx_v_start1; size_t __pyx_v_start2; size_t __pyx_v_offset; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Copy", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_AddTraceback("cbytesparse.c.Rack_Copy", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2107: cdef:
+2108: Rack_* that = Rack_Alloc(other.endex - other.start)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Alloc((__pyx_v_other->endex - __pyx_v_other->start)); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2108, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2109: size_t start1 = that.start
__pyx_t_2 = __pyx_v_that->start; __pyx_v_start1 = __pyx_t_2;
+2110: size_t start2 = other.start
__pyx_t_2 = __pyx_v_other->start; __pyx_v_start2 = __pyx_t_2;
2111: size_t offset
2112:
+2113: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L8_try_end; __pyx_L3_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5); goto __pyx_L1_error; __pyx_L8_try_end:; }
+2114: for offset in range(that.endex - that.start):
__pyx_t_2 = (__pyx_v_that->endex - __pyx_v_that->start); __pyx_t_6 = __pyx_t_2; for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) { __pyx_v_offset = __pyx_t_7;
+2115: that.blocks[start1 + offset] = Block_Copy(other.blocks[start2 + offset])
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Block_Copy((__pyx_v_other->blocks[(__pyx_v_start2 + __pyx_v_offset)])); if (unlikely(__pyx_t_8 == ((Block_ *)NULL))) __PYX_ERR(0, 2115, __pyx_L3_error)
(__pyx_v_that->blocks[(__pyx_v_start1 + __pyx_v_offset)]) = __pyx_t_8;
}
+2116: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Rack_Copy", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_9, &__pyx_t_10, &__pyx_t_11) < 0) __PYX_ERR(0, 2116, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11);
+2117: that = Rack_Free(that)
__pyx_v_that = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_that);
+2118: raise
__Pyx_GIVEREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_ErrRestoreWithState(__pyx_t_9, __pyx_t_10, __pyx_t_11); __pyx_t_9 = 0; __pyx_t_10 = 0; __pyx_t_11 = 0; __PYX_ERR(0, 2118, __pyx_L5_except_error) } __pyx_L5_except_error:;
+2119: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2120:
2121:
+2122: cdef Rack_* Rack_FromObject(object obj, saddr_t offset) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_FromObject(PyObject *__pyx_v_obj, saddr_t __pyx_v_offset) { Rack_ *__pyx_v_that; size_t __pyx_v_size; size_t __pyx_v_index; addr_t __pyx_v_address; PyObject *__pyx_v_data = NULL; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_FromObject", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_12); __Pyx_XDECREF(__pyx_t_13); __Pyx_XDECREF(__pyx_t_14); __Pyx_XDECREF(__pyx_t_15); __Pyx_XDECREF(__pyx_t_22); __Pyx_XDECREF(__pyx_t_23); __Pyx_XDECREF(__pyx_t_24); __Pyx_AddTraceback("cbytesparse.c.Rack_FromObject", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_data); __Pyx_RefNannyFinishContext(); return __pyx_r; }
2123: cdef:
+2124: Rack_* that = NULL
__pyx_v_that = NULL;
2125: size_t size
2126: size_t index
2127: addr_t address
2128:
+2129: try:
{ /*try:*/ { /* … */ } __pyx_L3_error:; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; __Pyx_XDECREF(__pyx_t_22); __pyx_t_22 = 0; __Pyx_XDECREF(__pyx_t_23); __pyx_t_23 = 0; __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L1_error; __pyx_L7_try_return:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L0; }
+2130: try:
{ /*try:*/ { /* … */ } /* … */ __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6); goto __pyx_L3_error; __pyx_L10_exception_handled:; __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6); __pyx_L14_try_end:; }
+2131: size = len(obj)
__pyx_t_7 = PyObject_Length(__pyx_v_obj); if (unlikely(__pyx_t_7 == ((Py_ssize_t)-1))) __PYX_ERR(0, 2131, __pyx_L9_error) __pyx_v_size = __pyx_t_7;
+2132: except TypeError:
__pyx_t_21 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError); if (__pyx_t_21) { __Pyx_AddTraceback("cbytesparse.c.Rack_FromObject", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_10, &__pyx_t_12, &__pyx_t_14) < 0) __PYX_ERR(0, 2132, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_12); __Pyx_GOTREF(__pyx_t_14);
+2133: that = Rack_Alloc(0)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Rack_Alloc(0); if (unlikely(__pyx_t_8 == ((Rack_ *)NULL))) __PYX_ERR(0, 2133, __pyx_L11_except_error)
__pyx_v_that = __pyx_t_8;
+2134: for address, data in obj:
if (likely(PyList_CheckExact(__pyx_v_obj)) || PyTuple_CheckExact(__pyx_v_obj)) { __pyx_t_13 = __pyx_v_obj; __Pyx_INCREF(__pyx_t_13); __pyx_t_7 = 0; __pyx_t_11 = NULL; } else { __pyx_t_7 = -1; __pyx_t_13 = PyObject_GetIter(__pyx_v_obj); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_11 = Py_TYPE(__pyx_t_13)->tp_iternext; if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 2134, __pyx_L11_except_error) } for (;;) { if (likely(!__pyx_t_11)) { if (likely(PyList_CheckExact(__pyx_t_13))) { if (__pyx_t_7 >= PyList_GET_SIZE(__pyx_t_13)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_15 = PyList_GET_ITEM(__pyx_t_13, __pyx_t_7); __Pyx_INCREF(__pyx_t_15); __pyx_t_7++; if (unlikely(0 < 0)) __PYX_ERR(0, 2134, __pyx_L11_except_error) #else __pyx_t_15 = PySequence_ITEM(__pyx_t_13, __pyx_t_7); __pyx_t_7++; if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_15); #endif } else { if (__pyx_t_7 >= PyTuple_GET_SIZE(__pyx_t_13)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_15 = PyTuple_GET_ITEM(__pyx_t_13, __pyx_t_7); __Pyx_INCREF(__pyx_t_15); __pyx_t_7++; if (unlikely(0 < 0)) __PYX_ERR(0, 2134, __pyx_L11_except_error) #else __pyx_t_15 = PySequence_ITEM(__pyx_t_13, __pyx_t_7); __pyx_t_7++; if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_15); #endif } } else { __pyx_t_15 = __pyx_t_11(__pyx_t_13); if (unlikely(!__pyx_t_15)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); else __PYX_ERR(0, 2134, __pyx_L11_except_error) } break; } __Pyx_GOTREF(__pyx_t_15); } if ((likely(PyTuple_CheckExact(__pyx_t_15))) || (PyList_CheckExact(__pyx_t_15))) { PyObject* sequence = __pyx_t_15; Py_ssize_t size = __Pyx_PySequence_SIZE(sequence); if (unlikely(size != 2)) { if (size > 2) __Pyx_RaiseTooManyValuesError(2); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); __PYX_ERR(0, 2134, __pyx_L11_except_error) } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS if (likely(PyTuple_CheckExact(sequence))) { __pyx_t_22 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_23 = PyTuple_GET_ITEM(sequence, 1); } else { __pyx_t_22 = PyList_GET_ITEM(sequence, 0); __pyx_t_23 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_22); __Pyx_INCREF(__pyx_t_23); #else __pyx_t_22 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_22)) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_22); __pyx_t_23 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_23)) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_23); #endif __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; } else { Py_ssize_t index = -1; __pyx_t_24 = PyObject_GetIter(__pyx_t_15); if (unlikely(!__pyx_t_24)) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_24); __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; __pyx_t_16 = Py_TYPE(__pyx_t_24)->tp_iternext; index = 0; __pyx_t_22 = __pyx_t_16(__pyx_t_24); if (unlikely(!__pyx_t_22)) goto __pyx_L24_unpacking_failed; __Pyx_GOTREF(__pyx_t_22); index = 1; __pyx_t_23 = __pyx_t_16(__pyx_t_24); if (unlikely(!__pyx_t_23)) goto __pyx_L24_unpacking_failed; __Pyx_GOTREF(__pyx_t_23); if (__Pyx_IternextUnpackEndCheck(__pyx_t_16(__pyx_t_24), 2) < 0) __PYX_ERR(0, 2134, __pyx_L11_except_error) __pyx_t_16 = NULL; __Pyx_DECREF(__pyx_t_24); __pyx_t_24 = 0; goto __pyx_L25_unpacking_done; __pyx_L24_unpacking_failed:; __Pyx_DECREF(__pyx_t_24); __pyx_t_24 = 0; __pyx_t_16 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); __PYX_ERR(0, 2134, __pyx_L11_except_error) __pyx_L25_unpacking_done:; } __pyx_t_17 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_22); if (unlikely((__pyx_t_17 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 2134, __pyx_L11_except_error) __Pyx_DECREF(__pyx_t_22); __pyx_t_22 = 0; __pyx_v_address = __pyx_t_17; __Pyx_XDECREF_SET(__pyx_v_data, __pyx_t_23); __pyx_t_23 = 0; /* … */ } __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L10_exception_handled; } goto __pyx_L11_except_error; __pyx_L11_except_error:;
+2135: if offset < 0:
__pyx_t_18 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_18) { /* … */ goto __pyx_L26; }
+2136: CheckSubAddrU(address, <addr_t>-offset)
__pyx_t_19 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_address, ((addr_t)(-__pyx_v_offset))); if (unlikely(__pyx_t_19 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2136, __pyx_L11_except_error)
+2137: address -= <addr_t>-offset
__pyx_v_address = (__pyx_v_address - ((addr_t)(-__pyx_v_offset)));
+2138: elif offset > 0:
__pyx_t_18 = ((__pyx_v_offset > 0) != 0); if (__pyx_t_18) { /* … */ } __pyx_L26:;
+2139: CheckAddAddrU(address, <addr_t>offset)
__pyx_t_19 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, ((addr_t)__pyx_v_offset)); if (unlikely(__pyx_t_19 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2139, __pyx_L11_except_error)
+2140: address += <addr_t>offset
__pyx_v_address = (__pyx_v_address + ((addr_t)__pyx_v_offset));
+2141: that = Rack_Append(that, Block_FromObject(address, data, True))
__pyx_t_20 = __pyx_f_11cbytesparse_1c_Block_FromObject(__pyx_v_address, __pyx_v_data, 1); if (unlikely(__pyx_t_20 == ((Block_ *)NULL))) __PYX_ERR(0, 2141, __pyx_L11_except_error) __pyx_t_8 = __pyx_f_11cbytesparse_1c_Rack_Append(__pyx_v_that, __pyx_t_20); if (unlikely(__pyx_t_8 == ((Rack_ *)NULL))) __PYX_ERR(0, 2141, __pyx_L11_except_error) __pyx_v_that = __pyx_t_8;
2142: else:
+2143: that = Rack_Alloc(size)
/*else:*/ {
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Rack_Alloc(__pyx_v_size); if (unlikely(__pyx_t_8 == ((Rack_ *)NULL))) __PYX_ERR(0, 2143, __pyx_L11_except_error)
__pyx_v_that = __pyx_t_8;
+2144: index = that.start
__pyx_t_9 = __pyx_v_that->start; __pyx_v_index = __pyx_t_9;
+2145: for address, data in obj:
if (likely(PyList_CheckExact(__pyx_v_obj)) || PyTuple_CheckExact(__pyx_v_obj)) { __pyx_t_10 = __pyx_v_obj; __Pyx_INCREF(__pyx_t_10); __pyx_t_7 = 0; __pyx_t_11 = NULL; } else { __pyx_t_7 = -1; __pyx_t_10 = PyObject_GetIter(__pyx_v_obj); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_10); __pyx_t_11 = Py_TYPE(__pyx_t_10)->tp_iternext; if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 2145, __pyx_L11_except_error) } for (;;) { if (likely(!__pyx_t_11)) { if (likely(PyList_CheckExact(__pyx_t_10))) { if (__pyx_t_7 >= PyList_GET_SIZE(__pyx_t_10)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_12 = PyList_GET_ITEM(__pyx_t_10, __pyx_t_7); __Pyx_INCREF(__pyx_t_12); __pyx_t_7++; if (unlikely(0 < 0)) __PYX_ERR(0, 2145, __pyx_L11_except_error) #else __pyx_t_12 = PySequence_ITEM(__pyx_t_10, __pyx_t_7); __pyx_t_7++; if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_12); #endif } else { if (__pyx_t_7 >= PyTuple_GET_SIZE(__pyx_t_10)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_12 = PyTuple_GET_ITEM(__pyx_t_10, __pyx_t_7); __Pyx_INCREF(__pyx_t_12); __pyx_t_7++; if (unlikely(0 < 0)) __PYX_ERR(0, 2145, __pyx_L11_except_error) #else __pyx_t_12 = PySequence_ITEM(__pyx_t_10, __pyx_t_7); __pyx_t_7++; if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_12); #endif } } else { __pyx_t_12 = __pyx_t_11(__pyx_t_10); if (unlikely(!__pyx_t_12)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); else __PYX_ERR(0, 2145, __pyx_L11_except_error) } break; } __Pyx_GOTREF(__pyx_t_12); } if ((likely(PyTuple_CheckExact(__pyx_t_12))) || (PyList_CheckExact(__pyx_t_12))) { PyObject* sequence = __pyx_t_12; Py_ssize_t size = __Pyx_PySequence_SIZE(sequence); if (unlikely(size != 2)) { if (size > 2) __Pyx_RaiseTooManyValuesError(2); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); __PYX_ERR(0, 2145, __pyx_L11_except_error) } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS if (likely(PyTuple_CheckExact(sequence))) { __pyx_t_13 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_14 = PyTuple_GET_ITEM(sequence, 1); } else { __pyx_t_13 = PyList_GET_ITEM(sequence, 0); __pyx_t_14 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_13); __Pyx_INCREF(__pyx_t_14); #else __pyx_t_13 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_14 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_14); #endif __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; } else { Py_ssize_t index = -1; __pyx_t_15 = PyObject_GetIter(__pyx_t_12); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_15); __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; __pyx_t_16 = Py_TYPE(__pyx_t_15)->tp_iternext; index = 0; __pyx_t_13 = __pyx_t_16(__pyx_t_15); if (unlikely(!__pyx_t_13)) goto __pyx_L17_unpacking_failed; __Pyx_GOTREF(__pyx_t_13); index = 1; __pyx_t_14 = __pyx_t_16(__pyx_t_15); if (unlikely(!__pyx_t_14)) goto __pyx_L17_unpacking_failed; __Pyx_GOTREF(__pyx_t_14); if (__Pyx_IternextUnpackEndCheck(__pyx_t_16(__pyx_t_15), 2) < 0) __PYX_ERR(0, 2145, __pyx_L11_except_error) __pyx_t_16 = NULL; __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; goto __pyx_L18_unpacking_done; __pyx_L17_unpacking_failed:; __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; __pyx_t_16 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); __PYX_ERR(0, 2145, __pyx_L11_except_error) __pyx_L18_unpacking_done:; } __pyx_t_17 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_13); if (unlikely((__pyx_t_17 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 2145, __pyx_L11_except_error) __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; __pyx_v_address = __pyx_t_17; __Pyx_XDECREF_SET(__pyx_v_data, __pyx_t_14); __pyx_t_14 = 0; /* … */ } __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; } __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; goto __pyx_L14_try_end; __pyx_L9_error:;
+2146: if offset < 0:
__pyx_t_18 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_18) { /* … */ goto __pyx_L19; }
+2147: CheckSubAddrU(address, <addr_t>-offset)
__pyx_t_19 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_address, ((addr_t)(-__pyx_v_offset))); if (unlikely(__pyx_t_19 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2147, __pyx_L11_except_error)
+2148: address -= <addr_t>-offset
__pyx_v_address = (__pyx_v_address - ((addr_t)(-__pyx_v_offset)));
+2149: elif offset > 0:
__pyx_t_18 = ((__pyx_v_offset > 0) != 0); if (__pyx_t_18) { /* … */ } __pyx_L19:;
+2150: CheckAddAddrU(address, <addr_t>offset)
__pyx_t_19 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, ((addr_t)__pyx_v_offset)); if (unlikely(__pyx_t_19 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2150, __pyx_L11_except_error)
+2151: address += <addr_t>offset
__pyx_v_address = (__pyx_v_address + ((addr_t)__pyx_v_offset));
+2152: that.blocks[index] = Block_FromObject(address, data, True)
__pyx_t_20 = __pyx_f_11cbytesparse_1c_Block_FromObject(__pyx_v_address, __pyx_v_data, 1); if (unlikely(__pyx_t_20 == ((Block_ *)NULL))) __PYX_ERR(0, 2152, __pyx_L11_except_error)
(__pyx_v_that->blocks[__pyx_v_index]) = __pyx_t_20;
+2153: index += 1
__pyx_v_index = (__pyx_v_index + 1);
+2154: return that
__pyx_r = __pyx_v_that; goto __pyx_L7_try_return;
2155:
+2156: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Rack_FromObject", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_14, &__pyx_t_12, &__pyx_t_10) < 0) __PYX_ERR(0, 2156, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_14); __Pyx_GOTREF(__pyx_t_12); __Pyx_GOTREF(__pyx_t_10);
+2157: that = Rack_Free(that)
__pyx_v_that = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_that);
+2158: raise
__Pyx_GIVEREF(__pyx_t_14); __Pyx_GIVEREF(__pyx_t_12); __Pyx_XGIVEREF(__pyx_t_10); __Pyx_ErrRestoreWithState(__pyx_t_14, __pyx_t_12, __pyx_t_10); __pyx_t_14 = 0; __pyx_t_12 = 0; __pyx_t_10 = 0; __PYX_ERR(0, 2158, __pyx_L5_except_error) } __pyx_L5_except_error:;
2159:
2160:
+2161: cdef size_t Rack_Length(const Rack_* that) nogil:
static size_t __pyx_f_11cbytesparse_1c_Rack_Length(Rack_ const *__pyx_v_that) { size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2162: return that.endex - that.start
__pyx_r = (__pyx_v_that->endex - __pyx_v_that->start); goto __pyx_L0;
2163:
2164:
+2165: cdef (addr_t, addr_t) Rack_BoundSlice(const Rack_* that, addr_t start, addr_t endex) nogil:
static __pyx_ctuple_addr_t__and_addr_t __pyx_f_11cbytesparse_1c_Rack_BoundSlice(Rack_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { Block_ const *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; __pyx_ctuple_addr_t__and_addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
2166: cdef:
2167: const Block_* block
2168: addr_t block_start
2169: addr_t block_endex
2170:
+2171: if that.start < that.endex:
__pyx_t_1 = ((__pyx_v_that->start < __pyx_v_that->endex) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+2172: block = that.blocks[that.start]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_that->start]);
+2173: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+2174: if start < block_start:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_block_start) != 0); if (__pyx_t_1) { /* … */ }
+2175: start = block_start
__pyx_v_start = __pyx_v_block_start;
+2176: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2177: endex = start
__pyx_v_endex = __pyx_v_start;
2178:
+2179: block = that.blocks[that.endex - 1]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]);
+2180: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+2181: if endex > block_endex:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_block_endex) != 0); if (__pyx_t_1) { /* … */ }
+2182: endex = block_endex
__pyx_v_endex = __pyx_v_block_endex;
+2183: if start > endex:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ }
+2184: start = endex
__pyx_v_start = __pyx_v_endex;
2185: else:
+2186: start = 0
/*else*/ { __pyx_v_start = 0;
+2187: endex = 0
__pyx_v_endex = 0; } __pyx_L3:;
2188:
+2189: return start, endex
__pyx_t_2.f0 = __pyx_v_start; __pyx_t_2.f1 = __pyx_v_endex; __pyx_r = __pyx_t_2; goto __pyx_L0;
2190:
2191:
+2192: cdef Rack_* Rack_Shift_(Rack_* that, addr_t offset) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Shift_(Rack_ *__pyx_v_that, addr_t __pyx_v_offset) { size_t __pyx_v_index; Block_ *__pyx_v_block; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Shift_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Shift_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2193: cdef:
2194: size_t index
2195: Block_* block
2196:
+2197: if offset:
__pyx_t_1 = (__pyx_v_offset != 0); if (__pyx_t_1) { /* … */ }
+2198: if that.start < that.endex:
__pyx_t_1 = ((__pyx_v_that->start < __pyx_v_that->endex) != 0); if (__pyx_t_1) { /* … */ }
+2199: block = that.blocks[that.endex - 1]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]);
+2200: CheckAddAddrU(block.address, offset)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_block->address, __pyx_v_offset); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2200, __pyx_L1_error)
2201:
+2202: for index in range(that.start, that.endex):
__pyx_t_3 = __pyx_v_that->endex; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = __pyx_v_that->start; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_index = __pyx_t_5;
+2203: block = that.blocks[index]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_index]);
+2204: block.address += offset
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_offset); }
+2205: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2206:
2207:
+2208: cdef Rack_* Rack_Shift(Rack_* that, saddr_t offset) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Shift(Rack_ *__pyx_v_that, saddr_t __pyx_v_offset) { size_t __pyx_v_index; Block_ *__pyx_v_block; addr_t __pyx_v_offset_; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Shift", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Shift", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2209: cdef:
2210: size_t index
2211: Block_* block
2212: addr_t offset_
2213:
+2214: if offset:
__pyx_t_1 = (__pyx_v_offset != 0); if (__pyx_t_1) { /* … */ }
+2215: if that.start < that.endex:
__pyx_t_1 = ((__pyx_v_that->start < __pyx_v_that->endex) != 0); if (__pyx_t_1) { /* … */ }
+2216: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L5; }
+2217: block = that.blocks[that.start]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_that->start]);
+2218: offset_ = <addr_t>-offset
__pyx_v_offset_ = ((addr_t)(-__pyx_v_offset));
+2219: CheckSubAddrU(block.address, offset_)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_block->address, __pyx_v_offset_); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2219, __pyx_L1_error)
2220:
+2221: for index in range(that.start, that.endex):
__pyx_t_3 = __pyx_v_that->endex; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = __pyx_v_that->start; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_index = __pyx_t_5;
+2222: block = that.blocks[index]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_index]);
+2223: block.address -= offset_
__pyx_v_block->address = (__pyx_v_block->address - __pyx_v_offset_); }
2224: else:
+2225: block = that.blocks[that.endex - 1]
/*else*/ { __pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]);
+2226: offset_ = <addr_t>offset
__pyx_v_offset_ = ((addr_t)__pyx_v_offset);
+2227: CheckAddAddrU(block.address, offset_)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_block->address, __pyx_v_offset_); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2227, __pyx_L1_error)
2228:
+2229: for index in range(that.start, that.endex):
__pyx_t_3 = __pyx_v_that->endex; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = __pyx_v_that->start; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_index = __pyx_t_5;
+2230: block = that.blocks[index]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_index]);
+2231: block.address += offset_
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_offset_); } } __pyx_L5:;
+2232: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2233:
2234:
+2235: cdef bint Rack_Eq(const Rack_* that, const Rack_* other) except -1:
static int __pyx_f_11cbytesparse_1c_Rack_Eq(Rack_ const *__pyx_v_that, Rack_ const *__pyx_v_other) { size_t __pyx_v_block_count; size_t __pyx_v_block_index; CYTHON_UNUSED size_t __pyx_v_block_length; Block_ const *__pyx_v_block1; Block_ const *__pyx_v_block2; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Eq", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2236: cdef:
+2237: size_t block_count = that.endex - that.start
__pyx_v_block_count = (__pyx_v_that->endex - __pyx_v_that->start);
2238: size_t block_index
2239: size_t block_length
2240: const Block_* block1
2241: const Block_* block2
2242:
+2243: if block_count != other.endex - other.start:
__pyx_t_1 = ((__pyx_v_block_count != (__pyx_v_other->endex - __pyx_v_other->start)) != 0); if (__pyx_t_1) { /* … */ }
+2244: return False
__pyx_r = 0; goto __pyx_L0;
2245:
+2246: for block_index in range(block_count):
__pyx_t_2 = __pyx_v_block_count; __pyx_t_3 = __pyx_t_2; for (__pyx_t_4 = 0; __pyx_t_4 < __pyx_t_3; __pyx_t_4+=1) { __pyx_v_block_index = __pyx_t_4;
+2247: block1 = Rack_Get__(that, block_index)
__pyx_v_block1 = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_that, __pyx_v_block_index);
+2248: block2 = Rack_Get__(other, block_index)
__pyx_v_block2 = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_other, __pyx_v_block_index);
+2249: block_length = Block_Length(block1)
__pyx_v_block_length = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block1);
2250:
+2251: if block1.address != block2.address:
__pyx_t_1 = ((__pyx_v_block1->address != __pyx_v_block2->address) != 0); if (__pyx_t_1) { /* … */ }
+2252: return False
__pyx_r = 0; goto __pyx_L0;
2253:
+2254: if not Block_Eq(block1, block2):
__pyx_t_1 = ((!(__pyx_f_11cbytesparse_1c_Block_Eq(__pyx_v_block1, __pyx_v_block2) != 0)) != 0); if (__pyx_t_1) { /* … */ } }
+2255: return False
__pyx_r = 0; goto __pyx_L0;
2256:
+2257: return True
__pyx_r = 1; goto __pyx_L0;
2258:
2259:
+2260: cdef Rack_* Rack_Reserve_(Rack_* that, size_t offset, size_t size) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Reserve_(Rack_ *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size) { size_t __pyx_v_actual; size_t __pyx_v_used; size_t __pyx_v_allocated; Rack_ *__pyx_v_ptr; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Reserve_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Rack_Reserve_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2261: cdef:
2262: size_t actual
2263: size_t used
2264: size_t margin
2265: size_t allocated
2266: Rack_* ptr
2267: size_t index
2268: Block_* node
2269:
+2270: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+2271: if ((size > SIZE_HMAX or
__pyx_t_2 = ((__pyx_v_size > SIZE_HMAX) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; } /* … */ if (unlikely(__pyx_t_1)) { /* … */ }
+2272: CannotAddSizeU(that.endex, size) or
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_that->endex, __pyx_v_size) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; }
+2273: that.endex + size > SIZE_HMAX)):
__pyx_t_2 = (((__pyx_v_that->endex + __pyx_v_size) > SIZE_HMAX) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L5_bool_binop_done:;
+2274: raise OverflowError('size overflow')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 2274, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 2274, __pyx_L1_error)
2275:
+2276: used = that.endex - that.start
__pyx_v_used = (__pyx_v_that->endex - __pyx_v_that->start);
+2277: if offset > used:
__pyx_t_1 = ((__pyx_v_offset > __pyx_v_used) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2278: raise IndexError('index out of range')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 2278, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 2278, __pyx_L1_error)
2279:
2280: # Prefer the side where there is less data to shift, which also favors the extremes
+2281: if offset >= (used >> 1):
__pyx_t_1 = ((__pyx_v_offset >= (__pyx_v_used >> 1)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L9; }
+2282: if size > that.allocated - that.endex:
__pyx_t_1 = ((__pyx_v_size > (__pyx_v_that->allocated - __pyx_v_that->endex)) != 0); if (__pyx_t_1) { /* … */ }
2283: # Calculate the upsized allocation
+2284: allocated = Upsize(that.allocated, that.allocated + size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Upsize(__pyx_v_that->allocated, (__pyx_v_that->allocated + __pyx_v_size));
+2285: if allocated > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2286: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2286, __pyx_L1_error)
2287:
2288: # Reallocate, including the header
+2289: ptr = <Rack_*>PyMem_Realloc(that, Rack_HEADING + (allocated * sizeof(Block_*)))
__pyx_v_ptr = ((Rack_ *)PyMem_Realloc(__pyx_v_that, (Rack_HEADING + (__pyx_v_allocated * (sizeof(Block_ *))))));
+2290: if ptr == NULL:
__pyx_t_1 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2291: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2291, __pyx_L1_error)
2292:
2293: # Reassign to that
+2294: that = ptr
__pyx_v_that = __pyx_v_ptr;
+2295: that.allocated = allocated # update
__pyx_v_that->allocated = __pyx_v_allocated;
2296:
2297: # Shift elements to make room for reservation at the requested offset
+2298: CheckAddSizeU(offset, that.start)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_that->start); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2298, __pyx_L1_error)
+2299: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+2300: used = that.endex - offset
__pyx_v_used = (__pyx_v_that->endex - __pyx_v_offset);
+2301: if used:
__pyx_t_1 = (__pyx_v_used != 0); if (__pyx_t_1) { /* … */ }
+2302: memmove(&that.blocks[offset + size],
(void)(memmove((&(__pyx_v_that->blocks[(__pyx_v_offset + __pyx_v_size)])), (&(__pyx_v_that->blocks[__pyx_v_offset])), (__pyx_v_used * (sizeof(Block_ *)))));
2303: &that.blocks[offset],
2304: used * sizeof(Block_*))
2305:
+2306: memset(&that.blocks[offset], 0, size * sizeof(Block_*)) # pad with zeros
(void)(memset((&(__pyx_v_that->blocks[__pyx_v_offset])), 0, (__pyx_v_size * (sizeof(Block_ *)))));
+2307: that.endex += size
__pyx_v_that->endex = (__pyx_v_that->endex + __pyx_v_size);
2308:
2309: else:
+2310: if size <= that.start:
/*else*/ { __pyx_t_1 = ((__pyx_v_size <= __pyx_v_that->start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L14; }
2311: # Shift elements to make room for reservation at the requested offset
+2312: that.start -= size
__pyx_v_that->start = (__pyx_v_that->start - __pyx_v_size);
+2313: if offset:
__pyx_t_1 = (__pyx_v_offset != 0); if (__pyx_t_1) { /* … */ }
+2314: memmove(&that.blocks[that.start],
(void)(memmove((&(__pyx_v_that->blocks[__pyx_v_that->start])), (&(__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_size)])), (__pyx_v_offset * (sizeof(Block_ *)))));
2315: &that.blocks[that.start + size],
2316: offset * sizeof(Block_*))
2317:
+2318: memset(&that.blocks[that.start + offset], 0, size * sizeof(Block_*)) # pad with zeros
(void)(memset((&(__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)])), 0, (__pyx_v_size * (sizeof(Block_ *)))));
2319:
2320: else:
2321: # Calculate the upsized allocation
+2322: CheckAddSizeU(that.allocated, size)
/*else*/ {
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->allocated, __pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2322, __pyx_L1_error)
+2323: allocated = Upsize(that.allocated, that.allocated + size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Upsize(__pyx_v_that->allocated, (__pyx_v_that->allocated + __pyx_v_size));
+2324: if allocated > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2325: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2325, __pyx_L1_error)
2326:
2327: # Allocate a new chunk, including the header
+2328: actual = Rack_HEADING + (allocated * sizeof(Block_*))
__pyx_v_actual = (Rack_HEADING + (__pyx_v_allocated * (sizeof(Block_ *))));
+2329: ptr = <Rack_*>PyMem_Calloc(actual, 1)
__pyx_v_ptr = ((Rack_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(__pyx_v_actual, 1));
+2330: if ptr == NULL:
__pyx_t_1 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2331: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2331, __pyx_L1_error)
2332:
2333: # Prepare the new chunk aligning towards the end
+2334: ptr.allocated = allocated
__pyx_v_ptr->allocated = __pyx_v_allocated;
+2335: ptr.endex = ptr.allocated - MARGIN # leave some room
__pyx_v_ptr->endex = (__pyx_v_ptr->allocated - MARGIN);
+2336: ptr.start = ptr.endex - used - size
__pyx_v_ptr->start = ((__pyx_v_ptr->endex - __pyx_v_used) - __pyx_v_size);
2337:
2338: # Shift/copy elements to make room for reservation at the requested offset
+2339: if offset:
__pyx_t_1 = (__pyx_v_offset != 0); if (__pyx_t_1) { /* … */ }
+2340: used -= offset # prepare for later
__pyx_v_used = (__pyx_v_used - __pyx_v_offset);
+2341: memcpy(&ptr.blocks[ptr.start],
(void)(memcpy((&(__pyx_v_ptr->blocks[__pyx_v_ptr->start])), (&(__pyx_v_that->blocks[__pyx_v_that->start])), (__pyx_v_offset * (sizeof(Block_ *)))));
2342: &that.blocks[that.start],
2343: offset * sizeof(Block_*))
+2344: if used:
__pyx_t_1 = (__pyx_v_used != 0); if (__pyx_t_1) { /* … */ }
+2345: memcpy(&ptr.blocks[ptr.start + offset + size],
(void)(memcpy((&(__pyx_v_ptr->blocks[((__pyx_v_ptr->start + __pyx_v_offset) + __pyx_v_size)])), (&(__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)])), (__pyx_v_used * (sizeof(Block_ *)))));
2346: &that.blocks[that.start + offset],
2347: used * sizeof(Block_*))
2348:
2349: # Reassign to that
+2350: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
+2351: that = ptr
__pyx_v_that = __pyx_v_ptr; } __pyx_L14:; } __pyx_L9:;
2352:
+2353: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2354:
2355:
+2356: cdef Rack_* Rack_Delete_(Rack_* that, size_t offset, size_t size) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Delete_(Rack_ *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size) { size_t __pyx_v_allocated; Rack_ *__pyx_v_ptr; size_t __pyx_v_index; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Delete_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Rack_Delete_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2357: cdef:
2358: size_t allocated
2359: Rack_* ptr
2360: size_t index
2361: Block_* node
2362:
+2363: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+2364: if ((size > SIZE_HMAX or
__pyx_t_2 = ((__pyx_v_size > SIZE_HMAX) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; } /* … */ if (unlikely(__pyx_t_1)) { /* … */ }
+2365: CannotAddSizeU(offset, size) or
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_offset, __pyx_v_size) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; }
+2366: offset + size > SIZE_HMAX or
__pyx_t_2 = (((__pyx_v_offset + __pyx_v_size) > SIZE_HMAX) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; }
+2367: CannotAddSizeU(offset, that.start) or
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_CannotAddSizeU(__pyx_v_offset, __pyx_v_that->start) != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; }
+2368: that.start > SIZE_HMAX)):
__pyx_t_2 = ((__pyx_v_that->start > SIZE_HMAX) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L5_bool_binop_done:;
+2369: raise OverflowError('size overflow')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 2369, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 2369, __pyx_L1_error)
2370:
+2371: if that.endex < that.start + offset + size:
__pyx_t_1 = ((__pyx_v_that->endex < ((__pyx_v_that->start + __pyx_v_offset) + __pyx_v_size)) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2372: raise IndexError('index out of range')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 2372, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 2372, __pyx_L1_error)
2373:
2374: # Calculate the downsized allocation
+2375: allocated = Downsize(that.allocated, that.allocated - size)
__pyx_v_allocated = __pyx_f_11cbytesparse_1c_Downsize(__pyx_v_that->allocated, (__pyx_v_that->allocated - __pyx_v_size));
+2376: if allocated > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_allocated > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2377: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2377, __pyx_L1_error)
2378:
2379: # Release blocks within the deleted range
+2380: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+2381: for index in range(offset, offset + size):
__pyx_t_4 = (__pyx_v_offset + __pyx_v_size); __pyx_t_5 = __pyx_t_4; for (__pyx_t_6 = __pyx_v_offset; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { __pyx_v_index = __pyx_t_6;
+2382: that.blocks[index] = Block_Release(that.blocks[index])
(__pyx_v_that->blocks[__pyx_v_index]) = __pyx_f_11cbytesparse_1c_Block_Release((__pyx_v_that->blocks[__pyx_v_index])); }
2383:
+2384: if offset == 0:
__pyx_t_1 = ((__pyx_v_offset == 0) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L14; }
+2385: if allocated == that.allocated:
__pyx_t_1 = ((__pyx_v_allocated == __pyx_v_that->allocated) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L15; }
2386: # Just skip initial if not reallocated and no offset
+2387: memset(&that.blocks[that.start], 0, size * sizeof(Block_*)) # cleanup margin
(void)(memset((&(__pyx_v_that->blocks[__pyx_v_that->start])), 0, (__pyx_v_size * (sizeof(Block_ *)))));
+2388: that.start += size
__pyx_v_that->start = (__pyx_v_that->start + __pyx_v_size);
2389: else:
2390: # Shift elements to make for the deleted gap at the beginning
+2391: offset += that.start
/*else*/ { __pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+2392: memmove(&that.blocks[MARGIN], # realign to initial MARGIN
(void)(memmove((&(__pyx_v_that->blocks[MARGIN])), (&(__pyx_v_that->blocks[(__pyx_v_offset + __pyx_v_size)])), ((__pyx_v_that->endex - (__pyx_v_offset + __pyx_v_size)) * (sizeof(Block_ *)))));
2393: &that.blocks[offset + size],
2394: (that.endex - (offset + size)) * sizeof(Block_*))
+2395: size = that.endex - that.start - size
__pyx_v_size = ((__pyx_v_that->endex - __pyx_v_that->start) - __pyx_v_size);
+2396: that.start = MARGIN
__pyx_v_that->start = MARGIN;
+2397: that.endex = MARGIN + size
__pyx_v_that->endex = (MARGIN + __pyx_v_size);
2398:
2399: # Cleanup margins
+2400: memset(&that.blocks[0], 0, that.start * sizeof(Block_*))
(void)(memset((&(__pyx_v_that->blocks[0])), 0, (__pyx_v_that->start * (sizeof(Block_ *)))));
+2401: memset(&that.blocks[that.endex], 0, (that.allocated - that.endex) * sizeof(Block_*))
(void)(memset((&(__pyx_v_that->blocks[__pyx_v_that->endex])), 0, ((__pyx_v_that->allocated - __pyx_v_that->endex) * (sizeof(Block_ *))))); } __pyx_L15:;
2402: else:
2403: # Shift elements to make for the deleted gap at the requested offset
+2404: memmove(&that.blocks[offset],
/*else*/ { /* … */ (void)(memmove((&(__pyx_v_that->blocks[__pyx_v_offset])), (&(__pyx_v_that->blocks[(__pyx_v_offset + __pyx_v_size)])), ((__pyx_v_that->endex - (__pyx_v_offset + __pyx_v_size)) * (sizeof(Block_ *)))));
2405: &that.blocks[offset + size],
2406: (that.endex - (offset + size)) * sizeof(Block_*))
+2407: that.endex -= size
__pyx_v_that->endex = (__pyx_v_that->endex - __pyx_v_size);
+2408: memset(&that.blocks[that.endex], 0, size * sizeof(Block_*)) # cleanup margin
(void)(memset((&(__pyx_v_that->blocks[__pyx_v_that->endex])), 0, (__pyx_v_size * (sizeof(Block_ *))))); } __pyx_L14:;
2409:
+2410: if allocated != that.allocated:
__pyx_t_1 = ((__pyx_v_allocated != __pyx_v_that->allocated) != 0); if (__pyx_t_1) { /* … */ }
2411: # Reallocate, including the header
+2412: ptr = <Rack_*>PyMem_Realloc(that, Rack_HEADING + (allocated * sizeof(Block_*)))
__pyx_v_ptr = ((Rack_ *)PyMem_Realloc(__pyx_v_that, (Rack_HEADING + (__pyx_v_allocated * (sizeof(Block_ *))))));
+2413: if ptr == NULL:
__pyx_t_1 = ((__pyx_v_ptr == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2414: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 2414, __pyx_L1_error)
2415:
2416: # Reassign to that
+2417: that = ptr
__pyx_v_that = __pyx_v_ptr;
+2418: that.allocated = allocated
__pyx_v_that->allocated = __pyx_v_allocated;
2419:
+2420: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2421:
2422:
+2423: cdef Rack_* Rack_Clear(Rack_* that) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Clear(Rack_ *__pyx_v_that) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Clear", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2424: return Rack_Delete_(that, 0, that.endex - that.start)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Delete_(__pyx_v_that, 0, (__pyx_v_that->endex - __pyx_v_that->start)); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2424, __pyx_L1_error)
__pyx_r = __pyx_t_1;
goto __pyx_L0;
2425:
2426:
+2427: cdef Rack_* Rack_Consolidate(Rack_* that) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Consolidate(Rack_ *__pyx_v_that) { size_t __pyx_v_offset; Block_ *__pyx_v_block; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Consolidate", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Consolidate", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2428: cdef:
2429: size_t offset
2430: Block_* block
2431:
+2432: for offset in range(that.start, that.endex):
__pyx_t_1 = __pyx_v_that->endex; __pyx_t_2 = __pyx_t_1; for (__pyx_t_3 = __pyx_v_that->start; __pyx_t_3 < __pyx_t_2; __pyx_t_3+=1) { __pyx_v_offset = __pyx_t_3;
+2433: block = that.blocks[offset]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_offset]);
+2434: if block.references > 1:
__pyx_t_4 = ((__pyx_v_block->references > 1) != 0); if (__pyx_t_4) { /* … */ } }
+2435: that.blocks[offset] = Block_Copy(block)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_Copy(__pyx_v_block); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 2435, __pyx_L1_error)
(__pyx_v_that->blocks[__pyx_v_offset]) = __pyx_t_5;
+2436: block = Block_Release(block)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Block_Release(__pyx_v_block);
+2437: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2438:
2439:
+2440: cdef Block_** Rack_At_(Rack_* that, size_t offset) nogil:
static Block_ **__pyx_f_11cbytesparse_1c_Rack_At_(Rack_ *__pyx_v_that, size_t __pyx_v_offset) { Block_ **__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2441: return &that.blocks[that.start + offset]
__pyx_r = (&(__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)])); goto __pyx_L0;
2442:
2443:
+2444: cdef const Block_** Rack_At__(const Rack_* that, size_t offset) nogil:
static Block_ const **__pyx_f_11cbytesparse_1c_Rack_At__(Rack_ const *__pyx_v_that, size_t __pyx_v_offset) { Block_ const **__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2445: return <const Block_**>&that.blocks[that.start + offset]
__pyx_r = ((Block_ const **)(&(__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)]))); goto __pyx_L0;
2446:
2447:
+2448: cdef Block_* Rack_First_(Rack_* that) nogil:
static Block_ *__pyx_f_11cbytesparse_1c_Rack_First_(Rack_ *__pyx_v_that) { Block_ *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2449: return that.blocks[that.start]
__pyx_r = (__pyx_v_that->blocks[__pyx_v_that->start]); goto __pyx_L0;
2450:
2451:
+2452: cdef const Block_* Rack_First__(const Rack_* that) nogil:
static Block_ const *__pyx_f_11cbytesparse_1c_Rack_First__(Rack_ const *__pyx_v_that) { Block_ const *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2453: return that.blocks[that.start]
__pyx_r = (__pyx_v_that->blocks[__pyx_v_that->start]); goto __pyx_L0;
2454:
2455:
+2456: cdef Block_* Rack_Last_(Rack_* that) nogil:
static Block_ *__pyx_f_11cbytesparse_1c_Rack_Last_(Rack_ *__pyx_v_that) { Block_ *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2457: return that.blocks[that.endex - 1]
__pyx_r = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]); goto __pyx_L0;
2458:
2459:
+2460: cdef const Block_* Rack_Last__(const Rack_* that) nogil:
static Block_ const *__pyx_f_11cbytesparse_1c_Rack_Last__(Rack_ const *__pyx_v_that) { Block_ const *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2461: return that.blocks[that.endex - 1]
__pyx_r = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]); goto __pyx_L0;
2462:
2463:
+2464: cdef Block_* Rack_Get__(const Rack_* that, size_t offset) nogil:
static Block_ *__pyx_f_11cbytesparse_1c_Rack_Get__(Rack_ const *__pyx_v_that, size_t __pyx_v_offset) { Block_ *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+2465: return that.blocks[that.start + offset]
__pyx_r = (__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)]); goto __pyx_L0;
2466:
2467:
+2468: cdef Block_* Rack_Get_(const Rack_* that, size_t offset) except? NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Rack_Get_(Rack_ const *__pyx_v_that, size_t __pyx_v_offset) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Get_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Rack_Get_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2469: CheckAddSizeU(that.start, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2469, __pyx_L1_error)
+2470: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
2471:
+2472: if offset < that.endex:
__pyx_t_2 = ((__pyx_v_offset < __pyx_v_that->endex) != 0); if (likely(__pyx_t_2)) { /* … */ }
+2473: return that.blocks[offset]
__pyx_r = (__pyx_v_that->blocks[__pyx_v_offset]); goto __pyx_L0;
2474: else:
+2475: raise IndexError('index out of range')
/*else*/ { __pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 2475, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 2475, __pyx_L1_error) }
2476:
2477:
+2478: cdef Block_* Rack_Get(const Rack_* that, ssize_t offset) except? NULL:
static Block_ *__pyx_f_11cbytesparse_1c_Rack_Get(Rack_ const *__pyx_v_that, Py_ssize_t __pyx_v_offset) { Block_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Get", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_Get", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2479: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
+2480: offset += <ssize_t>(that.endex - that.start) # anchor to end
__pyx_v_offset = (__pyx_v_offset + ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start)));
+2481: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2482: raise IndexError('index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2482, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2482, __pyx_L1_error)
2483:
+2484: return Rack_Get_(that, <size_t>offset)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_that, ((size_t)__pyx_v_offset)); if (unlikely(__pyx_t_3 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 2484, __pyx_L1_error) __pyx_r = __pyx_t_3; goto __pyx_L0;
2485:
2486:
+2487: cdef Block_* Rack_Set__(Rack_* that, size_t offset, Block_* value) nogil:
static Block_ *__pyx_f_11cbytesparse_1c_Rack_Set__(Rack_ *__pyx_v_that, size_t __pyx_v_offset, Block_ *__pyx_v_value) { Block_ *__pyx_v_backup; Block_ *__pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
2488: cdef:
2489: Block_* backup
2490:
+2491: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
+2492: backup = that.blocks[offset]
__pyx_v_backup = (__pyx_v_that->blocks[__pyx_v_offset]);
+2493: that.blocks[offset] = value
(__pyx_v_that->blocks[__pyx_v_offset]) = __pyx_v_value;
+2494: return backup
__pyx_r = __pyx_v_backup; goto __pyx_L0;
2495:
2496:
+2497: cdef vint Rack_Set_(Rack_* that, size_t offset, Block_* value, Block_** backup) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Rack_Set_(Rack_ *__pyx_v_that, size_t __pyx_v_offset, Block_ *__pyx_v_value, Block_ **__pyx_v_backup) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Set_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Rack_Set_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2498: CheckAddSizeU(that.start, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2498, __pyx_L1_error)
+2499: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
2500:
+2501: if offset < that.endex:
__pyx_t_2 = ((__pyx_v_offset < __pyx_v_that->endex) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+2502: if backup:
__pyx_t_2 = (__pyx_v_backup != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+2503: backup[0] = that.blocks[offset]
(__pyx_v_backup[0]) = (__pyx_v_that->blocks[__pyx_v_offset]);
2504: else:
+2505: that.blocks[offset] = Block_Release(that.blocks[offset])
/*else*/ { (__pyx_v_that->blocks[__pyx_v_offset]) = __pyx_f_11cbytesparse_1c_Block_Release((__pyx_v_that->blocks[__pyx_v_offset])); } __pyx_L4:;
+2506: that.blocks[offset] = value
(__pyx_v_that->blocks[__pyx_v_offset]) = __pyx_v_value;
2507: else:
+2508: if backup:
/*else*/ { __pyx_t_2 = (__pyx_v_backup != 0); if (__pyx_t_2) { /* … */ }
+2509: backup[0] = NULL
(__pyx_v_backup[0]) = NULL;
+2510: raise IndexError('index out of range')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 2510, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 2510, __pyx_L1_error) } __pyx_L3:;
2511:
2512:
+2513: cdef vint Rack_Set(Rack_* that, ssize_t offset, Block_* value, Block_** backup) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Rack_Set(Rack_ *__pyx_v_that, Py_ssize_t __pyx_v_offset, Block_ *__pyx_v_value, Block_ **__pyx_v_backup) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Set", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_Set", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2514: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
+2515: offset += <ssize_t>(that.endex - that.start) # anchor to end
__pyx_v_offset = (__pyx_v_offset + ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start)));
+2516: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2517: raise IndexError('index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2517, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2517, __pyx_L1_error)
2518:
+2519: Rack_Set_(that, <size_t>offset, value, backup)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Set_(__pyx_v_that, ((size_t)__pyx_v_offset), __pyx_v_value, __pyx_v_backup); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2519, __pyx_L1_error)
2520:
2521:
+2522: cdef Rack_* Rack_Pop__(Rack_* that, Block_** value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Pop__(Rack_ *__pyx_v_that, Block_ **__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Pop__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Rack_Pop__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2523: if that.start < that.endex:
__pyx_t_1 = ((__pyx_v_that->start < __pyx_v_that->endex) != 0); if (__pyx_t_1) { /* … */ }
+2524: if value:
__pyx_t_1 = (__pyx_v_value != 0); if (__pyx_t_1) { /* … */ }
+2525: value[0] = Block_Acquire(that.blocks[that.endex - 1]) # backup
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_that->blocks[(__pyx_v_that->endex - 1)])); if (unlikely(__pyx_t_2 == ((Block_ *)NULL))) __PYX_ERR(0, 2525, __pyx_L1_error)
(__pyx_v_value[0]) = __pyx_t_2;
2526:
+2527: return Rack_Delete_(that, that.endex - that.start - 1, 1)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Delete_(__pyx_v_that, ((__pyx_v_that->endex - __pyx_v_that->start) - 1), 1); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2527, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
2528: else:
+2529: if value:
/*else*/ { __pyx_t_1 = (__pyx_v_value != 0); if (__pyx_t_1) { /* … */ }
+2530: value[0] = NULL
(__pyx_v_value[0]) = NULL;
+2531: raise IndexError('pop index out of range')
__pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__7, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2531, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 2531, __pyx_L1_error) }
2532:
2533:
+2534: cdef Rack_* Rack_Pop_(Rack_* that, size_t offset, Block_** value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Pop_(Rack_ *__pyx_v_that, size_t __pyx_v_offset, Block_ **__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Pop_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Rack_Pop_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2535: CheckAddSizeU(that.start, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2535, __pyx_L1_error)
2536:
+2537: if that.start + offset < that.endex:
__pyx_t_2 = (((__pyx_v_that->start + __pyx_v_offset) < __pyx_v_that->endex) != 0); if (__pyx_t_2) { /* … */ }
+2538: if value:
__pyx_t_2 = (__pyx_v_value != 0); if (__pyx_t_2) { /* … */ }
+2539: value[0] = Block_Acquire(that.blocks[that.start + offset]) # backup
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)])); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 2539, __pyx_L1_error)
(__pyx_v_value[0]) = __pyx_t_3;
2540:
+2541: return Rack_Delete_(that, offset, 1)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Rack_Delete_(__pyx_v_that, __pyx_v_offset, 1); if (unlikely(__pyx_t_4 == ((Rack_ *)NULL))) __PYX_ERR(0, 2541, __pyx_L1_error)
__pyx_r = __pyx_t_4;
goto __pyx_L0;
2542: else:
+2543: if value:
/*else*/ { __pyx_t_2 = (__pyx_v_value != 0); if (__pyx_t_2) { /* … */ }
+2544: value[0] = NULL
(__pyx_v_value[0]) = NULL;
+2545: raise IndexError('pop index out of range')
__pyx_t_5 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__7, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 2545, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __PYX_ERR(0, 2545, __pyx_L1_error) }
2546:
2547:
+2548: cdef Rack_* Rack_Pop(Rack_* that, ssize_t offset, Block_** value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Pop(Rack_ *__pyx_v_that, Py_ssize_t __pyx_v_offset, Block_ **__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Pop", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_Pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2549: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
+2550: offset += <ssize_t>(that.endex - that.start) # anchor to end
__pyx_v_offset = (__pyx_v_offset + ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start)));
+2551: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2552: raise IndexError('pop index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__7, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2552, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2552, __pyx_L1_error)
2553:
+2554: return Rack_Pop_(that, <size_t>offset, value)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Pop_(__pyx_v_that, ((size_t)__pyx_v_offset), __pyx_v_value); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2554, __pyx_L1_error)
__pyx_r = __pyx_t_3;
goto __pyx_L0;
2555:
2556:
+2557: cdef Rack_* Rack_PopLeft(Rack_* that, Block_** value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_PopLeft(Rack_ *__pyx_v_that, Block_ **__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_PopLeft", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_PopLeft", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2558: return Rack_Pop_(that, 0, value)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Pop_(__pyx_v_that, 0, __pyx_v_value); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2558, __pyx_L1_error)
__pyx_r = __pyx_t_1;
goto __pyx_L0;
2559:
2560:
+2561: cdef Rack_* Rack_Insert_(Rack_* that, size_t offset, Block_* value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Insert_(Rack_ *__pyx_v_that, size_t __pyx_v_offset, Block_ *__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Insert_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Insert_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2562: # Insert the value at the requested offset
+2563: that = Rack_Reserve_(that, offset, 1)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, __pyx_v_offset, 1); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2563, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2564: that.blocks[that.start + offset] = value
(__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_offset)]) = __pyx_v_value;
+2565: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2566:
2567:
+2568: cdef Rack_* Rack_Insert(Rack_* that, ssize_t offset, Block_* value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Insert(Rack_ *__pyx_v_that, Py_ssize_t __pyx_v_offset, Block_ *__pyx_v_value) { Py_ssize_t __pyx_v_size; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Insert", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Insert", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2569: cdef:
+2570: ssize_t size = <ssize_t>(that.endex - that.start)
__pyx_v_size = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
2571:
+2572: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+2573: offset += size # anchor to end
__pyx_v_offset = (__pyx_v_offset + __pyx_v_size);
+2574: if offset < 0:
__pyx_t_1 = ((__pyx_v_offset < 0) != 0); if (__pyx_t_1) { /* … */ }
2575: # raise IndexError('index out of range')
+2576: offset = 0 # as per bytearray.insert
__pyx_v_offset = 0;
2577:
+2578: elif offset > size:
__pyx_t_1 = ((__pyx_v_offset > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L3:;
2579: # raise IndexError('index out of range')
+2580: offset = size # as per bytearray.insert
__pyx_v_offset = __pyx_v_size;
2581:
+2582: return Rack_Insert_(that, <size_t>offset, value)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Insert_(__pyx_v_that, ((size_t)__pyx_v_offset), __pyx_v_value); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2582, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
2583:
2584:
+2585: cdef Rack_* Rack_Append(Rack_* that, Block_* value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Append(Rack_ *__pyx_v_that, Block_ *__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Append", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Append", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2586: # Insert the value after the end
+2587: that = Rack_Reserve_(that, that.endex - that.start, 1)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, (__pyx_v_that->endex - __pyx_v_that->start), 1); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2587, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2588: that.blocks[that.endex - 1] = value
(__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]) = __pyx_v_value;
+2589: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2590:
2591:
+2592: cdef Rack_* Rack_AppendLeft(Rack_* that, Block_* value) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_AppendLeft(Rack_ *__pyx_v_that, Block_ *__pyx_v_value) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_AppendLeft", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_AppendLeft", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2593: # Insert the value after the end
+2594: that = Rack_Reserve_(that, 0, 1)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, 0, 1); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2594, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2595: that.blocks[that.start] = value
(__pyx_v_that->blocks[__pyx_v_that->start]) = __pyx_v_value;
+2596: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2597:
2598:
+2599: cdef Rack_* Rack_Extend_(Rack_* that, size_t size, Block_** buffer, bint direct) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Extend_(Rack_ *__pyx_v_that, size_t __pyx_v_size, Block_ **__pyx_v_buffer, int __pyx_v_direct) { size_t __pyx_v_start; size_t __pyx_v_offset; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Extend_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Extend_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2600: cdef:
2601: size_t start
2602: size_t offset
2603:
+2604: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+2605: that = Rack_Reserve_(that, that.endex - that.start, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, (__pyx_v_that->endex - __pyx_v_that->start), __pyx_v_size); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2605, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+2606: if direct:
__pyx_t_1 = (__pyx_v_direct != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+2607: memmove(&that.blocks[that.endex - size], buffer, size * sizeof(Block_*))
(void)(memmove((&(__pyx_v_that->blocks[(__pyx_v_that->endex - __pyx_v_size)])), __pyx_v_buffer, (__pyx_v_size * (sizeof(Block_ *)))));
2608: else:
+2609: start = that.endex - size
/*else*/ { __pyx_v_start = (__pyx_v_that->endex - __pyx_v_size);
+2610: for offset in range(size):
__pyx_t_3 = __pyx_v_size; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_offset = __pyx_t_5;
+2611: that.blocks[start + offset] = Block_Acquire(buffer[offset])
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_buffer[__pyx_v_offset])); if (unlikely(__pyx_t_6 == ((Block_ *)NULL))) __PYX_ERR(0, 2611, __pyx_L1_error)
(__pyx_v_that->blocks[(__pyx_v_start + __pyx_v_offset)]) = __pyx_t_6;
}
}
__pyx_L4:;
+2612: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2613:
2614:
+2615: cdef Rack_* Rack_Extend(Rack_* that, Rack_* more) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Extend(Rack_ *__pyx_v_that, Rack_ *__pyx_v_more) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Extend", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Extend", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2616: that = Rack_Extend_(that, more.endex - more.start, &more.blocks[more.start], False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Extend_(__pyx_v_that, (__pyx_v_more->endex - __pyx_v_more->start), (&(__pyx_v_more->blocks[__pyx_v_more->start])), 0); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2616, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2617: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2618:
2619:
+2620: cdef Rack_* Rack_ExtendLeft_(Rack_* that, size_t size, Block_** buffer, bint direct) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_ExtendLeft_(Rack_ *__pyx_v_that, size_t __pyx_v_size, Block_ **__pyx_v_buffer, int __pyx_v_direct) { size_t __pyx_v_start; size_t __pyx_v_offset; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_ExtendLeft_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_ExtendLeft_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2621: cdef:
2622: size_t start
2623: size_t offset
2624:
+2625: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+2626: that = Rack_Reserve_(that, 0, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, 0, __pyx_v_size); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2626, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+2627: if direct:
__pyx_t_1 = (__pyx_v_direct != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+2628: memmove(&that.blocks[that.endex - size], buffer, size * sizeof(Block_*))
(void)(memmove((&(__pyx_v_that->blocks[(__pyx_v_that->endex - __pyx_v_size)])), __pyx_v_buffer, (__pyx_v_size * (sizeof(Block_ *)))));
2629: else:
+2630: start = that.start
/*else*/ { __pyx_t_3 = __pyx_v_that->start; __pyx_v_start = __pyx_t_3;
+2631: for offset in range(size):
__pyx_t_3 = __pyx_v_size; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_offset = __pyx_t_5;
+2632: that.blocks[start + offset] = Block_Acquire(buffer[offset])
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_buffer[__pyx_v_offset])); if (unlikely(__pyx_t_6 == ((Block_ *)NULL))) __PYX_ERR(0, 2632, __pyx_L1_error)
(__pyx_v_that->blocks[(__pyx_v_start + __pyx_v_offset)]) = __pyx_t_6;
}
}
__pyx_L4:;
+2633: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2634:
2635:
+2636: cdef Rack_* Rack_ExtendLeft(Rack_* that, Rack_* more) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_ExtendLeft(Rack_ *__pyx_v_that, Rack_ *__pyx_v_more) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_ExtendLeft", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_ExtendLeft", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+2637: that = Rack_ExtendLeft_(that, more.endex - more.start, &more.blocks[more.start], False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_ExtendLeft_(__pyx_v_that, (__pyx_v_more->endex - __pyx_v_more->start), (&(__pyx_v_more->blocks[__pyx_v_more->start])), 0); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 2637, __pyx_L1_error)
__pyx_v_that = __pyx_t_1;
+2638: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2639:
2640:
+2641: cdef vint Rack_Read_(const Rack_* that, size_t offset,
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Rack_Read_(Rack_ const *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size, Block_ **__pyx_v_buffer, int __pyx_v_direct) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Read_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_Read_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2642: size_t size, Block_** buffer, bint direct) except -1:
+2643: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+2644: if size > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_size > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2645: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2645, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2645, __pyx_L1_error)
2646:
+2647: CheckAddSizeU(that.start, offset)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2647, __pyx_L1_error)
+2648: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
2649:
+2650: CheckAddSizeU(offset, size)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_size); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2650, __pyx_L1_error)
+2651: if that.endex <= offset + size:
__pyx_t_1 = ((__pyx_v_that->endex <= (__pyx_v_offset + __pyx_v_size)) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2652: raise IndexError('index out of range')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_IndexError, __pyx_tuple__6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2652, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2652, __pyx_L1_error)
2653:
+2654: if direct:
__pyx_t_1 = (__pyx_v_direct != 0); if (__pyx_t_1) { /* … */ goto __pyx_L6; }
+2655: memmove(buffer, &that.blocks[offset], size * sizeof(Block_*))
(void)(memmove(__pyx_v_buffer, (&(__pyx_v_that->blocks[__pyx_v_offset])), (__pyx_v_size * (sizeof(Block_ *)))));
2656: else:
+2657: for offset in range(offset, offset + size):
/*else*/ { __pyx_t_4 = (__pyx_v_offset + __pyx_v_size); __pyx_t_5 = __pyx_t_4; for (__pyx_t_6 = __pyx_v_offset; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { __pyx_v_offset = __pyx_t_6;
+2658: buffer[offset - that.start] = Block_Acquire(buffer[offset])
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_buffer[__pyx_v_offset])); if (unlikely(__pyx_t_7 == ((Block_ *)NULL))) __PYX_ERR(0, 2658, __pyx_L1_error)
(__pyx_v_buffer[(__pyx_v_offset - __pyx_v_that->start)]) = __pyx_t_7;
}
}
__pyx_L6:;
2659:
2660:
+2661: cdef Rack_* Rack_Write_(Rack_* that, size_t offset,
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_Write_(Rack_ *__pyx_v_that, size_t __pyx_v_offset, size_t __pyx_v_size, Block_ **__pyx_v_buffer, int __pyx_v_direct) { Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_Write_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_Write_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2662: size_t size, Block_** buffer, bint direct) except NULL:
+2663: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+2664: CheckAddSizeU(that.start, offset)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_that->start, __pyx_v_offset); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2664, __pyx_L1_error)
+2665: offset += that.start
__pyx_v_offset = (__pyx_v_offset + __pyx_v_that->start);
2666:
+2667: CheckAddSizeU(offset, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_offset, __pyx_v_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2667, __pyx_L1_error)
+2668: if that.endex < offset + size:
__pyx_t_1 = ((__pyx_v_that->endex < (__pyx_v_offset + __pyx_v_size)) != 0); if (__pyx_t_1) { /* … */ }
+2669: that = Rack_Reserve_(that, that.endex - that.start, (offset + size) - that.endex)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, (__pyx_v_that->endex - __pyx_v_that->start), ((__pyx_v_offset + __pyx_v_size) - __pyx_v_that->endex)); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2669, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
2670:
+2671: if direct:
__pyx_t_1 = (__pyx_v_direct != 0); if (__pyx_t_1) { /* … */ goto __pyx_L5; }
+2672: memmove(&that.blocks[offset], buffer, size * sizeof(Block_*))
(void)(memmove((&(__pyx_v_that->blocks[__pyx_v_offset])), __pyx_v_buffer, (__pyx_v_size * (sizeof(Block_ *)))));
2673: else:
+2674: for offset in range(offset, offset + size):
/*else*/ { __pyx_t_4 = (__pyx_v_offset + __pyx_v_size); __pyx_t_5 = __pyx_t_4; for (__pyx_t_6 = __pyx_v_offset; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { __pyx_v_offset = __pyx_t_6;
+2675: that.blocks[offset] = Block_Release(that.blocks[offset])
(__pyx_v_that->blocks[__pyx_v_offset]) = __pyx_f_11cbytesparse_1c_Block_Release((__pyx_v_that->blocks[__pyx_v_offset]));
+2676: that.blocks[offset] = Block_Acquire(buffer[offset - that.start])
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_buffer[(__pyx_v_offset - __pyx_v_that->start)])); if (unlikely(__pyx_t_7 == ((Block_ *)NULL))) __PYX_ERR(0, 2676, __pyx_L1_error)
(__pyx_v_that->blocks[__pyx_v_offset]) = __pyx_t_7;
}
}
__pyx_L5:;
2677:
+2678: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2679:
2680:
+2681: cdef vint Rack_ReadSlice_(const Rack_* that, size_t start, size_t endex,
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Rack_ReadSlice_(Rack_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t *__pyx_v_size_, Block_ **__pyx_v_buffer, int __pyx_v_direct) { size_t __pyx_v_size; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_ReadSlice_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_ReadSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2682: size_t* size_, Block_** buffer, bint direct) except -1:
2683: cdef:
+2684: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
2685:
+2686: size_[0] = 0
(__pyx_v_size_[0]) = 0;
2687:
+2688: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2689: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2689, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2689, __pyx_L1_error)
+2690: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2691: start = size # trim source start
__pyx_v_start = __pyx_v_size;
2692:
+2693: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2694: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2694, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2694, __pyx_L1_error)
+2695: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+2696: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
+2697: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+2698: endex = size # trim source end
__pyx_v_endex = __pyx_v_size;
2699:
+2700: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
+2701: Rack_Read_(that, start, size, buffer, direct)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Read_(__pyx_v_that, __pyx_v_start, __pyx_v_size, __pyx_v_buffer, __pyx_v_direct); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2701, __pyx_L1_error)
+2702: size_[0] = size
(__pyx_v_size_[0]) = __pyx_v_size;
2703:
2704:
+2705: cdef vint Rack_ReadSlice(const Rack_* that, ssize_t start, ssize_t endex,
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Rack_ReadSlice(Rack_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t *__pyx_v_size_, Block_ **__pyx_v_buffer, int __pyx_v_direct) { Py_ssize_t __pyx_v_ssize; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_ReadSlice", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_ReadSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2706: size_t* size_, Block_** buffer, bint direct) except -1:
2707: cdef:
+2708: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
2709:
+2710: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2711: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+2712: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2713: start = 0 # trim source start
__pyx_v_start = 0;
2714:
+2715: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+2716: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+2717: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2718: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
2719:
+2720: Rack_ReadSlice_(that, <size_t>start, <size_t>endex, size_, buffer, direct)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_ReadSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_size_, __pyx_v_buffer, __pyx_v_direct); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2720, __pyx_L1_error)
2721:
2722:
+2723: cdef Rack_* Rack_GetSlice_(const Rack_* that, size_t start, size_t endex) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_GetSlice_(Rack_ const *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex) { Rack_ *__pyx_v_other; size_t __pyx_v_size; size_t __pyx_v_offset; size_t __pyx_v_offset2; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_GetSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_12); __Pyx_XDECREF(__pyx_t_13); __Pyx_AddTraceback("cbytesparse.c.Rack_GetSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2724: cdef:
+2725: Rack_* other = NULL
__pyx_v_other = NULL;
+2726: size_t size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
2727: size_t offset
2728: size_t offset2
2729:
+2730: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2731: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2731, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2731, __pyx_L1_error)
+2732: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2733: start = size # trim source start
__pyx_v_start = __pyx_v_size;
2734:
+2735: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2736: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2736, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2736, __pyx_L1_error)
+2737: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+2738: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
+2739: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+2740: endex = size # trim source end
__pyx_v_endex = __pyx_v_size;
2741:
+2742: try:
{ /*try:*/ { /* … */ } __pyx_L5_error:; __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5); goto __pyx_L1_error; __pyx_L9_try_return:; __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5); goto __pyx_L0; }
+2743: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
+2744: other = Rack_Alloc(size)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Rack_Alloc(__pyx_v_size); if (unlikely(__pyx_t_6 == ((Rack_ *)NULL))) __PYX_ERR(0, 2744, __pyx_L5_error)
__pyx_v_other = __pyx_t_6;
+2745: CheckAddSizeU(other.start, size)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_other->start, __pyx_v_size); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 2745, __pyx_L5_error)
+2746: offset2 = that.start + start
__pyx_v_offset2 = (__pyx_v_that->start + __pyx_v_start);
2747:
+2748: for offset in range(other.start, other.start + size):
__pyx_t_8 = (__pyx_v_other->start + __pyx_v_size); __pyx_t_9 = __pyx_t_8; for (__pyx_t_10 = __pyx_v_other->start; __pyx_t_10 < __pyx_t_9; __pyx_t_10+=1) { __pyx_v_offset = __pyx_t_10;
+2749: other.blocks[offset] = Block_Acquire(that.blocks[offset2])
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Block_Acquire((__pyx_v_that->blocks[__pyx_v_offset2])); if (unlikely(__pyx_t_11 == ((Block_ *)NULL))) __PYX_ERR(0, 2749, __pyx_L5_error)
(__pyx_v_other->blocks[__pyx_v_offset]) = __pyx_t_11;
+2750: offset2 += 1
__pyx_v_offset2 = (__pyx_v_offset2 + 1); }
2751:
+2752: return other
__pyx_r = __pyx_v_other; goto __pyx_L9_try_return;
+2753: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Rack_GetSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_2, &__pyx_t_12, &__pyx_t_13) < 0) __PYX_ERR(0, 2753, __pyx_L7_except_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GOTREF(__pyx_t_12); __Pyx_GOTREF(__pyx_t_13);
+2754: other = Rack_Free(other)
__pyx_v_other = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_other);
+2755: raise
__Pyx_GIVEREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_12); __Pyx_XGIVEREF(__pyx_t_13); __Pyx_ErrRestoreWithState(__pyx_t_2, __pyx_t_12, __pyx_t_13); __pyx_t_2 = 0; __pyx_t_12 = 0; __pyx_t_13 = 0; __PYX_ERR(0, 2755, __pyx_L7_except_error) } __pyx_L7_except_error:;
2756:
2757:
+2758: cdef Rack_* Rack_GetSlice(const Rack_* that, ssize_t start, ssize_t endex) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_GetSlice(Rack_ const *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex) { Py_ssize_t __pyx_v_ssize; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_GetSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_GetSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2759: cdef:
+2760: ssize_t ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
2761:
+2762: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2763: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+2764: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2765: start = 0 # trim source start
__pyx_v_start = 0;
2766:
+2767: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+2768: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+2769: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2770: endex = start # clamp negative source length
__pyx_v_endex = __pyx_v_start;
2771:
+2772: return Rack_GetSlice_(that, <size_t>start, <size_t>endex)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_GetSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex)); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2772, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
2773:
2774:
+2775: cdef Rack_* Rack_WriteSlice_(Rack_* that, size_t start, size_t endex,
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_WriteSlice_(Rack_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, size_t __pyx_v_size, Block_ **__pyx_v_buffer, int __pyx_v_direct) { size_t __pyx_v_size2; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_WriteSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_WriteSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2776: size_t size, Block_** buffer, bint direct) except NULL:
2777: cdef:
2778: size_t size2 # source size
2779:
+2780: size2 = size
__pyx_v_size2 = __pyx_v_size;
+2781: size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
2782:
+2783: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2784: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2784, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2784, __pyx_L1_error)
+2785: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2786: start = size # trim target start
__pyx_v_start = __pyx_v_size;
2787:
+2788: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2789: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2789, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2789, __pyx_L1_error)
+2790: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2791: endex = size # trim target end
__pyx_v_endex = __pyx_v_size;
2792:
+2793: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2794: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
+2795: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
2796:
+2797: if size2 > size: # enlarge target at range end
__pyx_t_1 = ((__pyx_v_size2 > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L6; }
+2798: that = Rack_Reserve_(that, endex, size2 - size)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size2 - __pyx_v_size)); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2798, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
2799:
+2800: elif size > size2: # shrink target at range end
__pyx_t_1 = ((__pyx_v_size > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ } __pyx_L6:;
+2801: endex -= size - size2
__pyx_v_endex = (__pyx_v_endex - (__pyx_v_size - __pyx_v_size2));
+2802: that = Rack_Delete_(that, endex, size - size2)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Delete_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size - __pyx_v_size2)); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2802, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
2803:
+2804: that = Rack_Write_(that, start, size2, buffer, direct)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Write_(__pyx_v_that, __pyx_v_start, __pyx_v_size2, __pyx_v_buffer, __pyx_v_direct); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2804, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+2805: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2806:
2807:
+2808: cdef Rack_* Rack_WriteSlice(Rack_* that, ssize_t start, ssize_t endex,
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_WriteSlice(Rack_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, size_t __pyx_v_size, Block_ **__pyx_v_buffer, int __pyx_v_direct) { Py_ssize_t __pyx_v_ssize; Py_ssize_t __pyx_v_ssize2; Py_ssize_t __pyx_v_start2; Py_ssize_t __pyx_v_endex2; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_WriteSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_WriteSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2809: size_t size, Block_** buffer, bint direct) except NULL:
2810: cdef:
2811: ssize_t ssize # target size
2812: ssize_t ssize2 # source size
2813: ssize_t start2 # source start
2814: ssize_t endex2 # source end
2815:
+2816: start2 = 0
__pyx_v_start2 = 0;
+2817: endex2 = <ssize_t>size
__pyx_v_endex2 = ((Py_ssize_t)__pyx_v_size);
2818:
+2819: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
2820:
+2821: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2822: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+2823: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
2824: # start2 -= start # skip initial source data # as per bytearray
+2825: start = 0 # trim target start
__pyx_v_start = 0;
+2826: if start2 > endex2:
__pyx_t_1 = ((__pyx_v_start2 > __pyx_v_endex2) != 0); if (__pyx_t_1) { /* … */ }
+2827: start2 = endex2 # clamp source start
__pyx_v_start2 = __pyx_v_endex2;
2828:
+2829: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+2830: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+2831: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2832: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
2833:
+2834: if endex2 < start2:
__pyx_t_1 = ((__pyx_v_endex2 < __pyx_v_start2) != 0); if (__pyx_t_1) { /* … */ }
+2835: endex2 = start2 # clamp negative source length
__pyx_v_endex2 = __pyx_v_start2;
+2836: ssize2 = endex2 - start2
__pyx_v_ssize2 = (__pyx_v_endex2 - __pyx_v_start2);
2837:
+2838: that = Rack_WriteSlice_(that, <size_t>start, <size_t>endex, <size_t>ssize2, &buffer[start2], direct)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_WriteSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), ((size_t)__pyx_v_ssize2), (&(__pyx_v_buffer[__pyx_v_start2])), __pyx_v_direct); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2838, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+2839: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2840:
2841:
+2842: cdef Rack_* Rack_SetSlice_(Rack_* that, size_t start, size_t endex,
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_SetSlice_(Rack_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex, Rack_ *__pyx_v_src, size_t __pyx_v_start2, size_t __pyx_v_endex2) { size_t __pyx_v_size; size_t __pyx_v_size2; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_SetSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_SetSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2843: Rack_* src, size_t start2, size_t endex2) except NULL:
2844: cdef:
2845: size_t size # target size
2846: size_t size2 # source size
2847:
+2848: size2 = src.endex - src.start
__pyx_v_size2 = (__pyx_v_src->endex - __pyx_v_src->start);
2849:
+2850: if start2 > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start2 > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2851: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2851, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2851, __pyx_L1_error)
+2852: elif start2 > size2:
__pyx_t_1 = ((__pyx_v_start2 > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+2853: start2 = size2 # trim source start
__pyx_v_start2 = __pyx_v_size2;
2854:
+2855: if endex2 > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex2 > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2856: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2856, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2856, __pyx_L1_error)
+2857: elif endex2 > size2:
__pyx_t_1 = ((__pyx_v_endex2 > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ }
+2858: endex2 = size2 # trim source end
__pyx_v_endex2 = __pyx_v_size2;
2859:
+2860: if endex2 < start2:
__pyx_t_1 = ((__pyx_v_endex2 < __pyx_v_start2) != 0); if (__pyx_t_1) { /* … */ }
+2861: endex2 = start2 # clamp negative source length
__pyx_v_endex2 = __pyx_v_start2;
+2862: size2 = endex2 - start2
__pyx_v_size2 = (__pyx_v_endex2 - __pyx_v_start2);
2863:
+2864: size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
2865:
+2866: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2867: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2867, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2867, __pyx_L1_error)
+2868: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2869: start = size # trim target start
__pyx_v_start = __pyx_v_size;
2870:
+2871: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2872: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2872, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2872, __pyx_L1_error)
+2873: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2874: endex = size # trim target end
__pyx_v_endex = __pyx_v_size;
2875:
+2876: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2877: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
+2878: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
2879:
+2880: if size2 > size: # enlarge target at range end
__pyx_t_1 = ((__pyx_v_size2 > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L9; }
+2881: that = Rack_Reserve_(that, endex, size2 - size)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size2 - __pyx_v_size)); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2881, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
2882:
+2883: elif size > size2: # shrink target at range end
__pyx_t_1 = ((__pyx_v_size > __pyx_v_size2) != 0); if (__pyx_t_1) { /* … */ } __pyx_L9:;
+2884: endex -= size - size2
__pyx_v_endex = (__pyx_v_endex - (__pyx_v_size - __pyx_v_size2));
+2885: that = Rack_Delete_(that, endex, size - size2)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Delete_(__pyx_v_that, __pyx_v_endex, (__pyx_v_size - __pyx_v_size2)); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2885, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
2886:
+2887: that = Rack_Write_(that, start, size2, &src.blocks[src.start + start2], False)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Write_(__pyx_v_that, __pyx_v_start, __pyx_v_size2, (&(__pyx_v_src->blocks[(__pyx_v_src->start + __pyx_v_start2)])), 0); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2887, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+2888: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2889:
2890:
+2891: cdef Rack_* Rack_SetSlice(Rack_* that, ssize_t start, ssize_t endex,
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_SetSlice(Rack_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex, Rack_ *__pyx_v_src, Py_ssize_t __pyx_v_start2, Py_ssize_t __pyx_v_endex2) { Py_ssize_t __pyx_v_ssize; Py_ssize_t __pyx_v_ssize2; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_SetSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_SetSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2892: Rack_* src, ssize_t start2, ssize_t endex2) except NULL:
2893: cdef:
2894: ssize_t ssize # target size
2895: ssize_t ssize2 # source size
2896:
+2897: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
+2898: ssize2 = <ssize_t>(src.endex - src.start)
__pyx_v_ssize2 = ((Py_ssize_t)(__pyx_v_src->endex - __pyx_v_src->start));
2899:
+2900: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2901: start += ssize # anchor to target end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+2902: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
2903: # start2 -= start # skip initial source data # as per bytearray
+2904: start = 0 # trim target start
__pyx_v_start = 0;
2905:
+2906: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+2907: endex += ssize # anchor to target end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+2908: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2909: endex = start # clamp negative target length
__pyx_v_endex = __pyx_v_start;
2910:
+2911: if start2 < 0:
__pyx_t_1 = ((__pyx_v_start2 < 0) != 0); if (__pyx_t_1) { /* … */ }
+2912: start2 += ssize2 # anchor to source end
__pyx_v_start2 = (__pyx_v_start2 + __pyx_v_ssize2);
+2913: if start2 < 0:
__pyx_t_1 = ((__pyx_v_start2 < 0) != 0); if (__pyx_t_1) { /* … */ }
+2914: start2 = 0 # trim source start
__pyx_v_start2 = 0;
2915:
+2916: if endex2 < 0:
__pyx_t_1 = ((__pyx_v_endex2 < 0) != 0); if (__pyx_t_1) { /* … */ }
+2917: endex2 += ssize2 # anchor to source end
__pyx_v_endex2 = (__pyx_v_endex2 + __pyx_v_ssize2);
+2918: if endex2 < start2:
__pyx_t_1 = ((__pyx_v_endex2 < __pyx_v_start2) != 0); if (__pyx_t_1) { /* … */ }
+2919: endex2 = start2 # clamp negative source length
__pyx_v_endex2 = __pyx_v_start2;
2920:
+2921: that = Rack_SetSlice_(that, <size_t>start, <size_t>endex, src, <size_t>start2, <size_t>endex2)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_SetSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex), __pyx_v_src, ((size_t)__pyx_v_start2), ((size_t)__pyx_v_endex2)); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2921, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+2922: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2923:
2924:
+2925: cdef Rack_* Rack_DelSlice_(Rack_* that, size_t start, size_t endex) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_DelSlice_(Rack_ *__pyx_v_that, size_t __pyx_v_start, size_t __pyx_v_endex) { size_t __pyx_v_size; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_DelSlice_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Rack_DelSlice_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2926: cdef:
2927: size_t size
2928:
+2929: size = that.endex - that.start
__pyx_v_size = (__pyx_v_that->endex - __pyx_v_that->start);
2930:
+2931: if start > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_start > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2932: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2932, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2932, __pyx_L1_error)
+2933: elif start > size:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ }
+2934: start = size # trim start
__pyx_v_start = __pyx_v_size;
2935:
+2936: if endex > SIZE_HMAX:
__pyx_t_1 = ((__pyx_v_endex > SIZE_HMAX) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+2937: raise OverflowError('size overflow')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_OverflowError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2937, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 2937, __pyx_L1_error)
+2938: elif endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+2939: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
+2940: elif endex > size:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:;
+2941: endex = size # trim end
__pyx_v_endex = __pyx_v_size;
2942:
+2943: that = Rack_Delete_(that, start, (endex - start))
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Delete_(__pyx_v_that, __pyx_v_start, (__pyx_v_endex - __pyx_v_start)); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 2943, __pyx_L1_error)
__pyx_v_that = __pyx_t_3;
+2944: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2945:
2946:
+2947: cdef Rack_* Rack_DelSlice(Rack_* that, ssize_t start, ssize_t endex) except NULL:
static Rack_ *__pyx_f_11cbytesparse_1c_Rack_DelSlice(Rack_ *__pyx_v_that, Py_ssize_t __pyx_v_start, Py_ssize_t __pyx_v_endex) { Py_ssize_t __pyx_v_ssize; Rack_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_DelSlice", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rack_DelSlice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2948: cdef:
2949: ssize_t ssize
2950:
+2951: ssize = <ssize_t>(that.endex - that.start)
__pyx_v_ssize = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
2952:
+2953: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2954: start += ssize # anchor to end
__pyx_v_start = (__pyx_v_start + __pyx_v_ssize);
+2955: if start < 0:
__pyx_t_1 = ((__pyx_v_start < 0) != 0); if (__pyx_t_1) { /* … */ }
+2956: start = 0 # trim start
__pyx_v_start = 0;
2957:
+2958: if endex < 0:
__pyx_t_1 = ((__pyx_v_endex < 0) != 0); if (__pyx_t_1) { /* … */ }
+2959: endex += ssize # anchor to end
__pyx_v_endex = (__pyx_v_endex + __pyx_v_ssize);
+2960: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+2961: endex = start # clamp negative length
__pyx_v_endex = __pyx_v_start;
2962:
+2963: that = Rack_DelSlice_(that, <size_t>start, <size_t>endex)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_DelSlice_(__pyx_v_that, ((size_t)__pyx_v_start), ((size_t)__pyx_v_endex)); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 2963, __pyx_L1_error)
__pyx_v_that = __pyx_t_2;
+2964: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
2965:
2966:
+2967: cdef ssize_t Rack_IndexAt(const Rack_* that, addr_t address) except -2:
static Py_ssize_t __pyx_f_11cbytesparse_1c_Rack_IndexAt(Rack_ const *__pyx_v_that, addr_t __pyx_v_address) { Py_ssize_t __pyx_v_left; Py_ssize_t __pyx_v_right; Py_ssize_t __pyx_v_center; Block_ const *__pyx_v_block; Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_IndexAt", 0); /* … */ /* function exit code */ __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
2968: cdef:
+2969: ssize_t left = 0
__pyx_v_left = 0;
+2970: ssize_t right = <ssize_t>(that.endex - that.start)
__pyx_v_right = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
2971: ssize_t center
2972: const Block_* block
2973:
+2974: if right:
__pyx_t_1 = (__pyx_v_right != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+2975: block = that.blocks[that.start]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_that->start]);
+2976: if address < Block_Start(block):
__pyx_t_1 = ((__pyx_v_address < __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ }
+2977: return -1
__pyx_r = -1L; goto __pyx_L0;
2978:
+2979: block = that.blocks[that.endex - 1]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]);
+2980: if Block_Endex(block) <= address:
__pyx_t_1 = ((__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) <= __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ }
+2981: return -1
__pyx_r = -1L; goto __pyx_L0;
2982: else:
+2983: return -1
/*else*/ { __pyx_r = -1L; goto __pyx_L0; } __pyx_L3:;
2984:
+2985: while left <= right:
while (1) { __pyx_t_1 = ((__pyx_v_left <= __pyx_v_right) != 0); if (!__pyx_t_1) break;
+2986: center = (left + right) >> 1
__pyx_v_center = ((__pyx_v_left + __pyx_v_right) >> 1);
+2987: block = that.blocks[that.start + center]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_center)]);
2988:
+2989: if Block_Endex(block) <= address:
__pyx_t_1 = ((__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) <= __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+2990: left = center + 1
__pyx_v_left = (__pyx_v_center + 1);
+2991: elif address < Block_Start(block):
__pyx_t_1 = ((__pyx_v_address < __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+2992: right = center - 1
__pyx_v_right = (__pyx_v_center - 1);
2993: else:
+2994: return center
/*else*/ { __pyx_r = __pyx_v_center; goto __pyx_L0; } __pyx_L8:; }
2995: else:
+2996: return -1
/*else*/ { __pyx_r = -1L; goto __pyx_L0; }
2997:
2998:
+2999: cdef ssize_t Rack_IndexStart(const Rack_* that, addr_t address) except -2:
static Py_ssize_t __pyx_f_11cbytesparse_1c_Rack_IndexStart(Rack_ const *__pyx_v_that, addr_t __pyx_v_address) { Py_ssize_t __pyx_v_left; Py_ssize_t __pyx_v_right; Py_ssize_t __pyx_v_center; Block_ const *__pyx_v_block; Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_IndexStart", 0); /* … */ /* function exit code */ __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3000: cdef:
+3001: ssize_t left = 0
__pyx_v_left = 0;
+3002: ssize_t right = <ssize_t>(that.endex - that.start)
__pyx_v_right = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
3003: ssize_t center
3004: const Block_* block
3005:
+3006: if right:
__pyx_t_1 = (__pyx_v_right != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+3007: block = that.blocks[that.start]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_that->start]);
+3008: if address <= Block_Start(block):
__pyx_t_1 = ((__pyx_v_address <= __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ }
+3009: return 0
__pyx_r = 0; goto __pyx_L0;
3010:
+3011: block = that.blocks[that.endex - 1]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]);
+3012: if Block_Endex(block) <= address:
__pyx_t_1 = ((__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) <= __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ }
+3013: return right
__pyx_r = __pyx_v_right; goto __pyx_L0;
3014: else:
+3015: return 0
/*else*/ { __pyx_r = 0; goto __pyx_L0; } __pyx_L3:;
3016:
+3017: while left <= right:
while (1) { __pyx_t_1 = ((__pyx_v_left <= __pyx_v_right) != 0); if (!__pyx_t_1) break;
+3018: center = (left + right) >> 1
__pyx_v_center = ((__pyx_v_left + __pyx_v_right) >> 1);
+3019: block = that.blocks[that.start + center]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_center)]);
3020:
+3021: if Block_Endex(block) <= address:
__pyx_t_1 = ((__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) <= __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+3022: left = center + 1
__pyx_v_left = (__pyx_v_center + 1);
+3023: elif address < Block_Start(block):
__pyx_t_1 = ((__pyx_v_address < __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+3024: right = center - 1
__pyx_v_right = (__pyx_v_center - 1);
3025: else:
+3026: return center
/*else*/ { __pyx_r = __pyx_v_center; goto __pyx_L0; } __pyx_L8:; }
3027: else:
+3028: return left
/*else*/ { __pyx_r = __pyx_v_left; goto __pyx_L0; }
3029:
3030:
+3031: cdef ssize_t Rack_IndexEndex(const Rack_* that, addr_t address) except -2:
static Py_ssize_t __pyx_f_11cbytesparse_1c_Rack_IndexEndex(Rack_ const *__pyx_v_that, addr_t __pyx_v_address) { Py_ssize_t __pyx_v_left; Py_ssize_t __pyx_v_right; Py_ssize_t __pyx_v_center; Block_ const *__pyx_v_block; Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rack_IndexEndex", 0); /* … */ /* function exit code */ __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3032: cdef:
+3033: ssize_t left = 0
__pyx_v_left = 0;
+3034: ssize_t right = <ssize_t>(that.endex - that.start)
__pyx_v_right = ((Py_ssize_t)(__pyx_v_that->endex - __pyx_v_that->start));
3035: ssize_t center
3036: const Block_* block
3037:
+3038: if right:
__pyx_t_1 = (__pyx_v_right != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+3039: block = that.blocks[that.start]
__pyx_v_block = (__pyx_v_that->blocks[__pyx_v_that->start]);
+3040: if address < Block_Start(block):
__pyx_t_1 = ((__pyx_v_address < __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ }
+3041: return 0
__pyx_r = 0; goto __pyx_L0;
3042:
+3043: block = that.blocks[that.endex - 1]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->endex - 1)]);
+3044: if Block_Endex(block) <= address:
__pyx_t_1 = ((__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) <= __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ }
+3045: return right
__pyx_r = __pyx_v_right; goto __pyx_L0;
3046: else:
+3047: return 0
/*else*/ { __pyx_r = 0; goto __pyx_L0; } __pyx_L3:;
3048:
+3049: while left <= right:
while (1) { __pyx_t_1 = ((__pyx_v_left <= __pyx_v_right) != 0); if (!__pyx_t_1) break;
+3050: center = (left + right) >> 1
__pyx_v_center = ((__pyx_v_left + __pyx_v_right) >> 1);
+3051: block = that.blocks[that.start + center]
__pyx_v_block = (__pyx_v_that->blocks[(__pyx_v_that->start + __pyx_v_center)]);
3052:
+3053: if Block_Endex(block) <= address:
__pyx_t_1 = ((__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) <= __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+3054: left = center + 1
__pyx_v_left = (__pyx_v_center + 1);
+3055: elif address < Block_Start(block):
__pyx_t_1 = ((__pyx_v_address < __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+3056: right = center - 1
__pyx_v_right = (__pyx_v_center - 1);
3057: else:
+3058: return center + 1
/*else*/ { __pyx_r = (__pyx_v_center + 1); goto __pyx_L0; } __pyx_L8:; }
3059: else:
+3060: return right + 1
/*else*/ { __pyx_r = (__pyx_v_right + 1); goto __pyx_L0; }
3061:
3062:
3063: # =====================================================================================================================
3064:
+3065: cdef Memory Memory_AsObject(Memory_* that):
static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_f_11cbytesparse_1c_Memory_AsObject(Memory_ *__pyx_v_that) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; Memory_ *__pyx_v_memory_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_AsObject", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory_AsObject", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3066: cdef:
+3067: Memory memory = Memory()
__pyx_t_1 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3067, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_1); __pyx_t_1 = 0;
+3068: Memory_* memory_ = memory._
__pyx_t_2 = __pyx_v_memory->_; __pyx_v_memory_ = __pyx_t_2;
3069:
+3070: memory_.blocks = Rack_Free(memory_.blocks)
__pyx_v_memory_->blocks = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_memory_->blocks);
+3071: memory_.blocks = Rack_ShallowCopy(that.blocks)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_ShallowCopy(__pyx_v_that->blocks); if (unlikely(__pyx_t_3 == ((Rack_ *)NULL))) __PYX_ERR(0, 3071, __pyx_L1_error)
__pyx_v_memory_->blocks = __pyx_t_3;
+3072: memory_.trim_start = that.trim_start
__pyx_t_4 = __pyx_v_that->trim_start; __pyx_v_memory_->trim_start = __pyx_t_4;
+3073: memory_.trim_endex = that.trim_endex
__pyx_t_4 = __pyx_v_that->trim_endex; __pyx_v_memory_->trim_endex = __pyx_t_4;
+3074: memory_.trim_start_ = that.trim_start_
__pyx_t_5 = __pyx_v_that->trim_start_; __pyx_v_memory_->trim_start_ = __pyx_t_5;
+3075: memory_.trim_endex_ = that.trim_endex_
__pyx_t_5 = __pyx_v_that->trim_endex_; __pyx_v_memory_->trim_endex_ = __pyx_t_5;
+3076: return memory
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = __pyx_v_memory; goto __pyx_L0;
3077:
3078:
+3079: cdef Memory_* Memory_Alloc() except NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Alloc(void) { Rack_ *__pyx_v_blocks; Memory_ *__pyx_v_that; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Alloc", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Alloc", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3080: cdef:
+3081: Rack_* blocks = Rack_Alloc(0)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Alloc(0); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 3081, __pyx_L1_error)
__pyx_v_blocks = __pyx_t_1;
+3082: Memory_* that = NULL
__pyx_v_that = NULL;
3083:
+3084: that = <Memory_*>PyMem_Calloc(Memory_HEADING, 1)
__pyx_v_that = ((Memory_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(Memory_HEADING, 1));
+3085: if that == NULL:
__pyx_t_2 = ((__pyx_v_that == NULL) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+3086: blocks = Rack_Free(blocks)
__pyx_v_blocks = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_blocks);
+3087: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 3087, __pyx_L1_error)
3088:
+3089: that.blocks = blocks
__pyx_v_that->blocks = __pyx_v_blocks;
+3090: that.trim_start = 0
__pyx_v_that->trim_start = 0;
+3091: that.trim_endex = ADDR_MAX
__pyx_v_that->trim_endex = ADDR_MAX;
+3092: that.trim_start_ = False
__pyx_v_that->trim_start_ = 0;
+3093: that.trim_endex_ = False
__pyx_v_that->trim_endex_ = 0;
+3094: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
3095:
3096:
+3097: cdef Memory_* Memory_Free(Memory_* that) except? NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Free(Memory_ *__pyx_v_that) { Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Free", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3098: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (__pyx_t_1) { /* … */ }
+3099: that.blocks = Rack_Free(that.blocks)
__pyx_v_that->blocks = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_that->blocks);
+3100: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
+3101: return NULL
__pyx_r = NULL; goto __pyx_L0;
3102:
3103:
+3104: cdef Memory_* Memory_Create(
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Create(Memory_ *__pyx_v_memory, __Pyx_memviewslice __pyx_v_data, PyObject *__pyx_v_offset, PyObject *__pyx_v_blocks, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, int __pyx_v_copy, int __pyx_v_validate) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; addr_t __pyx_v_address; size_t __pyx_v_size; byte_t const *__pyx_v_ptr; Block_ *__pyx_v_block; Rack_ *__pyx_v_blocks_; Memory_ *__pyx_v_that; int __pyx_v_validate_; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Create", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_17); __Pyx_XDECREF(__pyx_t_18); __Pyx_AddTraceback("cbytesparse.c.Memory_Create", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3105: Memory_* memory,
3106: const byte_t[:] data,
3107: object offset,
3108: object blocks,
3109: object start,
3110: object endex,
3111: bint copy,
3112: bint validate,
3113: ) except NULL:
3114: cdef:
3115: addr_t start_
3116: addr_t endex_
3117: addr_t address
3118: size_t size
+3119: const byte_t* ptr = NULL
__pyx_v_ptr = NULL;
+3120: Block_* block = NULL
__pyx_v_block = NULL;
+3121: Rack_* blocks_ = NULL
__pyx_v_blocks_ = NULL;
+3122: Memory_* that = NULL
__pyx_v_that = NULL;
+3123: bint validate_ = validate
__pyx_v_validate_ = __pyx_v_validate;
3124:
+3125: if (memory != NULL) + (data is not None) + (blocks is not None) > 1:
__pyx_t_1 = (__pyx_v_blocks != Py_None); __pyx_t_2 = (((((__pyx_v_memory != NULL) + (((PyObject *) __pyx_v_data.memview) != Py_None)) + __pyx_t_1) > 1) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+3126: raise ValueError('only one of [memory, data, blocks] is allowed')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__15, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3126, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 3126, __pyx_L1_error) /* … */ __pyx_tuple__15 = PyTuple_Pack(1, __pyx_kp_u_only_one_of_memory_data_blocks_i); if (unlikely(!__pyx_tuple__15)) __PYX_ERR(0, 3126, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__15); __Pyx_GIVEREF(__pyx_tuple__15);
3127:
+3128: that = <Memory_*>PyMem_Calloc(Memory_HEADING, 1)
__pyx_v_that = ((Memory_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(Memory_HEADING, 1));
+3129: if that == NULL:
__pyx_t_2 = ((__pyx_v_that == NULL) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+3130: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 3130, __pyx_L1_error)
3131:
+3132: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; goto __pyx_L10_try_end; __pyx_L5_error:; __Pyx_XDECREF(__pyx_t_17); __pyx_t_17 = 0; __Pyx_XDECREF(__pyx_t_18); __pyx_t_18 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6); goto __pyx_L1_error; __pyx_L10_try_end:; }
+3133: start_ = ADDR_MIN if start is None else <addr_t>start
__pyx_t_2 = (__pyx_v_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_7 = ADDR_MIN; } else { __pyx_t_8 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_8 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3133, __pyx_L5_error) __pyx_t_7 = ((addr_t)__pyx_t_8); } __pyx_v_start_ = __pyx_t_7;
+3134: endex_ = ADDR_MAX if endex is None else <addr_t>endex
__pyx_t_2 = (__pyx_v_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_7 = ADDR_MAX; } else { __pyx_t_8 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_8 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3134, __pyx_L5_error) __pyx_t_7 = ((addr_t)__pyx_t_8); } __pyx_v_endex_ = __pyx_t_7;
+3135: if endex_ < start_:
__pyx_t_2 = ((__pyx_v_endex_ < __pyx_v_start_) != 0); if (__pyx_t_2) { /* … */ }
+3136: endex_ = start_ # clamp negative length
__pyx_v_endex_ = __pyx_v_start_;
3137:
+3138: if memory != NULL:
__pyx_t_2 = ((__pyx_v_memory != NULL) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L12; }
+3139: if copy or offset:
__pyx_t_1 = (__pyx_v_copy != 0); if (!__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L14_bool_binop_done; } __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_offset); if (unlikely(__pyx_t_1 < 0)) __PYX_ERR(0, 3139, __pyx_L5_error) __pyx_t_2 = __pyx_t_1; __pyx_L14_bool_binop_done:; if (__pyx_t_2) { /* … */ goto __pyx_L13; }
+3140: blocks_ = Rack_Copy(memory.blocks)
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_Copy(__pyx_v_memory->blocks); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3140, __pyx_L5_error)
__pyx_v_blocks_ = __pyx_t_9;
+3141: blocks_ = Rack_Shift(blocks_, <saddr_t>offset)
__pyx_t_10 = __Pyx_PyInt_As_int_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_10 == ((saddr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3141, __pyx_L5_error) __pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_Shift(__pyx_v_blocks_, ((saddr_t)__pyx_t_10)); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3141, __pyx_L5_error) __pyx_v_blocks_ = __pyx_t_9;
3142: else:
+3143: blocks_ = Rack_ShallowCopy(memory.blocks)
/*else*/ {
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_ShallowCopy(__pyx_v_memory->blocks); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3143, __pyx_L5_error)
__pyx_v_blocks_ = __pyx_t_9;
}
__pyx_L13:;
3144:
+3145: elif data is not None:
__pyx_t_2 = ((((PyObject *) __pyx_v_data.memview) != Py_None) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L12; }
+3146: if offset < 0:
__pyx_t_3 = PyObject_RichCompare(__pyx_v_offset, __pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3146, __pyx_L5_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3146, __pyx_L5_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(__pyx_t_2)) { /* … */ }
+3147: raise ValueError('negative offset')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__16, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3147, __pyx_L5_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 3147, __pyx_L5_error) /* … */ __pyx_tuple__16 = PyTuple_Pack(1, __pyx_kp_u_negative_offset); if (unlikely(!__pyx_tuple__16)) __PYX_ERR(0, 3147, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__16); __Pyx_GIVEREF(__pyx_tuple__16);
3148:
+3149: address = <addr_t>offset
__pyx_t_7 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_7 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3149, __pyx_L5_error) __pyx_v_address = ((addr_t)__pyx_t_7);
+3150: size = <size_t>len(data)
__pyx_t_11 = __Pyx_MemoryView_Len(__pyx_v_data);
__pyx_v_size = ((size_t)__pyx_t_11);
+3151: blocks_ = Rack_Alloc(0)
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_Alloc(0); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3151, __pyx_L5_error)
__pyx_v_blocks_ = __pyx_t_9;
3152:
+3153: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
3154: with cython.boundscheck(False):
+3155: ptr = &data[0]
__pyx_t_12 = 0; if (__pyx_t_12 < 0) __pyx_t_12 += __pyx_v_data.shape[0]; __pyx_v_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_data.data + __pyx_t_12 * __pyx_v_data.strides[0]) ))));
+3156: block = Block_Create(address, size, ptr)
__pyx_t_13 = __pyx_f_11cbytesparse_1c_Block_Create(__pyx_v_address, __pyx_v_size, __pyx_v_ptr); if (unlikely(__pyx_t_13 == ((Block_ *)NULL))) __PYX_ERR(0, 3156, __pyx_L5_error)
__pyx_v_block = __pyx_t_13;
+3157: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0; goto __pyx_L23_try_end; __pyx_L18_error:; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_ExceptionReset(__pyx_t_14, __pyx_t_15, __pyx_t_16); goto __pyx_L5_error; __pyx_L23_try_end:; }
+3158: blocks_ = Rack_Append(blocks_, block)
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_Append(__pyx_v_blocks_, __pyx_v_block); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3158, __pyx_L18_error)
__pyx_v_blocks_ = __pyx_t_9;
+3159: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Create", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_3, &__pyx_t_17, &__pyx_t_18) < 0) __PYX_ERR(0, 3159, __pyx_L20_except_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_GOTREF(__pyx_t_17); __Pyx_GOTREF(__pyx_t_18);
+3160: block = Block_Free(block)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block);
+3161: raise
__Pyx_GIVEREF(__pyx_t_3); __Pyx_GIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_ErrRestoreWithState(__pyx_t_3, __pyx_t_17, __pyx_t_18); __pyx_t_3 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __PYX_ERR(0, 3161, __pyx_L20_except_error) } __pyx_L20_except_error:;
3162:
+3163: elif blocks:
__pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_v_blocks); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3163, __pyx_L5_error) if (__pyx_t_2) { /* … */ goto __pyx_L12; }
+3164: blocks_ = Rack_FromObject(blocks, <saddr_t>offset)
__pyx_t_10 = __Pyx_PyInt_As_int_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_10 == ((saddr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3164, __pyx_L5_error) __pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_FromObject(__pyx_v_blocks, ((saddr_t)__pyx_t_10)); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3164, __pyx_L5_error) __pyx_v_blocks_ = __pyx_t_9;
3165:
3166: else:
+3167: blocks_ = Rack_Alloc(0)
/*else*/ {
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_Alloc(0); if (unlikely(__pyx_t_9 == ((Rack_ *)NULL))) __PYX_ERR(0, 3167, __pyx_L5_error)
__pyx_v_blocks_ = __pyx_t_9;
}
__pyx_L12:;
3168:
+3169: that.blocks = blocks_
__pyx_v_that->blocks = __pyx_v_blocks_;
+3170: blocks_ = NULL
__pyx_v_blocks_ = NULL;
3171:
+3172: that.trim_start = start_
__pyx_v_that->trim_start = __pyx_v_start_;
+3173: that.trim_endex = endex_
__pyx_v_that->trim_endex = __pyx_v_endex_;
+3174: that.trim_start_ = start is not None
__pyx_t_2 = (__pyx_v_start != Py_None); __pyx_v_that->trim_start_ = __pyx_t_2;
+3175: that.trim_endex_ = endex is not None
__pyx_t_2 = (__pyx_v_endex != Py_None); __pyx_v_that->trim_endex_ = __pyx_t_2;
3176:
+3177: if (that.trim_start_ or that.trim_endex_) and validate_: # fast check
__pyx_t_1 = (__pyx_v_that->trim_start_ != 0); if (!__pyx_t_1) { } else { goto __pyx_L28_next_and; } __pyx_t_1 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L27_bool_binop_done; } __pyx_L28_next_and:; __pyx_t_1 = (__pyx_v_validate_ != 0); __pyx_t_2 = __pyx_t_1; __pyx_L27_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+3178: Memory_Crop_(that, start_, endex_)
__pyx_t_19 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_19 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3178, __pyx_L5_error)
3179:
+3180: if validate_:
__pyx_t_2 = (__pyx_v_validate_ != 0); if (__pyx_t_2) { /* … */ }
+3181: Memory_Validate(that)
__pyx_t_19 = __pyx_f_11cbytesparse_1c_Memory_Validate(__pyx_v_that); if (unlikely(__pyx_t_19 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3181, __pyx_L5_error)
3182:
+3183: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Create", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_18, &__pyx_t_17, &__pyx_t_3) < 0) __PYX_ERR(0, 3183, __pyx_L7_except_error) __Pyx_GOTREF(__pyx_t_18); __Pyx_GOTREF(__pyx_t_17); __Pyx_GOTREF(__pyx_t_3);
+3184: Rack_Free(blocks_)
(void)(__pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_blocks_));
+3185: that = Memory_Free(that)
__pyx_t_20 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_that); if (unlikely(__pyx_t_20 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3185, __pyx_L7_except_error) __pyx_v_that = __pyx_t_20;
+3186: raise
__Pyx_GIVEREF(__pyx_t_18); __Pyx_GIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ErrRestoreWithState(__pyx_t_18, __pyx_t_17, __pyx_t_3); __pyx_t_18 = 0; __pyx_t_17 = 0; __pyx_t_3 = 0; __PYX_ERR(0, 3186, __pyx_L7_except_error) } __pyx_L7_except_error:;
3187:
+3188: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
3189:
3190:
+3191: cdef bint Memory_EqSame_(const Memory_* that, const Memory_* other) except -1:
static int __pyx_f_11cbytesparse_1c_Memory_EqSame_(Memory_ const *__pyx_v_that, Memory_ const *__pyx_v_other) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_EqSame_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_EqSame_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3192: return Rack_Eq(that.blocks, other.blocks)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Eq(__pyx_v_that->blocks, __pyx_v_other->blocks); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 3192, __pyx_L1_error)
__pyx_r = __pyx_t_1;
goto __pyx_L0;
3193:
3194:
+3195: cdef bint Memory_EqRaw_(const Memory_* that, size_t data_size, const byte_t* data_ptr) except -1:
static int __pyx_f_11cbytesparse_1c_Memory_EqRaw_(Memory_ const *__pyx_v_that, size_t __pyx_v_data_size, byte_t const *__pyx_v_data_ptr) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_count; Block_ const *__pyx_v_block; size_t __pyx_v_size; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_EqRaw_", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3196: cdef:
+3197: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3198: size_t block_count
3199: const Block_* block
3200: size_t size
3201:
+3202: block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
+3203: if block_count:
__pyx_t_2 = (__pyx_v_block_count != 0); if (__pyx_t_2) { /* … */ }
+3204: if block_count != 1:
__pyx_t_2 = ((__pyx_v_block_count != 1) != 0); if (__pyx_t_2) { /* … */ }
+3205: return False
__pyx_r = 0; goto __pyx_L0;
3206:
+3207: block = Rack_First__(blocks)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_First__(__pyx_v_blocks);
+3208: size = Block_Length(block)
__pyx_v_size = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block);
+3209: if data_size != size:
__pyx_t_2 = ((__pyx_v_data_size != __pyx_v_size) != 0); if (__pyx_t_2) { /* … */ }
+3210: return False
__pyx_r = 0; goto __pyx_L0;
3211:
+3212: if memcmp(Block_At__(block, 0), data_ptr, data_size):
__pyx_t_2 = (memcmp(__pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, 0), __pyx_v_data_ptr, __pyx_v_data_size) != 0); if (__pyx_t_2) { /* … */ }
+3213: return False
__pyx_r = 0; goto __pyx_L0;
+3214: return True
__pyx_r = 1; goto __pyx_L0;
3215: else:
+3216: return not data_size
/*else*/ { __pyx_r = (!(__pyx_v_data_size != 0)); goto __pyx_L0; }
3217:
3218:
+3219: cdef bint Memory_EqView_(const Memory_* that, const byte_t[:] view) except -1:
static int __pyx_f_11cbytesparse_1c_Memory_EqView_(Memory_ const *__pyx_v_that, __Pyx_memviewslice __pyx_v_view) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_EqView_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_EqView_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3220: with cython.boundscheck(False):
+3221: return Memory_EqRaw_(that, len(view), &view[0])
__pyx_t_1 = __Pyx_MemoryView_Len(__pyx_v_view); __pyx_t_2 = 0; if (__pyx_t_2 < 0) __pyx_t_2 += __pyx_v_view.shape[0]; __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_EqRaw_(__pyx_v_that, __pyx_t_1, (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_view.data + __pyx_t_2 * __pyx_v_view.strides[0]) ))))); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(0, 3221, __pyx_L1_error) __pyx_r = __pyx_t_3; goto __pyx_L0;
3222:
3223:
+3224: cdef bint Memory_EqIter_(const Memory_* that, object iterable) except -1:
static int __pyx_f_11cbytesparse_1c_Memory_EqIter_(Memory_ const *__pyx_v_that, PyObject *__pyx_v_iterable) { addr_t __pyx_v_start; addr_t __pyx_v_endex; Rover_ *__pyx_v_rover; int __pyx_v_equal; int __pyx_v_item1_; int __pyx_v_item2_; PyObject *__pyx_v_item2 = NULL; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_EqIter_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory_EqIter_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_XDECREF(__pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3225: cdef:
+3226: addr_t start = Memory_Start(that)
__pyx_v_start = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that);
+3227: addr_t endex = Memory_ContentEndex(that)
__pyx_v_endex = __pyx_f_11cbytesparse_1c_Memory_ContentEndex(__pyx_v_that);
+3228: Rover_* rover = Rover_Create(that, start, endex, 0, NULL, True, False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rover_Create(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0, NULL, 1, 0); if (unlikely(__pyx_t_1 == ((Rover_ *)NULL))) __PYX_ERR(0, 3228, __pyx_L1_error)
__pyx_v_rover = __pyx_t_1;
+3229: bint equal = True
__pyx_v_equal = 1;
3230: int item1_
3231: int item2_
3232:
+3233: try:
/*try:*/ {
+3234: for item2 in iterable:
if (likely(PyList_CheckExact(__pyx_v_iterable)) || PyTuple_CheckExact(__pyx_v_iterable)) { __pyx_t_2 = __pyx_v_iterable; __Pyx_INCREF(__pyx_t_2); __pyx_t_3 = 0; __pyx_t_4 = NULL; } else { __pyx_t_3 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_v_iterable); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 3234, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = Py_TYPE(__pyx_t_2)->tp_iternext; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3234, __pyx_L4_error) } for (;;) { if (likely(!__pyx_t_4)) { if (likely(PyList_CheckExact(__pyx_t_2))) { if (__pyx_t_3 >= PyList_GET_SIZE(__pyx_t_2)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_3); __Pyx_INCREF(__pyx_t_5); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(0, 3234, __pyx_L4_error) #else __pyx_t_5 = PySequence_ITEM(__pyx_t_2, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 3234, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_5); #endif } else { if (__pyx_t_3 >= PyTuple_GET_SIZE(__pyx_t_2)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_3); __Pyx_INCREF(__pyx_t_5); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(0, 3234, __pyx_L4_error) #else __pyx_t_5 = PySequence_ITEM(__pyx_t_2, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 3234, __pyx_L4_error) __Pyx_GOTREF(__pyx_t_5); #endif } } else { __pyx_t_5 = __pyx_t_4(__pyx_t_2); if (unlikely(!__pyx_t_5)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); else __PYX_ERR(0, 3234, __pyx_L4_error) } break; } __Pyx_GOTREF(__pyx_t_5); } __Pyx_XDECREF_SET(__pyx_v_item2, __pyx_t_5); __pyx_t_5 = 0; /* … */ } /*else*/ { /* … */ __pyx_L7_break:; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; }
+3235: item1_ = Rover_Next_(rover) if Rover_HasNext(rover) else -1
if ((__pyx_f_11cbytesparse_1c_Rover_HasNext(__pyx_v_rover) != 0)) {
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Rover_Next_(__pyx_v_rover); if (unlikely(__pyx_t_7 == ((int)-2))) __PYX_ERR(0, 3235, __pyx_L4_error)
__pyx_t_6 = __pyx_t_7;
} else {
__pyx_t_6 = -1;
}
__pyx_v_item1_ = __pyx_t_6;
+3236: item2_ = -1 if item2 is None else <int><unsigned><byte_t>item2
__pyx_t_8 = (__pyx_v_item2 == Py_None); if ((__pyx_t_8 != 0)) { __pyx_t_6 = -1; } else { __pyx_t_9 = __Pyx_PyInt_As_byte_t(__pyx_v_item2); if (unlikely((__pyx_t_9 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3236, __pyx_L4_error) __pyx_t_6 = ((int)((unsigned int)((byte_t)__pyx_t_9))); } __pyx_v_item2_ = __pyx_t_6;
3237:
+3238: if item1_ != item2_:
__pyx_t_8 = ((__pyx_v_item1_ != __pyx_v_item2_) != 0); if (__pyx_t_8) { /* … */ }
+3239: equal = False
__pyx_v_equal = 0;
+3240: break
goto __pyx_L7_break;
3241: else:
+3242: if Rover_HasNext(rover):
__pyx_t_8 = (__pyx_f_11cbytesparse_1c_Rover_HasNext(__pyx_v_rover) != 0); if (__pyx_t_8) { /* … */ } }
+3243: equal = False
__pyx_v_equal = 0;
3244: finally:
+3245: Rover_Free(rover)
/*finally:*/ { /*normal exit:*/{ __pyx_t_1 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_v_rover); if (unlikely(__pyx_t_1 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3245, __pyx_L1_error) goto __pyx_L5; } __pyx_L4_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_11 = 0; __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_11, &__pyx_t_12, &__pyx_t_13) < 0)) __Pyx_ErrFetch(&__pyx_t_11, &__pyx_t_12, &__pyx_t_13); __Pyx_XGOTREF(__pyx_t_11); __Pyx_XGOTREF(__pyx_t_12); __Pyx_XGOTREF(__pyx_t_13); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_15); __Pyx_XGOTREF(__pyx_t_16); __pyx_t_6 = __pyx_lineno; __pyx_t_7 = __pyx_clineno; __pyx_t_10 = __pyx_filename; { __pyx_t_1 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_v_rover); if (unlikely(__pyx_t_1 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3245, __pyx_L12_error) } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_ExceptionReset(__pyx_t_14, __pyx_t_15, __pyx_t_16); } __Pyx_XGIVEREF(__pyx_t_11); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_XGIVEREF(__pyx_t_13); __Pyx_ErrRestore(__pyx_t_11, __pyx_t_12, __pyx_t_13); __pyx_t_11 = 0; __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_lineno = __pyx_t_6; __pyx_clineno = __pyx_t_7; __pyx_filename = __pyx_t_10; goto __pyx_L1_error; __pyx_L12_error:; if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_ExceptionReset(__pyx_t_14, __pyx_t_15, __pyx_t_16); } __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; goto __pyx_L1_error; } __pyx_L5:; }
3246:
+3247: return equal
__pyx_r = __pyx_v_equal; goto __pyx_L0;
3248:
3249:
+3250: cdef bint Memory_Eq(const Memory_* that, object other) except -1:
static int __pyx_f_11cbytesparse_1c_Memory_Eq(Memory_ const *__pyx_v_that, PyObject *__pyx_v_other) { __Pyx_memviewslice __pyx_v_view = { 0, 0, { 0 }, { 0 }, { 0 } }; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Eq", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_6, 1); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_10); __Pyx_AddTraceback("cbytesparse.c.Memory_Eq", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3251: cdef:
3252: const byte_t[:] view
3253:
+3254: if isinstance(other, Memory):
__pyx_t_1 = __Pyx_TypeCheck(__pyx_v_other, __pyx_ptype_11cbytesparse_1c_Memory);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
}
+3255: return Memory_EqSame_(that, (<Memory>other)._)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_EqSame_(__pyx_v_that, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_other)->_); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(0, 3255, __pyx_L1_error)
__pyx_r = __pyx_t_2;
goto __pyx_L0;
3256: else:
+3257: try:
/*else*/ { { /*try:*/ { /* … */ } /* … */ __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5); goto __pyx_L1_error; __pyx_L7_except_return:; __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5); goto __pyx_L0; } }
+3258: view = other
__pyx_t_6 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_other, 0); if (unlikely(!__pyx_t_6.memview)) __PYX_ERR(0, 3258, __pyx_L4_error) __pyx_v_view = __pyx_t_6; __pyx_t_6.memview = NULL; __pyx_t_6.data = NULL;
+3259: except TypeError:
__pyx_t_7 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError); if (__pyx_t_7) { __Pyx_AddTraceback("cbytesparse.c.Memory_Eq", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_8, &__pyx_t_9, &__pyx_t_10) < 0) __PYX_ERR(0, 3259, __pyx_L6_except_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GOTREF(__pyx_t_9); __Pyx_GOTREF(__pyx_t_10);
+3260: return Memory_EqIter_(that, other)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_EqIter_(__pyx_v_that, __pyx_v_other); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(0, 3260, __pyx_L6_except_error) __pyx_r = __pyx_t_2; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; goto __pyx_L7_except_return; } goto __pyx_L6_except_error; __pyx_L6_except_error:;
3261: else:
+3262: return Memory_EqView_(that, view)
/*else:*/ {
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_EqView_(__pyx_v_that, __pyx_v_view); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(0, 3262, __pyx_L6_except_error)
__pyx_r = __pyx_t_2;
goto __pyx_L7_except_return;
}
__pyx_L4_error:;
__PYX_XDEC_MEMVIEW(&__pyx_t_6, 1);
3263:
3264:
+3265: cdef Memory_* Memory_Add(const Memory_* that, object value) except NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Add(Memory_ const *__pyx_v_that, PyObject *__pyx_v_value) { Memory_ *__pyx_v_memory; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Add", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("cbytesparse.c.Memory_Add", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3266: cdef:
+3267: Memory_* memory = Memory_Copy(that)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Copy(__pyx_v_that); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 3267, __pyx_L1_error)
__pyx_v_memory = __pyx_t_1;
+3268: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; goto __pyx_L8_try_end; __pyx_L3_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_4); __Pyx_ExceptionReset(__pyx_t_2, __pyx_t_3, __pyx_t_4); goto __pyx_L1_error; __pyx_L8_try_end:; }
+3269: Memory_Extend(memory, value, 0)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_Extend(__pyx_v_memory, __pyx_v_value, __pyx_int_0); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3269, __pyx_L3_error)
+3270: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Add", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8) < 0) __PYX_ERR(0, 3270, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GOTREF(__pyx_t_7); __Pyx_GOTREF(__pyx_t_8);
+3271: memory = Memory_Free(memory)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3271, __pyx_L5_except_error) __pyx_v_memory = __pyx_t_1;
+3272: raise
__Pyx_GIVEREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ErrRestoreWithState(__pyx_t_6, __pyx_t_7, __pyx_t_8); __pyx_t_6 = 0; __pyx_t_7 = 0; __pyx_t_8 = 0; __PYX_ERR(0, 3272, __pyx_L5_except_error) } __pyx_L5_except_error:;
+3273: return memory
__pyx_r = __pyx_v_memory; goto __pyx_L0;
3274:
3275:
+3276: cdef Memory_* Memory_IAdd(Memory_* that, object value) except NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_IAdd(Memory_ *__pyx_v_that, PyObject *__pyx_v_value) { Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_IAdd", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_IAdd", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3277: Memory_Extend(that, value, 0)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Extend(__pyx_v_that, __pyx_v_value, __pyx_int_0); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3277, __pyx_L1_error)
+3278: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
3279:
3280:
+3281: cdef Memory_* Memory_Mul(const Memory_* that, addr_t times) except NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Mul(Memory_ const *__pyx_v_that, addr_t __pyx_v_times) { Memory_ *__pyx_v_memory; addr_t __pyx_v_offset; addr_t __pyx_v_size; CYTHON_UNUSED addr_t __pyx_v_time; PyObject *__pyx_v_start = NULL; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Mul", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_13); __Pyx_AddTraceback("cbytesparse.c.Memory_Mul", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_start); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3282: cdef:
+3283: Memory_* memory = NULL
__pyx_v_memory = NULL;
3284: addr_t offset
3285: addr_t size
3286: addr_t time
3287:
+3288: if times and Rack_Length(that.blocks):
__pyx_t_2 = (__pyx_v_times != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L4_bool_binop_done; } __pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L4_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+3289: start = Memory_Start(that)
__pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3289, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_v_start = __pyx_t_3; __pyx_t_3 = 0;
+3290: size = Memory_Endex(that) - start
__pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3290, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = PyNumber_Subtract(__pyx_t_3, __pyx_v_start); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3290, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_4); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3290, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_v_size = __pyx_t_5;
+3291: offset = size # adjust first write
__pyx_v_offset = __pyx_v_size;
+3292: memory = Memory_Copy(that)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Copy(__pyx_v_that); if (unlikely(__pyx_t_6 == ((Memory_ *)NULL))) __PYX_ERR(0, 3292, __pyx_L1_error)
__pyx_v_memory = __pyx_t_6;
+3293: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; goto __pyx_L11_try_end; __pyx_L6_error:; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_XGIVEREF(__pyx_t_9); __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); goto __pyx_L1_error; __pyx_L11_try_end:; }
+3294: for time in range(times - 1):
__pyx_t_5 = (__pyx_v_times - 1); __pyx_t_10 = __pyx_t_5; for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_10; __pyx_t_11+=1) { __pyx_v_time = __pyx_t_11;
+3295: Memory_WriteSame_(memory, offset, that, False)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_memory, __pyx_v_offset, __pyx_v_that, 0); if (unlikely(__pyx_t_12 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3295, __pyx_L6_error)
+3296: offset += size
__pyx_v_offset = (__pyx_v_offset + __pyx_v_size); }
+3297: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Mul", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_3, &__pyx_t_13) < 0) __PYX_ERR(0, 3297, __pyx_L8_except_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_GOTREF(__pyx_t_3); __Pyx_GOTREF(__pyx_t_13);
+3298: memory = Memory_Free(memory)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory); if (unlikely(__pyx_t_6 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3298, __pyx_L8_except_error) __pyx_v_memory = __pyx_t_6;
+3299: raise
__Pyx_GIVEREF(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_3); __Pyx_XGIVEREF(__pyx_t_13); __Pyx_ErrRestoreWithState(__pyx_t_4, __pyx_t_3, __pyx_t_13); __pyx_t_4 = 0; __pyx_t_3 = 0; __pyx_t_13 = 0; __PYX_ERR(0, 3299, __pyx_L8_except_error) } __pyx_L8_except_error:;
3300:
+3301: return memory
__pyx_r = __pyx_v_memory; goto __pyx_L0;
3302: else:
+3303: return Memory_Alloc()
/*else*/ {
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Alloc(); if (unlikely(__pyx_t_6 == ((Memory_ *)NULL))) __PYX_ERR(0, 3303, __pyx_L1_error)
__pyx_r = __pyx_t_6;
goto __pyx_L0;
}
3304:
3305:
+3306: cdef Memory_* Memory_IMul(Memory_* that, addr_t times) except NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_IMul(Memory_ *__pyx_v_that, addr_t __pyx_v_times) { Memory_ *__pyx_v_memory; addr_t __pyx_v_offset; PyObject *__pyx_v_start = NULL; PyObject *__pyx_v_size = NULL; CYTHON_UNUSED addr_t __pyx_v_time; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_IMul", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory_IMul", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_start); __Pyx_XDECREF(__pyx_v_size); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3307: cdef:
+3308: Memory_* memory = NULL
__pyx_v_memory = NULL;
3309: addr_t offset
3310:
3311: times = int(times)
+3312: if times < 0:
__pyx_t_1 = ((__pyx_v_times < 0) != 0); if (__pyx_t_1) { /* … */ }
+3313: times = 0
__pyx_v_times = 0;
3314:
+3315: if times and Rack_Length(that.blocks):
__pyx_t_2 = (__pyx_v_times != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; } __pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); __pyx_t_1 = __pyx_t_2; __pyx_L5_bool_binop_done:; if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+3316: start = Memory_Start(that)
__pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3316, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_v_start = __pyx_t_3; __pyx_t_3 = 0;
+3317: size = Memory_Endex(that) - start
__pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3317, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = PyNumber_Subtract(__pyx_t_3, __pyx_v_start); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3317, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_size = __pyx_t_4; __pyx_t_4 = 0;
+3318: offset = size
__pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3318, __pyx_L1_error) __pyx_v_offset = __pyx_t_5;
+3319: memory = Memory_Copy(that)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Copy(__pyx_v_that); if (unlikely(__pyx_t_6 == ((Memory_ *)NULL))) __PYX_ERR(0, 3319, __pyx_L1_error)
__pyx_v_memory = __pyx_t_6;
+3320: try:
/*try:*/ {
+3321: for time in range(times - 1):
__pyx_t_5 = (__pyx_v_times - 1); __pyx_t_7 = __pyx_t_5; for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) { __pyx_v_time = __pyx_t_8;
+3322: Memory_WriteSame_(that, offset, memory, False)
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_that, __pyx_v_offset, __pyx_v_memory, 0); if (unlikely(__pyx_t_9 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3322, __pyx_L8_error)
+3323: offset += size
__pyx_t_4 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_offset); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3323, __pyx_L8_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = PyNumber_InPlaceAdd(__pyx_t_4, __pyx_v_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3323, __pyx_L8_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_10 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_3); if (unlikely((__pyx_t_10 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3323, __pyx_L8_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_offset = __pyx_t_10; } }
3324: finally:
+3325: memory = Memory_Free(memory)
/*finally:*/ { /*normal exit:*/{ __pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory); if (unlikely(__pyx_t_6 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3325, __pyx_L1_error) __pyx_v_memory = __pyx_t_6; goto __pyx_L9; } __pyx_L8_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_17, &__pyx_t_18, &__pyx_t_19); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16) < 0)) __Pyx_ErrFetch(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_15); __Pyx_XGOTREF(__pyx_t_16); __Pyx_XGOTREF(__pyx_t_17); __Pyx_XGOTREF(__pyx_t_18); __Pyx_XGOTREF(__pyx_t_19); __pyx_t_11 = __pyx_lineno; __pyx_t_12 = __pyx_clineno; __pyx_t_13 = __pyx_filename; { __pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory); if (unlikely(__pyx_t_6 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 3325, __pyx_L13_error) __pyx_v_memory = __pyx_t_6; } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_XGIVEREF(__pyx_t_19); __Pyx_ExceptionReset(__pyx_t_17, __pyx_t_18, __pyx_t_19); } __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_ErrRestore(__pyx_t_14, __pyx_t_15, __pyx_t_16); __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; __pyx_lineno = __pyx_t_11; __pyx_clineno = __pyx_t_12; __pyx_filename = __pyx_t_13; goto __pyx_L1_error; __pyx_L13_error:; if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_XGIVEREF(__pyx_t_19); __Pyx_ExceptionReset(__pyx_t_17, __pyx_t_18, __pyx_t_19); } __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; goto __pyx_L1_error; } __pyx_L9:; }
3326: else:
+3327: that.blocks = Rack_Clear(that.blocks)
/*else*/ {
__pyx_t_20 = __pyx_f_11cbytesparse_1c_Rack_Clear(__pyx_v_that->blocks); if (unlikely(__pyx_t_20 == ((Rack_ *)NULL))) __PYX_ERR(0, 3327, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_20;
}
__pyx_L4:;
+3328: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
3329:
3330:
+3331: cdef addr_t Memory_Length(const Memory_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Memory_Length(Memory_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+3332: return Memory_Endex(that) - Memory_Start(that)
__pyx_r = (__pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that) - __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that)); goto __pyx_L0;
3333:
3334:
+3335: cdef bint Memory_IsEmpty(const Memory_* that) nogil:
static int __pyx_f_11cbytesparse_1c_Memory_IsEmpty(Memory_ const *__pyx_v_that) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+3336: return Rack_Length(that.blocks) == 0
__pyx_r = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) == 0); goto __pyx_L0;
3337:
3338:
+3339: cdef object Memory_ObjFind(const Memory_* that, object item, object start, object endex):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_ObjFind(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_v_offset = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ObjFind", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory_ObjFind", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_offset); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3340: offset = Memory_Find(that, item, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Find(__pyx_v_that, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3340, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_offset = __pyx_t_1; __pyx_t_1 = 0;
+3341: if offset >= 0:
__pyx_t_1 = PyObject_RichCompare(__pyx_v_offset, __pyx_int_0, Py_GE); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3341, __pyx_L1_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3341, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_2) { /* … */ }
+3342: return offset
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_offset); __pyx_r = __pyx_v_offset; goto __pyx_L0;
3343: else:
+3344: return None
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; }
3345:
3346:
+3347: cdef object Memory_RevObjFind(const Memory_* that, object item, object start, object endex):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_RevObjFind(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_v_offset = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_RevObjFind", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory_RevObjFind", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_offset); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3348: offset = Memory_RevFind(that, item, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_RevFind(__pyx_v_that, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3348, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_offset = __pyx_t_1; __pyx_t_1 = 0;
+3349: if offset >= 0:
__pyx_t_1 = PyObject_RichCompare(__pyx_v_offset, __pyx_int_0, Py_GE); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3349, __pyx_L1_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3349, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_2) { /* … */ }
+3350: return offset
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_offset); __pyx_r = __pyx_v_offset; goto __pyx_L0;
3351: else:
+3352: return None
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; }
3353:
3354:
+3355: cdef addr_t Memory_FindUnbounded_(const Memory_* that, size_t size, const byte_t* buffer) except? -1:
static addr_t __pyx_f_11cbytesparse_1c_Memory_FindUnbounded_(Memory_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; Py_ssize_t __pyx_v_offset; addr_t __pyx_v_start_; addr_t __pyx_v_offset_; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_FindUnbounded_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_FindUnbounded_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1LL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3356: cdef:
+3357: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3358: size_t block_index
3359: const Block_* block
3360: ssize_t offset
3361: addr_t start_
3362: addr_t offset_
3363:
+3364: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+3365: for block_index in range(Rack_Length(blocks)):
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_block_index = __pyx_t_5;
+3366: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+3367: offset = Block_Find_(block, 0, SIZE_MAX, size, buffer)
__pyx_v_offset = __pyx_f_11cbytesparse_1c_Block_Find_(__pyx_v_block, 0, SIZE_MAX, __pyx_v_size, __pyx_v_buffer);
+3368: if offset >= 0:
__pyx_t_2 = ((__pyx_v_offset >= 0) != 0); if (__pyx_t_2) { /* … */ } }
+3369: start_ = Block_Start(block)
__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+3370: offset_ = <addr_t><size_t>offset
__pyx_v_offset_ = ((addr_t)((size_t)__pyx_v_offset));
+3371: CheckAddAddrU(start_, offset_)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start_, __pyx_v_offset_); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3371, __pyx_L1_error)
+3372: return start_ + offset_
__pyx_r = (__pyx_v_start_ + __pyx_v_offset_); goto __pyx_L0;
+3373: return ADDR_MAX
__pyx_r = ADDR_MAX; goto __pyx_L0;
3374:
3375:
+3376: cdef addr_t Memory_FindBounded_(const Memory_* that, size_t size, const byte_t* buffer,
static addr_t __pyx_f_11cbytesparse_1c_Memory_FindBounded_(Memory_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer, addr_t __pyx_v_start, addr_t __pyx_v_endex) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; Py_ssize_t __pyx_v_offset; size_t __pyx_v_block_index_start; size_t __pyx_v_block_index_endex; size_t __pyx_v_slice_start; size_t __pyx_v_slice_endex; addr_t __pyx_v_start_; addr_t __pyx_v_offset_; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_FindBounded_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_FindBounded_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1LL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3377: addr_t start, addr_t endex) except? -1:
3378: cdef:
+3379: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3380: size_t block_index
3381: const Block_* block
3382: ssize_t offset
3383: size_t block_index_start
3384: size_t block_index_endex
3385: size_t slice_start
3386: size_t slice_endex
3387: addr_t start_
3388: addr_t offset_
3389:
+3390: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+3391: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+3392: endex = start
__pyx_v_endex = __pyx_v_start;
+3393: block_index_start = Rack_IndexStart(blocks, start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_start); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3393, __pyx_L1_error)
__pyx_v_block_index_start = __pyx_t_3;
+3394: block_index_endex = Rack_IndexEndex(blocks, endex)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_blocks, __pyx_v_endex); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3394, __pyx_L1_error)
__pyx_v_block_index_endex = __pyx_t_3;
3395:
+3396: for block_index in range(block_index_start, block_index_endex):
__pyx_t_4 = __pyx_v_block_index_endex; __pyx_t_5 = __pyx_t_4; for (__pyx_t_6 = __pyx_v_block_index_start; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { __pyx_v_block_index = __pyx_t_6;
+3397: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+3398: slice_start, slice_endex = Block_BoundAddressSliceToOffset(block, start, endex)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_BoundAddressSliceToOffset(__pyx_v_block, __pyx_v_start, __pyx_v_endex); __pyx_t_8 = __pyx_t_7.f0; __pyx_t_9 = __pyx_t_7.f1; __pyx_v_slice_start = __pyx_t_8; __pyx_v_slice_endex = __pyx_t_9;
+3399: offset = Block_Find_(block, slice_start, slice_endex, size, buffer)
__pyx_v_offset = __pyx_f_11cbytesparse_1c_Block_Find_(__pyx_v_block, __pyx_v_slice_start, __pyx_v_slice_endex, __pyx_v_size, __pyx_v_buffer);
+3400: if offset >= 0:
__pyx_t_2 = ((__pyx_v_offset >= 0) != 0); if (__pyx_t_2) { /* … */ } }
+3401: start_ = Block_Start(block)
__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+3402: offset_ = <addr_t><size_t>offset
__pyx_v_offset_ = ((addr_t)((size_t)__pyx_v_offset));
+3403: CheckAddAddrU(start_, offset_)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start_, __pyx_v_offset_); if (unlikely(__pyx_t_10 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3403, __pyx_L1_error)
+3404: return start_ + offset_
__pyx_r = (__pyx_v_start_ + __pyx_v_offset_); goto __pyx_L0;
+3405: return ADDR_MAX
__pyx_r = ADDR_MAX; goto __pyx_L0;
3406:
3407:
+3408: cdef object Memory_Find(const Memory_* that, object item, object start, object endex):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Find(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; byte_t __pyx_v_item_value; __Pyx_memviewslice __pyx_v_item_view = { 0, 0, { 0 }, { 0 }, { 0 } }; size_t __pyx_v_item_size; byte_t const *__pyx_v_item_ptr; addr_t __pyx_v_address; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Find", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_9); __Pyx_AddTraceback("cbytesparse.c.Memory_Find", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_item_view, 1); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3409: cdef:
3410: addr_t start_
3411: addr_t endex_
3412: byte_t item_value
3413: const byte_t[:] item_view
3414: size_t item_size
3415: const byte_t* item_ptr
3416: addr_t address
3417:
+3418: if isinstance(item, int):
__pyx_t_1 = PyInt_Check(__pyx_v_item);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+3419: item_value = <byte_t>item
__pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3419, __pyx_L1_error) __pyx_v_item_value = ((byte_t)__pyx_t_3);
+3420: item_size = 1
__pyx_v_item_size = 1;
+3421: item_ptr = &item_value
__pyx_v_item_ptr = (&__pyx_v_item_value);
3422: else:
+3423: item_view = item
/*else*/ { __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_item, 0); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(0, 3423, __pyx_L1_error) __pyx_v_item_view = __pyx_t_4; __pyx_t_4.memview = NULL; __pyx_t_4.data = NULL;
+3424: item_size = 1
__pyx_v_item_size = 1;
3425: with cython.boundscheck(False):
+3426: item_ptr = &item_view[0]
__pyx_t_5 = 0; if (__pyx_t_5 < 0) __pyx_t_5 += __pyx_v_item_view.shape[0]; __pyx_v_item_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_item_view.data + __pyx_t_5 * __pyx_v_item_view.strides[0]) )))); } __pyx_L3:;
3427:
3428: # Faster code for unbounded slice
+3429: if start is None and endex is None:
__pyx_t_1 = (__pyx_v_start == Py_None); __pyx_t_6 = (__pyx_t_1 != 0); if (__pyx_t_6) { } else { __pyx_t_2 = __pyx_t_6; goto __pyx_L5_bool_binop_done; } __pyx_t_6 = (__pyx_v_endex == Py_None); __pyx_t_1 = (__pyx_t_6 != 0); __pyx_t_2 = __pyx_t_1; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+3430: address = Memory_FindUnbounded_(that, item_size, item_ptr)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_FindUnbounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr); if (unlikely(__pyx_t_7 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3430, __pyx_L1_error) __pyx_v_address = __pyx_t_7;
+3431: return -1 if address == ADDR_MAX else <object>address
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_address == ADDR_MAX) != 0)) { __Pyx_INCREF(__pyx_int_neg_1); __pyx_t_8 = __pyx_int_neg_1; } else { __pyx_t_9 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 3431, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_INCREF(((PyObject *)__pyx_t_9)); __pyx_t_8 = __pyx_t_9; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } __pyx_r = __pyx_t_8; __pyx_t_8 = 0; goto __pyx_L0;
3432:
3433: # Bounded slice
+3434: start_, endex_ = Memory_Bound(that, start, endex)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 3434, __pyx_L1_error)
__pyx_t_7 = __pyx_t_10.f0;
__pyx_t_11 = __pyx_t_10.f1;
__pyx_v_start_ = __pyx_t_7;
__pyx_v_endex_ = __pyx_t_11;
+3435: address = Memory_FindBounded_(that, item_size, item_ptr, start_, endex_)
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Memory_FindBounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_11 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3435, __pyx_L1_error) __pyx_v_address = __pyx_t_11;
+3436: return -1 if address == ADDR_MAX else <object>address
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_address == ADDR_MAX) != 0)) { __Pyx_INCREF(__pyx_int_neg_1); __pyx_t_8 = __pyx_int_neg_1; } else { __pyx_t_9 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 3436, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_INCREF(((PyObject *)__pyx_t_9)); __pyx_t_8 = __pyx_t_9; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } __pyx_r = __pyx_t_8; __pyx_t_8 = 0; goto __pyx_L0;
3437:
3438:
+3439: cdef addr_t Memory_RevFindUnbounded_(const Memory_* that, size_t size, const byte_t* buffer) except? -1:
static addr_t __pyx_f_11cbytesparse_1c_Memory_RevFindUnbounded_(Memory_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; Py_ssize_t __pyx_v_offset; addr_t __pyx_v_start_; addr_t __pyx_v_offset_; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_RevFindUnbounded_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_RevFindUnbounded_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1LL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3440: cdef:
+3441: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3442: size_t block_index
3443: const Block_* block
3444: ssize_t offset
3445: addr_t start_
3446: addr_t offset_
3447:
+3448: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+3449: for block_index in range(Rack_Length(blocks), 0, -1):
for (__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) + 1; __pyx_t_3 > 0 + 1; ) { __pyx_t_3-=1; __pyx_v_block_index = __pyx_t_3;
+3450: block = Rack_Get__(blocks, block_index - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_block_index - 1));
+3451: offset = Block_ReverseFind_(block, 0, SIZE_MAX, size, buffer)
__pyx_v_offset = __pyx_f_11cbytesparse_1c_Block_ReverseFind_(__pyx_v_block, 0, SIZE_MAX, __pyx_v_size, __pyx_v_buffer);
+3452: if offset >= 0:
__pyx_t_2 = ((__pyx_v_offset >= 0) != 0); if (__pyx_t_2) { /* … */ } }
+3453: start_ = Block_Start(block)
__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+3454: offset_ = <addr_t><size_t>offset
__pyx_v_offset_ = ((addr_t)((size_t)__pyx_v_offset));
+3455: CheckAddAddrU(start_, offset_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start_, __pyx_v_offset_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3455, __pyx_L1_error)
+3456: return start_ + offset_
__pyx_r = (__pyx_v_start_ + __pyx_v_offset_); goto __pyx_L0;
+3457: return ADDR_MAX
__pyx_r = ADDR_MAX; goto __pyx_L0;
3458:
3459:
+3460: cdef addr_t Memory_RevFindBounded_(const Memory_* that, size_t size, const byte_t* buffer,
static addr_t __pyx_f_11cbytesparse_1c_Memory_RevFindBounded_(Memory_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer, addr_t __pyx_v_start, addr_t __pyx_v_endex) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; Py_ssize_t __pyx_v_offset; size_t __pyx_v_block_index_start; size_t __pyx_v_block_index_endex; size_t __pyx_v_slice_start; size_t __pyx_v_slice_endex; addr_t __pyx_v_start_; addr_t __pyx_v_offset_; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_RevFindBounded_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_RevFindBounded_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1LL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3461: addr_t start, addr_t endex) except? -1:
3462: cdef:
+3463: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3464: size_t block_index
3465: const Block_* block
3466: ssize_t offset
3467: size_t block_index_start
3468: size_t block_index_endex
3469: size_t slice_start
3470: size_t slice_endex
3471: addr_t start_
3472: addr_t offset_
3473:
+3474: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+3475: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+3476: endex = start
__pyx_v_endex = __pyx_v_start;
+3477: block_index_start = Rack_IndexStart(blocks, start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_start); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3477, __pyx_L1_error)
__pyx_v_block_index_start = __pyx_t_3;
+3478: block_index_endex = Rack_IndexEndex(blocks, endex)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_blocks, __pyx_v_endex); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3478, __pyx_L1_error)
__pyx_v_block_index_endex = __pyx_t_3;
3479:
+3480: for block_index in range(block_index_endex, block_index_start, -1):
__pyx_t_4 = __pyx_v_block_index_start; __pyx_t_5 = __pyx_t_4; for (__pyx_t_6 = __pyx_v_block_index_endex + 1; __pyx_t_6 > __pyx_t_5 + 1; ) { __pyx_t_6-=1; __pyx_v_block_index = __pyx_t_6;
+3481: block = Rack_Get__(blocks, block_index - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_block_index - 1));
+3482: slice_start, slice_endex = Block_BoundAddressSliceToOffset(block, start, endex)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_BoundAddressSliceToOffset(__pyx_v_block, __pyx_v_start, __pyx_v_endex); __pyx_t_8 = __pyx_t_7.f0; __pyx_t_9 = __pyx_t_7.f1; __pyx_v_slice_start = __pyx_t_8; __pyx_v_slice_endex = __pyx_t_9;
+3483: offset = Block_ReverseFind_(block, slice_start, slice_endex, size, buffer)
__pyx_v_offset = __pyx_f_11cbytesparse_1c_Block_ReverseFind_(__pyx_v_block, __pyx_v_slice_start, __pyx_v_slice_endex, __pyx_v_size, __pyx_v_buffer);
+3484: if offset >= 0:
__pyx_t_2 = ((__pyx_v_offset >= 0) != 0); if (__pyx_t_2) { /* … */ } }
+3485: start_ = Block_Start(block)
__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+3486: offset_ = <addr_t><size_t>offset
__pyx_v_offset_ = ((addr_t)((size_t)__pyx_v_offset));
+3487: CheckAddAddrU(start_, offset_)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start_, __pyx_v_offset_); if (unlikely(__pyx_t_10 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3487, __pyx_L1_error)
+3488: return start_ + offset_
__pyx_r = (__pyx_v_start_ + __pyx_v_offset_); goto __pyx_L0;
+3489: return ADDR_MAX
__pyx_r = ADDR_MAX; goto __pyx_L0;
3490:
3491:
+3492: cdef object Memory_RevFind(const Memory_* that, object item, object start, object endex):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_RevFind(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; byte_t __pyx_v_item_value; __Pyx_memviewslice __pyx_v_item_view = { 0, 0, { 0 }, { 0 }, { 0 } }; size_t __pyx_v_item_size; byte_t const *__pyx_v_item_ptr; addr_t __pyx_v_address; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_RevFind", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_9); __Pyx_AddTraceback("cbytesparse.c.Memory_RevFind", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_item_view, 1); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3493: cdef:
3494: addr_t start_
3495: addr_t endex_
3496: byte_t item_value
3497: const byte_t[:] item_view
3498: size_t item_size
3499: const byte_t* item_ptr
3500: addr_t address
3501:
+3502: if isinstance(item, int):
__pyx_t_1 = PyInt_Check(__pyx_v_item);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+3503: item_value = <byte_t>item
__pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3503, __pyx_L1_error) __pyx_v_item_value = ((byte_t)__pyx_t_3);
+3504: item_size = 1
__pyx_v_item_size = 1;
+3505: item_ptr = &item_value
__pyx_v_item_ptr = (&__pyx_v_item_value);
3506: else:
+3507: item_view = item
/*else*/ { __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_item, 0); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(0, 3507, __pyx_L1_error) __pyx_v_item_view = __pyx_t_4; __pyx_t_4.memview = NULL; __pyx_t_4.data = NULL;
+3508: item_size = 1
__pyx_v_item_size = 1;
3509: with cython.boundscheck(False):
+3510: item_ptr = &item_view[0]
__pyx_t_5 = 0; if (__pyx_t_5 < 0) __pyx_t_5 += __pyx_v_item_view.shape[0]; __pyx_v_item_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_item_view.data + __pyx_t_5 * __pyx_v_item_view.strides[0]) )))); } __pyx_L3:;
3511:
3512: # Faster code for unbounded slice
+3513: if start is None and endex is None:
__pyx_t_1 = (__pyx_v_start == Py_None); __pyx_t_6 = (__pyx_t_1 != 0); if (__pyx_t_6) { } else { __pyx_t_2 = __pyx_t_6; goto __pyx_L5_bool_binop_done; } __pyx_t_6 = (__pyx_v_endex == Py_None); __pyx_t_1 = (__pyx_t_6 != 0); __pyx_t_2 = __pyx_t_1; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+3514: address = Memory_RevFindUnbounded_(that, item_size, item_ptr)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_RevFindUnbounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr); if (unlikely(__pyx_t_7 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3514, __pyx_L1_error) __pyx_v_address = __pyx_t_7;
+3515: return -1 if address == ADDR_MAX else <object>address
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_address == ADDR_MAX) != 0)) { __Pyx_INCREF(__pyx_int_neg_1); __pyx_t_8 = __pyx_int_neg_1; } else { __pyx_t_9 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 3515, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_INCREF(((PyObject *)__pyx_t_9)); __pyx_t_8 = __pyx_t_9; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } __pyx_r = __pyx_t_8; __pyx_t_8 = 0; goto __pyx_L0;
3516:
3517: # Bounded slice
+3518: start_, endex_ = Memory_Bound(that, start, endex)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 3518, __pyx_L1_error)
__pyx_t_7 = __pyx_t_10.f0;
__pyx_t_11 = __pyx_t_10.f1;
__pyx_v_start_ = __pyx_t_7;
__pyx_v_endex_ = __pyx_t_11;
+3519: address = Memory_RevFindBounded_(that, item_size, item_ptr, start_, endex_)
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Memory_RevFindBounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_11 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3519, __pyx_L1_error) __pyx_v_address = __pyx_t_11;
+3520: return -1 if address == ADDR_MAX else <object>address
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_address == ADDR_MAX) != 0)) { __Pyx_INCREF(__pyx_int_neg_1); __pyx_t_8 = __pyx_int_neg_1; } else { __pyx_t_9 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 3520, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_INCREF(((PyObject *)__pyx_t_9)); __pyx_t_8 = __pyx_t_9; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } __pyx_r = __pyx_t_8; __pyx_t_8 = 0; goto __pyx_L0;
3521:
3522:
+3523: cdef object Memory_Index(const Memory_* that, object item, object start, object endex):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Index(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_v_offset = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Index", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory_Index", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_offset); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3524: offset = Memory_Find(that, item, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Find(__pyx_v_that, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3524, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_offset = __pyx_t_1; __pyx_t_1 = 0;
+3525: if offset is not -1:
__pyx_t_2 = (__pyx_v_offset != __pyx_int_neg_1); __pyx_t_3 = (__pyx_t_2 != 0); if (likely(__pyx_t_3)) { /* … */ }
+3526: return offset
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_offset); __pyx_r = __pyx_v_offset; goto __pyx_L0;
3527: else:
+3528: raise ValueError('subsection not found')
/*else*/ { __pyx_t_1 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__17, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3528, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 3528, __pyx_L1_error) } /* … */ __pyx_tuple__17 = PyTuple_Pack(1, __pyx_kp_u_subsection_not_found); if (unlikely(!__pyx_tuple__17)) __PYX_ERR(0, 3528, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__17); __Pyx_GIVEREF(__pyx_tuple__17);
3529:
3530:
+3531: cdef object Memory_RevIndex(const Memory_* that, object item, object start, object endex):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_RevIndex(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_v_offset = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_RevIndex", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory_RevIndex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_offset); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3532: offset = Memory_RevFind(that, item, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_RevFind(__pyx_v_that, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3532, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_offset = __pyx_t_1; __pyx_t_1 = 0;
+3533: if offset is not -1:
__pyx_t_2 = (__pyx_v_offset != __pyx_int_neg_1); __pyx_t_3 = (__pyx_t_2 != 0); if (likely(__pyx_t_3)) { /* … */ }
+3534: return offset
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_offset); __pyx_r = __pyx_v_offset; goto __pyx_L0;
3535: else:
+3536: raise ValueError('subsection not found')
/*else*/ { __pyx_t_1 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__17, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3536, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 3536, __pyx_L1_error) }
3537:
3538:
+3539: cdef bint Memory_Contains(const Memory_* that, object item) except -1:
static int __pyx_f_11cbytesparse_1c_Memory_Contains(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item) { byte_t __pyx_v_item_value; __Pyx_memviewslice __pyx_v_item_view = { 0, 0, { 0 }, { 0 }, { 0 } }; size_t __pyx_v_item_size; byte_t const *__pyx_v_item_ptr; addr_t __pyx_v_address; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Contains", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1); __Pyx_AddTraceback("cbytesparse.c.Memory_Contains", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_item_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3540: cdef:
3541: byte_t item_value
3542: const byte_t[:] item_view
3543: size_t item_size
3544: const byte_t* item_ptr
3545: addr_t address
3546:
+3547: if isinstance(item, int):
__pyx_t_1 = PyInt_Check(__pyx_v_item);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+3548: item_value = <byte_t>item
__pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3548, __pyx_L1_error) __pyx_v_item_value = ((byte_t)__pyx_t_3);
+3549: item_size = 1
__pyx_v_item_size = 1;
+3550: item_ptr = &item_value
__pyx_v_item_ptr = (&__pyx_v_item_value);
3551: else:
+3552: item_view = item
/*else*/ { __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_item, 0); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(0, 3552, __pyx_L1_error) __pyx_v_item_view = __pyx_t_4; __pyx_t_4.memview = NULL; __pyx_t_4.data = NULL;
+3553: item_size = 1
__pyx_v_item_size = 1;
3554: with cython.boundscheck(False):
+3555: item_ptr = &item_view[0]
__pyx_t_5 = 0; if (__pyx_t_5 < 0) __pyx_t_5 += __pyx_v_item_view.shape[0]; __pyx_v_item_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_item_view.data + __pyx_t_5 * __pyx_v_item_view.strides[0]) )))); } __pyx_L3:;
3556:
+3557: address = Memory_FindUnbounded_(that, item_size, item_ptr)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_FindUnbounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr); if (unlikely(__pyx_t_6 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3557, __pyx_L1_error) __pyx_v_address = __pyx_t_6;
+3558: return address != ADDR_MAX
__pyx_r = (__pyx_v_address != ADDR_MAX); goto __pyx_L0;
3559:
3560:
+3561: cdef addr_t Memory_CountUnbounded_(const Memory_* that, size_t size, const byte_t* buffer) except? -1:
static addr_t __pyx_f_11cbytesparse_1c_Memory_CountUnbounded_(Memory_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_count; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_CountUnbounded_", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3562: cdef:
+3563: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3564: size_t block_index
3565: const Block_* block
+3566: addr_t count = 0
__pyx_v_count = 0;
3567:
+3568: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+3569: for block_index in range(Rack_Length(blocks)):
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_block_index = __pyx_t_5;
+3570: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+3571: count += Block_Count_(block, 0, SIZE_MAX, size, buffer)
__pyx_v_count = (__pyx_v_count + __pyx_f_11cbytesparse_1c_Block_Count_(__pyx_v_block, 0, SIZE_MAX, __pyx_v_size, __pyx_v_buffer)); }
+3572: return count
__pyx_r = __pyx_v_count; goto __pyx_L0;
3573:
3574:
+3575: cdef addr_t Memory_CountBounded_(const Memory_* that, size_t size, const byte_t* buffer,
static addr_t __pyx_f_11cbytesparse_1c_Memory_CountBounded_(Memory_ const *__pyx_v_that, size_t __pyx_v_size, byte_t const *__pyx_v_buffer, addr_t __pyx_v_start, addr_t __pyx_v_endex) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_count; size_t __pyx_v_block_index_start; size_t __pyx_v_block_index_endex; size_t __pyx_v_slice_start; size_t __pyx_v_slice_endex; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_CountBounded_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_CountBounded_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1LL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3576: addr_t start, addr_t endex) except? -1:
3577: cdef:
+3578: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3579: size_t block_index
3580: const Block_* block
+3581: addr_t count = 0
__pyx_v_count = 0;
3582: size_t block_index_start
3583: size_t block_index_endex
3584: addr_t block_start
3585: addr_t block_endex
3586: size_t slice_start
3587: size_t slice_endex
3588:
+3589: if size:
__pyx_t_2 = (__pyx_v_size != 0); if (__pyx_t_2) { /* … */ }
+3590: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+3591: endex = start
__pyx_v_endex = __pyx_v_start;
+3592: block_index_start = Rack_IndexStart(blocks, start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_start); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3592, __pyx_L1_error)
__pyx_v_block_index_start = __pyx_t_3;
+3593: block_index_endex = Rack_IndexEndex(blocks, endex)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_blocks, __pyx_v_endex); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3593, __pyx_L1_error)
__pyx_v_block_index_endex = __pyx_t_3;
3594:
+3595: for block_index in range(block_index_start, block_index_endex):
__pyx_t_4 = __pyx_v_block_index_endex; __pyx_t_5 = __pyx_t_4; for (__pyx_t_6 = __pyx_v_block_index_start; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { __pyx_v_block_index = __pyx_t_6;
+3596: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+3597: slice_start, slice_endex = Block_BoundAddressSliceToOffset(block, start, endex)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_BoundAddressSliceToOffset(__pyx_v_block, __pyx_v_start, __pyx_v_endex); __pyx_t_8 = __pyx_t_7.f0; __pyx_t_9 = __pyx_t_7.f1; __pyx_v_slice_start = __pyx_t_8; __pyx_v_slice_endex = __pyx_t_9;
+3598: count += Block_Count_(block, slice_start, slice_endex, size, buffer)
__pyx_v_count = (__pyx_v_count + __pyx_f_11cbytesparse_1c_Block_Count_(__pyx_v_block, __pyx_v_slice_start, __pyx_v_slice_endex, __pyx_v_size, __pyx_v_buffer)); }
+3599: return count
__pyx_r = __pyx_v_count; goto __pyx_L0;
3600:
3601:
+3602: cdef addr_t Memory_Count(const Memory_* that, object item, object start, object endex) except? -1:
static addr_t __pyx_f_11cbytesparse_1c_Memory_Count(Memory_ const *__pyx_v_that, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; byte_t __pyx_v_item_value; __Pyx_memviewslice __pyx_v_item_view = { 0, 0, { 0 }, { 0 }, { 0 } }; size_t __pyx_v_item_size; byte_t const *__pyx_v_item_ptr; addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Count", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1); __Pyx_AddTraceback("cbytesparse.c.Memory_Count", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1LL; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_item_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3603: cdef:
3604: addr_t start_
3605: addr_t endex_
3606: byte_t item_value
3607: const byte_t[:] item_view
3608: size_t item_size
3609: const byte_t* item_ptr
3610:
+3611: if isinstance(item, int):
__pyx_t_1 = PyInt_Check(__pyx_v_item);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+3612: item_value = <byte_t>item
__pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3612, __pyx_L1_error) __pyx_v_item_value = ((byte_t)__pyx_t_3);
+3613: item_size = 1
__pyx_v_item_size = 1;
+3614: item_ptr = &item_value
__pyx_v_item_ptr = (&__pyx_v_item_value);
3615: else:
+3616: item_view = item
/*else*/ { __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_item, 0); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(0, 3616, __pyx_L1_error) __pyx_v_item_view = __pyx_t_4; __pyx_t_4.memview = NULL; __pyx_t_4.data = NULL;
+3617: item_size = 1
__pyx_v_item_size = 1;
3618: with cython.boundscheck(False):
+3619: item_ptr = &item_view[0]
__pyx_t_5 = 0; if (__pyx_t_5 < 0) __pyx_t_5 += __pyx_v_item_view.shape[0]; __pyx_v_item_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_item_view.data + __pyx_t_5 * __pyx_v_item_view.strides[0]) )))); } __pyx_L3:;
3620:
3621: # Faster code for unbounded slice
+3622: if start is None and endex is None:
__pyx_t_1 = (__pyx_v_start == Py_None); __pyx_t_6 = (__pyx_t_1 != 0); if (__pyx_t_6) { } else { __pyx_t_2 = __pyx_t_6; goto __pyx_L5_bool_binop_done; } __pyx_t_6 = (__pyx_v_endex == Py_None); __pyx_t_1 = (__pyx_t_6 != 0); __pyx_t_2 = __pyx_t_1; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+3623: return Memory_CountUnbounded_(that, item_size, item_ptr)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_CountUnbounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr); if (unlikely(__pyx_t_7 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3623, __pyx_L1_error) __pyx_r = __pyx_t_7; goto __pyx_L0;
3624:
3625: # Bounded slice
+3626: start_, endex_ = Memory_Bound(that, start, endex)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 3626, __pyx_L1_error)
__pyx_t_7 = __pyx_t_8.f0;
__pyx_t_9 = __pyx_t_8.f1;
__pyx_v_start_ = __pyx_t_7;
__pyx_v_endex_ = __pyx_t_9;
+3627: return Memory_CountBounded_(that, item_size, item_ptr, start_, endex_)
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Memory_CountBounded_(__pyx_v_that, __pyx_v_item_size, __pyx_v_item_ptr, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_9 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 3627, __pyx_L1_error) __pyx_r = __pyx_t_9; goto __pyx_L0;
3628:
3629:
+3630: cdef object Memory_GetItem(const Memory_* that, object key):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_GetItem(Memory_ const *__pyx_v_that, PyObject *__pyx_v_key) { PyObject *__pyx_v_key_ = 0; addr_t __pyx_v_start; addr_t __pyx_v_endex; Block_ *__pyx_v_pattern; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; int __pyx_v_value; PyObject *__pyx_v_key_start = NULL; PyObject *__pyx_v_key_endex = NULL; PyObject *__pyx_v_key_step = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_GetItem", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_18); __Pyx_AddTraceback("cbytesparse.c.Memory_GetItem", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_key_); __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XDECREF(__pyx_v_key_start); __Pyx_XDECREF(__pyx_v_key_endex); __Pyx_XDECREF(__pyx_v_key_step); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3631: cdef:
3632: slice key_
3633: addr_t start
3634: addr_t endex
+3635: Block_* pattern = NULL
__pyx_v_pattern = NULL;
3636: Memory memory
3637: int value
3638:
+3639: if isinstance(key, slice):
__pyx_t_1 = PySlice_Check(__pyx_v_key);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
}
+3640: key_ = <slice>key
__pyx_t_3 = __pyx_v_key;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_ = ((PyObject*)__pyx_t_3);
__pyx_t_3 = 0;
+3641: key_start = key_.start
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->start;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_start = __pyx_t_3;
__pyx_t_3 = 0;
+3642: key_endex = key_.stop
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->stop;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_endex = __pyx_t_3;
__pyx_t_3 = 0;
+3643: start = Memory_Start(that) if key_start is None else <addr_t>key_start
__pyx_t_2 = (__pyx_v_key_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_start); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3643, __pyx_L1_error) __pyx_t_4 = ((addr_t)__pyx_t_5); } __pyx_v_start = __pyx_t_4;
+3644: endex = Memory_Endex(that) if key_endex is None else <addr_t>key_endex
__pyx_t_2 = (__pyx_v_key_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); } else { __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_endex); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3644, __pyx_L1_error) __pyx_t_4 = ((addr_t)__pyx_t_5); } __pyx_v_endex = __pyx_t_4;
+3645: key_step = key_.step
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->step;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_step = __pyx_t_3;
__pyx_t_3 = 0;
3646:
+3647: if key_step is None or key_step is 1 or key_step == 1:
__pyx_t_1 = (__pyx_v_key_step == Py_None); __pyx_t_6 = (__pyx_t_1 != 0); if (!__pyx_t_6) { } else { __pyx_t_2 = __pyx_t_6; goto __pyx_L5_bool_binop_done; } __pyx_t_6 = (__pyx_v_key_step == __pyx_int_1); __pyx_t_1 = (__pyx_t_6 != 0); if (!__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L5_bool_binop_done; } __pyx_t_3 = __Pyx_PyInt_EqObjC(__pyx_v_key_step, __pyx_int_1, 1, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3647, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_1 < 0)) __PYX_ERR(0, 3647, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_2 = __pyx_t_1; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+3648: return Memory_Extract_(that, start, endex, 0, NULL, 1, True)
__Pyx_XDECREF(__pyx_r); __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0, NULL, 1, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3648, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
3649:
+3650: elif isinstance(key_step, int):
__pyx_t_2 = PyInt_Check(__pyx_v_key_step);
__pyx_t_1 = (__pyx_t_2 != 0);
if (__pyx_t_1) {
/* … */
}
+3651: if key_step > 1:
__pyx_t_3 = PyObject_RichCompare(__pyx_v_key_step, __pyx_int_1, Py_GT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3651, __pyx_L1_error) __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_1 < 0)) __PYX_ERR(0, 3651, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_1) { /* … */ }
+3652: return Memory_Extract_(that, start, endex, 0, NULL, <saddr_t>key_step, True)
__Pyx_XDECREF(__pyx_r); __pyx_t_7 = __Pyx_PyInt_As_int_fast64_t(__pyx_v_key_step); if (unlikely((__pyx_t_7 == ((saddr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3652, __pyx_L1_error) __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0, NULL, ((saddr_t)__pyx_t_7), 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3652, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
3653: else:
+3654: return Memory() # empty
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3654, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; }
3655:
3656: else:
+3657: pattern = Block_FromObject(0, key_step, True)
/*else*/ {
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Block_FromObject(0, __pyx_v_key_step, 1); if (unlikely(__pyx_t_8 == ((Block_ *)NULL))) __PYX_ERR(0, 3657, __pyx_L1_error)
__pyx_v_pattern = __pyx_t_8;
+3658: try:
/*try:*/ {
+3659: memory = Memory_Extract_(that, start, endex, Block_Length(pattern), Block_At__(pattern, 0), 1, True)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_that, __pyx_v_start, __pyx_v_endex, __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_pattern), __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_pattern, 0), 1, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3659, __pyx_L10_error) __Pyx_GOTREF(__pyx_t_3); if (!(likely(((__pyx_t_3) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_3, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 3659, __pyx_L10_error) __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_3); __pyx_t_3 = 0; }
3660: finally:
+3661: Block_Free(pattern) # orphan
/*finally:*/ { /*normal exit:*/{ (void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_pattern)); goto __pyx_L11; } __pyx_L10_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_15, &__pyx_t_16, &__pyx_t_17); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_12, &__pyx_t_13, &__pyx_t_14) < 0)) __Pyx_ErrFetch(&__pyx_t_12, &__pyx_t_13, &__pyx_t_14); __Pyx_XGOTREF(__pyx_t_12); __Pyx_XGOTREF(__pyx_t_13); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_15); __Pyx_XGOTREF(__pyx_t_16); __Pyx_XGOTREF(__pyx_t_17); __pyx_t_9 = __pyx_lineno; __pyx_t_10 = __pyx_clineno; __pyx_t_11 = __pyx_filename; { (void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_pattern)); } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_XGIVEREF(__pyx_t_17); __Pyx_ExceptionReset(__pyx_t_15, __pyx_t_16, __pyx_t_17); } __Pyx_XGIVEREF(__pyx_t_12); __Pyx_XGIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_14); __Pyx_ErrRestore(__pyx_t_12, __pyx_t_13, __pyx_t_14); __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_lineno = __pyx_t_9; __pyx_clineno = __pyx_t_10; __pyx_filename = __pyx_t_11; goto __pyx_L1_error; } __pyx_L11:; }
+3662: return memory
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = ((PyObject *)__pyx_v_memory); goto __pyx_L0; }
3663: else:
+3664: value = Memory_Peek_(that, <addr_t>key)
/*else*/ { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3664, __pyx_L1_error) __pyx_t_10 = __pyx_f_11cbytesparse_1c_Memory_Peek_(__pyx_v_that, ((addr_t)__pyx_t_4)); if (unlikely(__pyx_t_10 == ((int)-2))) __PYX_ERR(0, 3664, __pyx_L1_error) __pyx_v_value = __pyx_t_10;
+3665: return None if value < 0 else value
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_value < 0) != 0)) { __Pyx_INCREF(Py_None); __pyx_t_3 = Py_None; } else { __pyx_t_18 = __Pyx_PyInt_From_int(__pyx_v_value); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 3665, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_18); __pyx_t_3 = __pyx_t_18; __pyx_t_18 = 0; } __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; }
3666:
3667:
+3668: cdef object Memory_SetItem(Memory_* that, object key, object value):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_SetItem(Memory_ *__pyx_v_that, PyObject *__pyx_v_key, PyObject *__pyx_v_value) { PyObject *__pyx_v_key_ = 0; addr_t __pyx_v_start; addr_t __pyx_v_endex; addr_t __pyx_v_step; addr_t __pyx_v_address; addr_t __pyx_v_slice_size; Block_ *__pyx_v_value_; size_t __pyx_v_value_size; addr_t __pyx_v_del_start; addr_t __pyx_v_del_endex; size_t __pyx_v_offset; PyObject *__pyx_v_key_start = NULL; PyObject *__pyx_v_key_endex = NULL; PyObject *__pyx_v_key_step = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_SetItem", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("cbytesparse.c.Memory_SetItem", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_key_); __Pyx_XDECREF(__pyx_v_key_start); __Pyx_XDECREF(__pyx_v_key_endex); __Pyx_XDECREF(__pyx_v_key_step); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3669: cdef:
3670: slice key_
3671: addr_t start
3672: addr_t endex
+3673: addr_t step = 0 # indefinite
__pyx_v_step = 0;
3674: addr_t address
3675: addr_t slice_size
+3676: Block_* value_ = NULL
__pyx_v_value_ = NULL;
3677: size_t value_size
3678: addr_t del_start
3679: addr_t del_endex
3680: size_t offset
3681:
+3682: if isinstance(key, slice):
__pyx_t_1 = PySlice_Check(__pyx_v_key);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+3683: key_ = <slice>key
__pyx_t_3 = __pyx_v_key;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_ = ((PyObject*)__pyx_t_3);
__pyx_t_3 = 0;
+3684: key_start = key_.start
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->start;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_start = __pyx_t_3;
__pyx_t_3 = 0;
+3685: key_endex = key_.stop
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->stop;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_endex = __pyx_t_3;
__pyx_t_3 = 0;
+3686: start = Memory_Start(that) if key_start is None else <addr_t>key_start
__pyx_t_2 = (__pyx_v_key_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_start); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3686, __pyx_L1_error) __pyx_t_4 = ((addr_t)__pyx_t_5); } __pyx_v_start = __pyx_t_4;
+3687: endex = Memory_Endex(that) if key_endex is None else <addr_t>key_endex
__pyx_t_2 = (__pyx_v_key_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); } else { __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_endex); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3687, __pyx_L1_error) __pyx_t_4 = ((addr_t)__pyx_t_5); } __pyx_v_endex = __pyx_t_4;
+3688: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+3689: endex = start
__pyx_v_endex = __pyx_v_start;
3690:
+3691: key_step = key_.step
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->step;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_step = __pyx_t_3;
__pyx_t_3 = 0;
+3692: if isinstance(key_step, int):
__pyx_t_2 = PyInt_Check(__pyx_v_key_step);
__pyx_t_1 = (__pyx_t_2 != 0);
if (__pyx_t_1) {
/* … */
}
+3693: if key_step is None or key_step is 1 or key_step == 1:
__pyx_t_2 = (__pyx_v_key_step == Py_None); __pyx_t_6 = (__pyx_t_2 != 0); if (!__pyx_t_6) { } else { __pyx_t_1 = __pyx_t_6; goto __pyx_L7_bool_binop_done; } __pyx_t_6 = (__pyx_v_key_step == __pyx_int_1); __pyx_t_2 = (__pyx_t_6 != 0); if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L7_bool_binop_done; } __pyx_t_3 = __Pyx_PyInt_EqObjC(__pyx_v_key_step, __pyx_int_1, 1, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3693, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3693, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_1 = __pyx_t_2; __pyx_L7_bool_binop_done:; if (__pyx_t_1) { goto __pyx_L6; }
3694: pass
+3695: elif key_step > 1:
__pyx_t_3 = PyObject_RichCompare(__pyx_v_key_step, __pyx_int_1, Py_GT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3695, __pyx_L1_error) __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_1 < 0)) __PYX_ERR(0, 3695, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_1) { /* … */ goto __pyx_L6; }
+3696: step = <addr_t>key_step
__pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_step); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3696, __pyx_L1_error) __pyx_v_step = ((addr_t)__pyx_t_4);
3697: else:
+3698: return # empty range
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; } __pyx_L6:;
3699:
+3700: if value is None:
__pyx_t_1 = (__pyx_v_value == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ }
3701: # Clear range
+3702: if not step:
__pyx_t_2 = ((!(__pyx_v_step != 0)) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L11; }
+3703: Memory_Erase__(that, start, endex, False) # clear
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3703, __pyx_L1_error)
3704: else:
+3705: address = start
/*else*/ { __pyx_v_address = __pyx_v_start;
+3706: while address < endex:
while (1) { __pyx_t_2 = ((__pyx_v_address < __pyx_v_endex) != 0); if (!__pyx_t_2) break;
+3707: Memory_Erase__(that, address, address + 1, False) # clear
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_address, (__pyx_v_address + 1), 0); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3707, __pyx_L1_error)
+3708: if CannotAddAddrU(address, step):
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_CannotAddAddrU(__pyx_v_address, __pyx_v_step) != 0); if (__pyx_t_2) { /* … */ }
+3709: break
goto __pyx_L13_break;
+3710: address += step
__pyx_v_address = (__pyx_v_address + __pyx_v_step); } __pyx_L13_break:; } __pyx_L11:;
+3711: return # nothing to write
__Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0;
3712:
+3713: slice_size = endex - start
__pyx_v_slice_size = (__pyx_v_endex - __pyx_v_start);
+3714: if step:
__pyx_t_2 = (__pyx_v_step != 0); if (__pyx_t_2) { /* … */ }
3715: with cython.cdivision(True):
+3716: slice_size = (slice_size + step - 1) // step
__pyx_v_slice_size = (((__pyx_v_slice_size + __pyx_v_step) - 1) / __pyx_v_step);
+3717: CheckAddrToSizeU(slice_size)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_slice_size); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3717, __pyx_L1_error)
3718:
+3719: value_ = Block_FromObject(0, value, False)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Block_FromObject(0, __pyx_v_value, 0); if (unlikely(__pyx_t_8 == ((Block_ *)NULL))) __PYX_ERR(0, 3719, __pyx_L1_error)
__pyx_v_value_ = __pyx_t_8;
+3720: try:
/*try:*/ {
+3721: if isinstance(value, int):
__pyx_t_2 = PyInt_Check(__pyx_v_value);
__pyx_t_1 = (__pyx_t_2 != 0);
if (__pyx_t_1) {
/* … */
}
+3722: value_ = Block_Repeat(value_, <size_t>slice_size)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Block_Repeat(__pyx_v_value_, ((size_t)__pyx_v_slice_size)); if (unlikely(__pyx_t_8 == ((Block_ *)NULL))) __PYX_ERR(0, 3722, __pyx_L17_error)
__pyx_v_value_ = __pyx_t_8;
+3723: value_size = Block_Length(value_)
__pyx_v_value_size = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_value_);
3724:
+3725: if value_size < slice_size:
__pyx_t_1 = ((__pyx_v_value_size < __pyx_v_slice_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L20; }
3726: # Shrink: remove excess, overwrite existing
+3727: if not step:
__pyx_t_1 = ((!(__pyx_v_step != 0)) != 0); if (likely(__pyx_t_1)) { /* … */ goto __pyx_L21; }
+3728: if CannotAddAddrU(start, value_size):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddAddrU(__pyx_v_start, __pyx_v_value_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L22; }
+3729: del_start = ADDR_MAX
__pyx_v_del_start = ADDR_MAX;
3730: else:
+3731: del_start = start + value_size
/*else*/ { __pyx_v_del_start = (__pyx_v_start + __pyx_v_value_size); } __pyx_L22:;
+3732: if CannotAddAddrU(del_start, (slice_size - value_size)):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddAddrU(__pyx_v_del_start, (__pyx_v_slice_size - __pyx_v_value_size)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L23; }
+3733: del_endex = ADDR_MAX
__pyx_v_del_endex = ADDR_MAX;
3734: else:
+3735: del_endex = del_start + (slice_size - value_size)
/*else*/ { __pyx_v_del_endex = (__pyx_v_del_start + (__pyx_v_slice_size - __pyx_v_value_size)); } __pyx_L23:;
+3736: Memory_Erase__(that, del_start, del_endex, True) # delete
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_del_start, __pyx_v_del_endex, 1); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3736, __pyx_L17_error)
+3737: if value_size:
__pyx_t_1 = (__pyx_v_value_size != 0); if (__pyx_t_1) { /* … */ }
+3738: Memory_WriteRaw_(that, start, value_size, Block_At__(value_, 0))
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(__pyx_v_that, __pyx_v_start, __pyx_v_value_size, __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_value_, 0)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3738, __pyx_L17_error)
3739: else:
+3740: raise ValueError(f'attempt to assign bytes of size {value_size}'
/*else*/ { __pyx_t_3 = PyTuple_New(4); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3740, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_9 = 0; __pyx_t_10 = 127; __Pyx_INCREF(__pyx_kp_u_attempt_to_assign_bytes_of_size); __pyx_t_9 += 32; __Pyx_GIVEREF(__pyx_kp_u_attempt_to_assign_bytes_of_size); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_kp_u_attempt_to_assign_bytes_of_size); __pyx_t_11 = __Pyx_PyUnicode_From_size_t(__pyx_v_value_size, 0, ' ', 'd'); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 3740, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_11); __pyx_t_9 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_11); __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_11); __pyx_t_11 = 0; __Pyx_INCREF(__pyx_kp_u_to_extended_slice_of_size); __pyx_t_9 += 27; __Pyx_GIVEREF(__pyx_kp_u_to_extended_slice_of_size); PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_kp_u_to_extended_slice_of_size); /* … */ __pyx_t_12 = __Pyx_PyUnicode_Join(__pyx_t_3, 4, __pyx_t_9, __pyx_t_10); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 3740, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_PyObject_CallOneArg(__pyx_builtin_ValueError, __pyx_t_12); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3740, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 3740, __pyx_L17_error) } __pyx_L21:;
+3741: f' to extended slice of size {slice_size}')
__pyx_t_11 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_slice_size); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 3741, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_11); __pyx_t_12 = __Pyx_PyObject_FormatSimple(__pyx_t_11, __pyx_empty_unicode); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 3741, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; __pyx_t_10 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_12) > __pyx_t_10) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_12) : __pyx_t_10; __pyx_t_9 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_12); __Pyx_GIVEREF(__pyx_t_12); PyTuple_SET_ITEM(__pyx_t_3, 3, __pyx_t_12); __pyx_t_12 = 0;
+3742: elif slice_size < value_size:
__pyx_t_1 = ((__pyx_v_slice_size < __pyx_v_value_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L20; }
3743: # Enlarge: insert excess, overwrite existing
+3744: if not step:
__pyx_t_1 = ((!(__pyx_v_step != 0)) != 0); if (likely(__pyx_t_1)) { /* … */ goto __pyx_L25; }
+3745: Memory_InsertRaw_(that, endex, value_size - slice_size, Block_At__(value_, slice_size))
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_InsertRaw_(__pyx_v_that, __pyx_v_endex, (__pyx_v_value_size - __pyx_v_slice_size), __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_value_, __pyx_v_slice_size)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3745, __pyx_L17_error)
+3746: Memory_WriteRaw_(that, start, slice_size, Block_At__(value_, 0))
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(__pyx_v_that, __pyx_v_start, __pyx_v_slice_size, __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_value_, 0)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3746, __pyx_L17_error)
3747: else:
+3748: raise ValueError(f'attempt to assign bytes of size {value_size}'
/*else*/ { __pyx_t_3 = PyTuple_New(4); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3748, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_9 = 0; __pyx_t_10 = 127; __Pyx_INCREF(__pyx_kp_u_attempt_to_assign_bytes_of_size); __pyx_t_9 += 32; __Pyx_GIVEREF(__pyx_kp_u_attempt_to_assign_bytes_of_size); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_kp_u_attempt_to_assign_bytes_of_size); __pyx_t_12 = __Pyx_PyUnicode_From_size_t(__pyx_v_value_size, 0, ' ', 'd'); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 3748, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_12); __pyx_t_9 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_12); __Pyx_GIVEREF(__pyx_t_12); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_12); __pyx_t_12 = 0; __Pyx_INCREF(__pyx_kp_u_to_extended_slice_of_size); __pyx_t_9 += 27; __Pyx_GIVEREF(__pyx_kp_u_to_extended_slice_of_size); PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_kp_u_to_extended_slice_of_size); /* … */ __pyx_t_11 = __Pyx_PyUnicode_Join(__pyx_t_3, 4, __pyx_t_9, __pyx_t_10); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 3748, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_11); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_PyObject_CallOneArg(__pyx_builtin_ValueError, __pyx_t_11); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3748, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 3748, __pyx_L17_error) } __pyx_L25:;
+3749: f' to extended slice of size {slice_size}')
__pyx_t_12 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_slice_size); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 3749, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_12); __pyx_t_11 = __Pyx_PyObject_FormatSimple(__pyx_t_12, __pyx_empty_unicode); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 3749, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_11); __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; __pyx_t_10 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_11) > __pyx_t_10) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_11) : __pyx_t_10; __pyx_t_9 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_11); __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_3, 3, __pyx_t_11); __pyx_t_11 = 0;
3750: else:
3751: # Same size: overwrite existing
+3752: if not step:
/*else*/ { __pyx_t_1 = ((!(__pyx_v_step != 0)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L26; }
+3753: Memory_WriteRaw_(that, start, value_size, Block_At__(value_, 0))
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(__pyx_v_that, __pyx_v_start, __pyx_v_value_size, __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_value_, 0)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3753, __pyx_L17_error)
3754: else:
+3755: CheckMulAddrU(step, value_size)
/*else*/ {
__pyx_t_7 = __pyx_f_11cbytesparse_1c_CheckMulAddrU(__pyx_v_step, __pyx_v_value_size); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3755, __pyx_L17_error)
+3756: CheckAddAddrU(start, step * value_size)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start, (__pyx_v_step * __pyx_v_value_size)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3756, __pyx_L17_error)
+3757: for offset in range(value_size):
__pyx_t_13 = __pyx_v_value_size; __pyx_t_14 = __pyx_t_13; for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_14; __pyx_t_15+=1) { __pyx_v_offset = __pyx_t_15;
+3758: Memory_Poke_(that, start + (step * offset), Block_Get__(value_, offset))
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Poke_(__pyx_v_that, (__pyx_v_start + (__pyx_v_step * __pyx_v_offset)), __pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_value_, __pyx_v_offset)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3758, __pyx_L17_error)
}
}
__pyx_L26:;
}
__pyx_L20:;
}
3759: finally:
+3760: Block_Free(value_) # orphan
/*finally:*/ { /*normal exit:*/{ (void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_value_)); goto __pyx_L18; } __pyx_L17_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __pyx_t_22 = 0; __pyx_t_23 = 0; __pyx_t_24 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_22, &__pyx_t_23, &__pyx_t_24); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_19, &__pyx_t_20, &__pyx_t_21) < 0)) __Pyx_ErrFetch(&__pyx_t_19, &__pyx_t_20, &__pyx_t_21); __Pyx_XGOTREF(__pyx_t_19); __Pyx_XGOTREF(__pyx_t_20); __Pyx_XGOTREF(__pyx_t_21); __Pyx_XGOTREF(__pyx_t_22); __Pyx_XGOTREF(__pyx_t_23); __Pyx_XGOTREF(__pyx_t_24); __pyx_t_16 = __pyx_lineno; __pyx_t_17 = __pyx_clineno; __pyx_t_18 = __pyx_filename; { (void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_value_)); } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_22); __Pyx_XGIVEREF(__pyx_t_23); __Pyx_XGIVEREF(__pyx_t_24); __Pyx_ExceptionReset(__pyx_t_22, __pyx_t_23, __pyx_t_24); } __Pyx_XGIVEREF(__pyx_t_19); __Pyx_XGIVEREF(__pyx_t_20); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ErrRestore(__pyx_t_19, __pyx_t_20, __pyx_t_21); __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __pyx_t_22 = 0; __pyx_t_23 = 0; __pyx_t_24 = 0; __pyx_lineno = __pyx_t_16; __pyx_clineno = __pyx_t_17; __pyx_filename = __pyx_t_18; goto __pyx_L1_error; } __pyx_L18:; }
3761: else:
3762: # below: self.poke(key, value)
+3763: address = <addr_t>key
/*else*/ { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3763, __pyx_L1_error) __pyx_v_address = ((addr_t)__pyx_t_4);
+3764: if value is None:
__pyx_t_1 = (__pyx_v_value == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L31; }
+3765: Memory_PokeNone_(that, address)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_PokeNone_(__pyx_v_that, __pyx_v_address); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3765, __pyx_L1_error)
3766: else:
+3767: if isinstance(value, int):
/*else*/ {
__pyx_t_2 = PyInt_Check(__pyx_v_value);
__pyx_t_1 = (__pyx_t_2 != 0);
if (__pyx_t_1) {
/* … */
goto __pyx_L32;
}
+3768: Memory_Poke_(that, address, <byte_t>value)
__pyx_t_25 = __Pyx_PyInt_As_byte_t(__pyx_v_value); if (unlikely((__pyx_t_25 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3768, __pyx_L1_error) __pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Poke_(__pyx_v_that, __pyx_v_address, ((byte_t)__pyx_t_25)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3768, __pyx_L1_error)
3769: else:
+3770: if len(value) != 1:
/*else*/ { __pyx_t_9 = PyObject_Length(__pyx_v_value); if (unlikely(__pyx_t_9 == ((Py_ssize_t)-1))) __PYX_ERR(0, 3770, __pyx_L1_error) __pyx_t_1 = ((__pyx_t_9 != 1) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+3771: raise ValueError('expecting single item')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3771, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 3771, __pyx_L1_error) /* … */ __pyx_tuple__18 = PyTuple_Pack(1, __pyx_kp_u_expecting_single_item); if (unlikely(!__pyx_tuple__18)) __PYX_ERR(0, 3771, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__18); __Pyx_GIVEREF(__pyx_tuple__18);
+3772: Memory_Poke_(that, address, <byte_t>value[0])
__pyx_t_3 = __Pyx_GetItemInt(__pyx_v_value, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3772, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_25 = __Pyx_PyInt_As_byte_t(__pyx_t_3); if (unlikely((__pyx_t_25 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3772, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Poke_(__pyx_v_that, __pyx_v_address, ((byte_t)__pyx_t_25)); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3772, __pyx_L1_error) } __pyx_L32:; } __pyx_L31:; } __pyx_L3:;
3773:
3774:
+3775: cdef vint Memory_DelItem(Memory_* that, object key) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_DelItem(Memory_ *__pyx_v_that, PyObject *__pyx_v_key) { PyObject *__pyx_v_key_ = 0; addr_t __pyx_v_start; addr_t __pyx_v_endex; addr_t __pyx_v_step; addr_t __pyx_v_address; PyObject *__pyx_v_key_start = NULL; PyObject *__pyx_v_key_endex = NULL; PyObject *__pyx_v_key_step = NULL; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_DelItem", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory_DelItem", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_XDECREF(__pyx_v_key_); __Pyx_XDECREF(__pyx_v_key_start); __Pyx_XDECREF(__pyx_v_key_endex); __Pyx_XDECREF(__pyx_v_key_step); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3776: cdef:
3777: slice key_
3778: addr_t start
3779: addr_t endex
3780: addr_t step
3781: addr_t address
3782:
+3783: if Rack_Length(that.blocks):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); if (__pyx_t_1) { /* … */ }
+3784: if isinstance(key, slice):
__pyx_t_1 = PySlice_Check(__pyx_v_key);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L4;
}
+3785: key_ = <slice>key
__pyx_t_3 = __pyx_v_key;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_ = ((PyObject*)__pyx_t_3);
__pyx_t_3 = 0;
+3786: key_start = key_.start
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->start;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_start = __pyx_t_3;
__pyx_t_3 = 0;
+3787: key_endex = key_.stop
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->stop;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_endex = __pyx_t_3;
__pyx_t_3 = 0;
+3788: start = Memory_Start(that) if key_start is None else <addr_t>key_start
__pyx_t_2 = (__pyx_v_key_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_start); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3788, __pyx_L1_error) __pyx_t_4 = ((addr_t)__pyx_t_5); } __pyx_v_start = __pyx_t_4;
+3789: endex = Memory_Endex(that) if key_endex is None else <addr_t>key_endex
__pyx_t_2 = (__pyx_v_key_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); } else { __pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_endex); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3789, __pyx_L1_error) __pyx_t_4 = ((addr_t)__pyx_t_5); } __pyx_v_endex = __pyx_t_4;
3790:
+3791: if start < endex:
__pyx_t_2 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_2) { /* … */ }
+3792: key_step = key_.step
__pyx_t_3 = ((PySliceObject*)__pyx_v_key_)->step;
__Pyx_INCREF(__pyx_t_3);
__pyx_v_key_step = __pyx_t_3;
__pyx_t_3 = 0;
+3793: if key_step is None or key_step is 1 or key_step == 1:
__pyx_t_1 = (__pyx_v_key_step == Py_None); __pyx_t_6 = (__pyx_t_1 != 0); if (!__pyx_t_6) { } else { __pyx_t_2 = __pyx_t_6; goto __pyx_L7_bool_binop_done; } __pyx_t_6 = (__pyx_v_key_step == __pyx_int_1); __pyx_t_1 = (__pyx_t_6 != 0); if (!__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L7_bool_binop_done; } __pyx_t_3 = __Pyx_PyInt_EqObjC(__pyx_v_key_step, __pyx_int_1, 1, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3793, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_1 < 0)) __PYX_ERR(0, 3793, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_2 = __pyx_t_1; __pyx_L7_bool_binop_done:; if (__pyx_t_2) { /* … */ goto __pyx_L6; }
+3794: Memory_Erase__(that, start, endex, True) # delete
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 1); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3794, __pyx_L1_error)
3795:
+3796: elif key_step > 1:
__pyx_t_3 = PyObject_RichCompare(__pyx_v_key_step, __pyx_int_1, Py_GT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 3796, __pyx_L1_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3796, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_2) { /* … */ } __pyx_L6:;
+3797: step = <addr_t>key_step - 1
__pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key_step); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3797, __pyx_L1_error) __pyx_v_step = (((addr_t)__pyx_t_4) - 1);
+3798: address = start
__pyx_v_address = __pyx_v_start;
+3799: while address < endex:
while (1) { __pyx_t_2 = ((__pyx_v_address < __pyx_v_endex) != 0); if (!__pyx_t_2) break;
+3800: Memory_Erase__(that, address, address + 1, True) # delete
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_address, (__pyx_v_address + 1), 1); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3800, __pyx_L1_error)
+3801: address += step
__pyx_v_address = (__pyx_v_address + __pyx_v_step);
+3802: endex -= 1
__pyx_v_endex = (__pyx_v_endex - 1); }
3803: else:
+3804: address = <addr_t>key
/*else*/ { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_key); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3804, __pyx_L1_error) __pyx_v_address = ((addr_t)__pyx_t_4);
+3805: Memory_Erase__(that, address, address + 1, True) # delete
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_address, (__pyx_v_address + 1), 1); if (unlikely(__pyx_t_7 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3805, __pyx_L1_error)
}
__pyx_L4:;
3806:
3807:
+3808: cdef vint Memory_Append_(Memory_* that, byte_t value) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Append_(Memory_ *__pyx_v_that, byte_t __pyx_v_value) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_count; Block_ *__pyx_v_block; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Append_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_9); __Pyx_AddTraceback("cbytesparse.c.Memory_Append_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3809: cdef:
+3810: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
3811: size_t block_count
3812: Block_* block
3813:
+3814: block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
+3815: if block_count:
__pyx_t_2 = (__pyx_v_block_count != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+3816: block = Block_Append(Rack_Last_(blocks), value)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Append(__pyx_f_11cbytesparse_1c_Rack_Last_(__pyx_v_blocks), __pyx_v_value); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 3816, __pyx_L1_error)
__pyx_v_block = __pyx_t_3;
+3817: Rack_Set__(blocks, block_count - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_block_count - 1), __pyx_v_block));
3818: else:
+3819: block = Block_Create(0, 1, &value)
/*else*/ {
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Create(0, 1, (&__pyx_v_value)); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 3819, __pyx_L1_error)
__pyx_v_block = __pyx_t_3;
+3820: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; goto __pyx_L9_try_end; __pyx_L4_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_4); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6); goto __pyx_L1_error; __pyx_L9_try_end:; } } __pyx_L3:;
+3821: that.blocks = blocks = Rack_Append(blocks, block)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Append(__pyx_v_blocks, __pyx_v_block); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 3821, __pyx_L4_error)
__pyx_v_that->blocks = __pyx_t_1;
__pyx_v_blocks = __pyx_t_1;
+3822: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Append_", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_8, &__pyx_t_9) < 0) __PYX_ERR(0, 3822, __pyx_L6_except_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GOTREF(__pyx_t_8); __Pyx_GOTREF(__pyx_t_9);
+3823: Block_Free(block) # orphan
(void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block));
+3824: raise
__Pyx_GIVEREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_8); __Pyx_XGIVEREF(__pyx_t_9); __Pyx_ErrRestoreWithState(__pyx_t_7, __pyx_t_8, __pyx_t_9); __pyx_t_7 = 0; __pyx_t_8 = 0; __pyx_t_9 = 0; __PYX_ERR(0, 3824, __pyx_L6_except_error) } __pyx_L6_except_error:;
3825:
3826:
+3827: cdef vint Memory_Append(Memory_* that, object item) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Append(Memory_ *__pyx_v_that, PyObject *__pyx_v_item) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Append", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.Memory_Append", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3828: if isinstance(item, int):
__pyx_t_1 = PyInt_Check(__pyx_v_item);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+3829: Memory_Append_(that, <byte_t>item)
__pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3829, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Append_(__pyx_v_that, ((byte_t)__pyx_t_3)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3829, __pyx_L1_error)
3830: else:
+3831: if len(item) != 1:
/*else*/ { __pyx_t_5 = PyObject_Length(__pyx_v_item); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-1))) __PYX_ERR(0, 3831, __pyx_L1_error) __pyx_t_2 = ((__pyx_t_5 != 1) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+3832: raise ValueError('expecting single item')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 3832, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 3832, __pyx_L1_error)
+3833: Memory_Append_(that, <byte_t>item[0])
__pyx_t_6 = __Pyx_GetItemInt(__pyx_v_item, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 3833, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_3 = __Pyx_PyInt_As_byte_t(__pyx_t_6); if (unlikely((__pyx_t_3 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3833, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Append_(__pyx_v_that, ((byte_t)__pyx_t_3)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3833, __pyx_L1_error) } __pyx_L3:;
3834:
3835:
+3836: cdef vint Memory_ExtendSame_(Memory_* that, const Memory_* items, addr_t offset) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_ExtendSame_(Memory_ *__pyx_v_that, Memory_ const *__pyx_v_items, addr_t __pyx_v_offset) { addr_t __pyx_v_content_endex; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ExtendSame_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_ExtendSame_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3837: cdef:
+3838: addr_t content_endex = Memory_ContentEndex(that)
__pyx_v_content_endex = __pyx_f_11cbytesparse_1c_Memory_ContentEndex(__pyx_v_that);
3839:
+3840: CheckAddAddrU(content_endex, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_content_endex, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3840, __pyx_L1_error)
+3841: offset += content_endex
__pyx_v_offset = (__pyx_v_offset + __pyx_v_content_endex);
+3842: Memory_WriteSame_(that, offset, items, False)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_that, __pyx_v_offset, __pyx_v_items, 0); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3842, __pyx_L1_error)
3843:
3844:
+3845: cdef vint Memory_ExtendRaw_(Memory_* that, size_t items_size, const byte_t* items_ptr, addr_t offset) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_ExtendRaw_(Memory_ *__pyx_v_that, size_t __pyx_v_items_size, byte_t const *__pyx_v_items_ptr, addr_t __pyx_v_offset) { addr_t __pyx_v_content_endex; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ExtendRaw_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_ExtendRaw_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3846: cdef:
+3847: addr_t content_endex = Memory_ContentEndex(that)
__pyx_v_content_endex = __pyx_f_11cbytesparse_1c_Memory_ContentEndex(__pyx_v_that);
3848:
+3849: CheckAddAddrU(content_endex, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_content_endex, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3849, __pyx_L1_error)
+3850: offset += content_endex
__pyx_v_offset = (__pyx_v_offset + __pyx_v_content_endex);
+3851: CheckAddAddrU(offset, items_size)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_offset, __pyx_v_items_size); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3851, __pyx_L1_error)
+3852: Memory_WriteRaw_(that, offset, items_size, items_ptr)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(__pyx_v_that, __pyx_v_offset, __pyx_v_items_size, __pyx_v_items_ptr); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3852, __pyx_L1_error)
3853:
3854:
+3855: cdef vint Memory_Extend(Memory_* that, object items, object offset) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Extend(Memory_ *__pyx_v_that, PyObject *__pyx_v_items, PyObject *__pyx_v_offset) { __Pyx_memviewslice __pyx_v_items_view = { 0, 0, { 0 }, { 0 }, { 0 } }; byte_t __pyx_v_items_value; size_t __pyx_v_items_size; byte_t const *__pyx_v_items_ptr; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Extend", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1); __Pyx_AddTraceback("cbytesparse.c.Memory_Extend", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_items_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3856: cdef:
3857: const byte_t[:] items_view
3858: byte_t items_value
3859: size_t items_size
3860: const byte_t* items_ptr
3861:
+3862: if offset < 0:
__pyx_t_1 = PyObject_RichCompare(__pyx_v_offset, __pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3862, __pyx_L1_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 3862, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (unlikely(__pyx_t_2)) { /* … */ }
+3863: raise ValueError('negative extension offset')
__pyx_t_1 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__19, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 3863, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 3863, __pyx_L1_error) /* … */ __pyx_tuple__19 = PyTuple_Pack(1, __pyx_kp_u_negative_extension_offset); if (unlikely(!__pyx_tuple__19)) __PYX_ERR(0, 3863, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__19); __Pyx_GIVEREF(__pyx_tuple__19);
3864:
+3865: if isinstance(items, Memory):
__pyx_t_2 = __Pyx_TypeCheck(__pyx_v_items, __pyx_ptype_11cbytesparse_1c_Memory);
__pyx_t_3 = (__pyx_t_2 != 0);
if (__pyx_t_3) {
/* … */
goto __pyx_L4;
}
+3866: Memory_ExtendSame_(that, (<Memory>items)._, <addr_t>offset)
__pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3866, __pyx_L1_error) __pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_ExtendSame_(__pyx_v_that, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_items)->_, ((addr_t)__pyx_t_4)); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3866, __pyx_L1_error)
3867: else:
+3868: if isinstance(items, int):
/*else*/ {
__pyx_t_3 = PyInt_Check(__pyx_v_items);
__pyx_t_2 = (__pyx_t_3 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L5;
}
+3869: items_value = <byte_t>items
__pyx_t_6 = __Pyx_PyInt_As_byte_t(__pyx_v_items); if (unlikely((__pyx_t_6 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3869, __pyx_L1_error) __pyx_v_items_value = ((byte_t)__pyx_t_6);
+3870: items_size = 1
__pyx_v_items_size = 1;
+3871: items_ptr = &items_value
__pyx_v_items_ptr = (&__pyx_v_items_value);
3872: else:
+3873: items_view = items
/*else*/ { __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_items, 0); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(0, 3873, __pyx_L1_error) __pyx_v_items_view = __pyx_t_7; __pyx_t_7.memview = NULL; __pyx_t_7.data = NULL;
+3874: items_size = len(items_view)
__pyx_t_8 = __Pyx_MemoryView_Len(__pyx_v_items_view);
__pyx_v_items_size = __pyx_t_8;
3875: with cython.boundscheck(False):
+3876: items_ptr = &items_view[0]
__pyx_t_9 = 0; if (__pyx_t_9 < 0) __pyx_t_9 += __pyx_v_items_view.shape[0]; __pyx_v_items_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_items_view.data + __pyx_t_9 * __pyx_v_items_view.strides[0]) )))); } __pyx_L5:;
3877:
+3878: Memory_ExtendRaw_(that, items_size, items_ptr, <addr_t>offset)
__pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3878, __pyx_L1_error) __pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_ExtendRaw_(__pyx_v_that, __pyx_v_items_size, __pyx_v_items_ptr, ((addr_t)__pyx_t_4)); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3878, __pyx_L1_error) } __pyx_L4:;
3879:
3880:
+3881: cdef int Memory_PopLast_(Memory_* that) except -2:
static int __pyx_f_11cbytesparse_1c_Memory_PopLast_(Memory_ *__pyx_v_that) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_count; Block_ *__pyx_v_block; byte_t __pyx_v_backup; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PopLast_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PopLast_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -2; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3882: cdef:
+3883: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
+3884: size_t block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
3885: Block_* block
3886: byte_t backup
3887:
+3888: if block_count:
__pyx_t_2 = (__pyx_v_block_count != 0); if (__pyx_t_2) { /* … */ }
+3889: block = Rack_Last_(blocks)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Last_(__pyx_v_blocks);
+3890: if Block_Length(block) > 1:
__pyx_t_2 = ((__pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block) > 1) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+3891: block = Block_Pop__(block, &backup)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Block_Pop__(__pyx_v_block, (&__pyx_v_backup)); if (unlikely(__pyx_t_3 == ((Block_ *)NULL))) __PYX_ERR(0, 3891, __pyx_L1_error)
__pyx_v_block = __pyx_t_3;
+3892: Rack_Set__(blocks, block_count - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_block_count - 1), __pyx_v_block));
3893: else:
+3894: backup = Block_Get__(block, 0)
/*else*/ { __pyx_v_backup = __pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_block, 0);
+3895: that.blocks = blocks = Rack_Pop__(blocks, NULL)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Pop__(__pyx_v_blocks, NULL); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 3895, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_1;
__pyx_v_blocks = __pyx_t_1;
}
__pyx_L4:;
+3896: return backup
__pyx_r = __pyx_v_backup; goto __pyx_L0;
3897: else:
+3898: return -1
/*else*/ { __pyx_r = -1; goto __pyx_L0; }
3899:
3900:
+3901: cdef int Memory_PopAt_(Memory_* that, addr_t address) except -2:
static int __pyx_f_11cbytesparse_1c_Memory_PopAt_(Memory_ *__pyx_v_that, addr_t __pyx_v_address) { int __pyx_v_backup; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PopAt_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PopAt_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -2; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3902: cdef:
3903: int backup
3904:
+3905: backup = Memory_Peek_(that, address)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Peek_(__pyx_v_that, __pyx_v_address); if (unlikely(__pyx_t_1 == ((int)-2))) __PYX_ERR(0, 3905, __pyx_L1_error)
__pyx_v_backup = __pyx_t_1;
+3906: Memory_Erase__(that, address, address + 1, True) # delete
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_address, (__pyx_v_address + 1), 1); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 3906, __pyx_L1_error)
+3907: return backup
__pyx_r = __pyx_v_backup; goto __pyx_L0;
3908:
3909:
+3910: cdef object Memory_Pop(Memory_* that, object address):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Pop(Memory_ *__pyx_v_that, PyObject *__pyx_v_address) { int __pyx_v_value; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Pop", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.Memory_Pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3911: cdef:
3912: int value
3913:
+3914: if address is None:
__pyx_t_1 = (__pyx_v_address == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+3915: value = Memory_PopLast_(that)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_PopLast_(__pyx_v_that); if (unlikely(__pyx_t_3 == ((int)-2))) __PYX_ERR(0, 3915, __pyx_L1_error)
__pyx_v_value = __pyx_t_3;
3916: else:
+3917: value = Memory_PopAt_(that, <addr_t>address)
/*else*/ { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 3917, __pyx_L1_error) __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_PopAt_(__pyx_v_that, ((addr_t)__pyx_t_4)); if (unlikely(__pyx_t_3 == ((int)-2))) __PYX_ERR(0, 3917, __pyx_L1_error) __pyx_v_value = __pyx_t_3; } __pyx_L3:;
+3918: return None if value < 0 else value
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_value < 0) != 0)) { __Pyx_INCREF(Py_None); __pyx_t_5 = Py_None; } else { __pyx_t_6 = __Pyx_PyInt_From_int(__pyx_v_value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 3918, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __pyx_t_6; __pyx_t_6 = 0; } __pyx_r = __pyx_t_5; __pyx_t_5 = 0; goto __pyx_L0;
3919:
3920:
+3921: cdef BlockView Memory_View(const Memory_* that, addr_t start, addr_t endex):
static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_f_11cbytesparse_1c_Memory_View(Memory_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { Rack_ const *__pyx_v_blocks; Block_ *__pyx_v_block; Py_ssize_t __pyx_v_block_index; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_View", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory_View", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
3922: cdef:
3923: const Rack_* blocks
3924: Block_* block
3925: ssize_t block_index
3926: addr_t block_start
3927: addr_t block_endex
3928:
+3929: if start < endex:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ }
+3930: blocks = that.blocks
__pyx_t_2 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_2;
+3931: block_index = Rack_IndexAt(blocks, start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexAt(__pyx_v_blocks, __pyx_v_start); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 3931, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_3;
3932:
+3933: if block_index >= 0:
__pyx_t_1 = ((__pyx_v_block_index >= 0) != 0); if (__pyx_t_1) { /* … */ }
+3934: block = Rack_Get__(blocks, <size_t>block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, ((size_t)__pyx_v_block_index));
+3935: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
3936:
+3937: if endex <= block_endex:
__pyx_t_1 = ((__pyx_v_endex <= __pyx_v_block_endex) != 0); if (__pyx_t_1) { /* … */ }
+3938: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+3939: start -= block_start
__pyx_v_start = (__pyx_v_start - __pyx_v_block_start);
+3940: endex -= block_start
__pyx_v_endex = (__pyx_v_endex - __pyx_v_block_start);
+3941: return Block_ViewSlice_(block, start, endex)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_4 = ((PyObject *)__pyx_f_11cbytesparse_1c_Block_ViewSlice_(__pyx_v_block, __pyx_v_start, __pyx_v_endex)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3941, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_4); __pyx_t_4 = 0; goto __pyx_L0;
3942:
+3943: raise ValueError('non-contiguous data within range')
__pyx_t_4 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__20, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3943, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 3943, __pyx_L1_error) /* … */ __pyx_tuple__20 = PyTuple_Pack(1, __pyx_kp_u_non_contiguous_data_within_range); if (unlikely(!__pyx_tuple__20)) __PYX_ERR(0, 3943, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__20); __Pyx_GIVEREF(__pyx_tuple__20);
3944: else:
+3945: return Block_ViewSlice_(_empty_block, 0, 0)
/*else*/ { __Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_4 = ((PyObject *)__pyx_f_11cbytesparse_1c_Block_ViewSlice_(__pyx_v_11cbytesparse_1c__empty_block, 0, 0)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 3945, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_4); __pyx_t_4 = 0; goto __pyx_L0; }
3946:
3947:
+3948: cdef Memory_* Memory_Copy(const Memory_* that) except NULL:
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Copy(Memory_ const *__pyx_v_that) { Rack_ *__pyx_v_blocks; Memory_ *__pyx_v_memory; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Copy", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Copy", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3949: cdef:
+3950: Rack_* blocks = Rack_Copy(that.blocks)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Copy(__pyx_v_that->blocks); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 3950, __pyx_L1_error)
__pyx_v_blocks = __pyx_t_1;
+3951: Memory_* memory = NULL
__pyx_v_memory = NULL;
3952:
+3953: memory = <Memory_*>PyMem_Calloc(Memory_HEADING, 1)
__pyx_v_memory = ((Memory_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(Memory_HEADING, 1));
+3954: if memory == NULL:
__pyx_t_2 = ((__pyx_v_memory == NULL) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+3955: blocks = Rack_Free(blocks)
__pyx_v_blocks = __pyx_f_11cbytesparse_1c_Rack_Free(__pyx_v_blocks);
+3956: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 3956, __pyx_L1_error)
3957:
+3958: memory.blocks = blocks
__pyx_v_memory->blocks = __pyx_v_blocks;
+3959: memory.trim_start = that.trim_start
__pyx_t_3 = __pyx_v_that->trim_start; __pyx_v_memory->trim_start = __pyx_t_3;
+3960: memory.trim_endex = that.trim_endex
__pyx_t_3 = __pyx_v_that->trim_endex; __pyx_v_memory->trim_endex = __pyx_t_3;
+3961: memory.trim_start_ = that.trim_start_
__pyx_t_2 = __pyx_v_that->trim_start_; __pyx_v_memory->trim_start_ = __pyx_t_2;
+3962: memory.trim_endex_ = that.trim_endex_
__pyx_t_2 = __pyx_v_that->trim_endex_; __pyx_v_memory->trim_endex_ = __pyx_t_2;
+3963: return memory
__pyx_r = __pyx_v_memory; goto __pyx_L0;
3964:
3965:
+3966: cdef bint Memory_Contiguous(const Memory_* that) nogil:
static int __pyx_f_11cbytesparse_1c_Memory_Contiguous(Memory_ const *__pyx_v_that) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_count; addr_t __pyx_v_start; addr_t __pyx_v_endex; int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
3967: cdef:
+3968: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
+3969: size_t block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
3970: addr_t start
3971: addr_t endex
3972:
+3973: if not block_count:
__pyx_t_2 = ((!(__pyx_v_block_count != 0)) != 0); if (__pyx_t_2) { /* … */ }
+3974: start = that.trim_start
__pyx_t_3 = __pyx_v_that->trim_start; __pyx_v_start = __pyx_t_3;
+3975: endex = that.trim_endex
__pyx_t_3 = __pyx_v_that->trim_endex; __pyx_v_endex = __pyx_t_3;
+3976: if that.trim_start_ and that.trim_endex_ and start < endex:
__pyx_t_4 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_4) { } else { __pyx_t_2 = __pyx_t_4; goto __pyx_L5_bool_binop_done; } __pyx_t_4 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_4) { } else { __pyx_t_2 = __pyx_t_4; goto __pyx_L5_bool_binop_done; } __pyx_t_4 = ((__pyx_v_start < __pyx_v_endex) != 0); __pyx_t_2 = __pyx_t_4; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+3977: return False
__pyx_r = 0; goto __pyx_L0;
+3978: return True
__pyx_r = 1; goto __pyx_L0;
3979:
+3980: elif block_count == 1:
__pyx_t_2 = ((__pyx_v_block_count == 1) != 0); if (__pyx_t_2) { /* … */ }
+3981: start = that.trim_start
__pyx_t_3 = __pyx_v_that->trim_start; __pyx_v_start = __pyx_t_3;
+3982: if that.trim_start_:
__pyx_t_2 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_2) { /* … */ }
+3983: if start != Block_Start(Rack_First__(blocks)):
__pyx_t_2 = ((__pyx_v_start != __pyx_f_11cbytesparse_1c_Block_Start(__pyx_f_11cbytesparse_1c_Rack_First__(__pyx_v_blocks))) != 0); if (__pyx_t_2) { /* … */ }
+3984: return False
__pyx_r = 0; goto __pyx_L0;
+3985: endex = that.trim_endex
__pyx_t_3 = __pyx_v_that->trim_endex; __pyx_v_endex = __pyx_t_3;
+3986: if that.trim_endex_:
__pyx_t_2 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_2) { /* … */ }
+3987: if endex != Block_Endex(Rack_Last__(blocks)):
__pyx_t_2 = ((__pyx_v_endex != __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks))) != 0); if (__pyx_t_2) { /* … */ }
+3988: return False
__pyx_r = 0; goto __pyx_L0;
+3989: return True
__pyx_r = 1; goto __pyx_L0;
3990:
+3991: return False
__pyx_r = 0; goto __pyx_L0;
3992:
3993:
+3994: cdef object Memory_GetTrimStart(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_GetTrimStart(Memory_ const *__pyx_v_that) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_GetTrimStart", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory_GetTrimStart", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+3995: return that.trim_start if that.trim_start_ else None
__Pyx_XDECREF(__pyx_r); if ((__pyx_v_that->trim_start_ != 0)) { __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_that->trim_start); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 3995, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __pyx_t_2; __pyx_t_2 = 0; } else { __Pyx_INCREF(Py_None); __pyx_t_1 = Py_None; } __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
3996:
3997:
+3998: cdef vint Memory_SetTrimStart(Memory_* that, object trim_start) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_SetTrimStart(Memory_ *__pyx_v_that, PyObject *__pyx_v_trim_start) { addr_t __pyx_v_trim_start_; addr_t __pyx_v_trim_endex_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_SetTrimStart", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_SetTrimStart", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
3999: cdef:
4000: addr_t trim_start_
4001: addr_t trim_endex_
4002:
+4003: if trim_start is None:
__pyx_t_1 = (__pyx_v_trim_start == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+4004: trim_start_ = 0
__pyx_v_trim_start_ = 0;
+4005: that.trim_start_ = False
__pyx_v_that->trim_start_ = 0;
4006: else:
+4007: trim_start_ = <addr_t>trim_start
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_trim_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4007, __pyx_L1_error) __pyx_v_trim_start_ = ((addr_t)__pyx_t_3);
+4008: that.trim_start_ = True
__pyx_v_that->trim_start_ = 1; } __pyx_L3:;
4009:
+4010: trim_endex_ = that.trim_endex
__pyx_t_3 = __pyx_v_that->trim_endex; __pyx_v_trim_endex_ = __pyx_t_3;
+4011: if that.trim_start_ and that.trim_endex_ and trim_endex_ < trim_start_:
__pyx_t_1 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L5_bool_binop_done; } __pyx_t_1 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L5_bool_binop_done; } __pyx_t_1 = ((__pyx_v_trim_endex_ < __pyx_v_trim_start_) != 0); __pyx_t_2 = __pyx_t_1; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+4012: that.trim_endex = trim_endex_ = trim_start_
__pyx_v_that->trim_endex = __pyx_v_trim_start_; __pyx_v_trim_endex_ = __pyx_v_trim_start_;
4013:
+4014: that.trim_start = trim_start_
__pyx_v_that->trim_start = __pyx_v_trim_start_;
+4015: if that.trim_start_:
__pyx_t_2 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_2) { /* … */ }
+4016: Memory_Crop_(that, trim_start_, trim_endex_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_that, __pyx_v_trim_start_, __pyx_v_trim_endex_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4016, __pyx_L1_error)
4017:
4018:
+4019: cdef object Memory_GetTrimEndex(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_GetTrimEndex(Memory_ const *__pyx_v_that) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_GetTrimEndex", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory_GetTrimEndex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4020: return that.trim_endex if that.trim_endex_ else None
__Pyx_XDECREF(__pyx_r); if ((__pyx_v_that->trim_endex_ != 0)) { __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_that->trim_endex); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4020, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __pyx_t_2; __pyx_t_2 = 0; } else { __Pyx_INCREF(Py_None); __pyx_t_1 = Py_None; } __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
4021:
4022:
+4023: cdef vint Memory_SetTrimEndex(Memory_* that, object trim_endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_SetTrimEndex(Memory_ *__pyx_v_that, PyObject *__pyx_v_trim_endex) { addr_t __pyx_v_trim_start_; addr_t __pyx_v_trim_endex_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_SetTrimEndex", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_SetTrimEndex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4024: cdef:
4025: addr_t trim_start_
4026: addr_t trim_endex_
4027:
+4028: if trim_endex is None:
__pyx_t_1 = (__pyx_v_trim_endex == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+4029: trim_endex_ = ADDR_MAX
__pyx_v_trim_endex_ = ADDR_MAX;
+4030: that.trim_endex_ = False
__pyx_v_that->trim_endex_ = 0;
4031: else:
+4032: trim_endex_ = <addr_t>trim_endex
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_trim_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4032, __pyx_L1_error) __pyx_v_trim_endex_ = ((addr_t)__pyx_t_3);
+4033: that.trim_endex_ = True
__pyx_v_that->trim_endex_ = 1; } __pyx_L3:;
4034:
+4035: trim_start_ = that.trim_start
__pyx_t_3 = __pyx_v_that->trim_start; __pyx_v_trim_start_ = __pyx_t_3;
+4036: if that.trim_start_ and that.trim_endex_ and trim_endex_ < trim_start_:
__pyx_t_1 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L5_bool_binop_done; } __pyx_t_1 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_1) { } else { __pyx_t_2 = __pyx_t_1; goto __pyx_L5_bool_binop_done; } __pyx_t_1 = ((__pyx_v_trim_endex_ < __pyx_v_trim_start_) != 0); __pyx_t_2 = __pyx_t_1; __pyx_L5_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+4037: that.trim_start = trim_start_ = trim_endex_
__pyx_v_that->trim_start = __pyx_v_trim_endex_; __pyx_v_trim_start_ = __pyx_v_trim_endex_;
4038:
+4039: that.trim_endex = trim_endex_
__pyx_v_that->trim_endex = __pyx_v_trim_endex_;
+4040: if that.trim_endex_:
__pyx_t_2 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_2) { /* … */ }
+4041: Memory_Crop_(that, trim_start_, trim_endex_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_that, __pyx_v_trim_start_, __pyx_v_trim_endex_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4041, __pyx_L1_error)
4042:
4043:
+4044: cdef object Memory_GetTrimSpan(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_GetTrimSpan(Memory_ const *__pyx_v_that) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_GetTrimSpan", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory_GetTrimSpan", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4045: return (that.trim_start if that.trim_start_ else None,
__Pyx_XDECREF(__pyx_r); if ((__pyx_v_that->trim_start_ != 0)) { __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_that->trim_start); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4045, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __pyx_t_2; __pyx_t_2 = 0; } else { __Pyx_INCREF(Py_None); __pyx_t_1 = Py_None; } /* … */ __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4045, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2); __pyx_t_1 = 0; __pyx_t_2 = 0; __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
+4046: that.trim_endex if that.trim_endex_ else None)
if ((__pyx_v_that->trim_endex_ != 0)) { __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_that->trim_endex); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = __pyx_t_3; __pyx_t_3 = 0; } else { __Pyx_INCREF(Py_None); __pyx_t_2 = Py_None; }
4047:
4048:
+4049: cdef vint Memory_SetTrimSpan(Memory_* that, object trim_span) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_SetTrimSpan(Memory_ *__pyx_v_that, PyObject *__pyx_v_trim_span) { PyObject *__pyx_v_trim_start = NULL; PyObject *__pyx_v_trim_endex = NULL; addr_t __pyx_v_trim_start_; addr_t __pyx_v_trim_endex_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_SetTrimSpan", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory_SetTrimSpan", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_XDECREF(__pyx_v_trim_start); __Pyx_XDECREF(__pyx_v_trim_endex); __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4050: trim_start, trim_endex = trim_span
if ((likely(PyTuple_CheckExact(__pyx_v_trim_span))) || (PyList_CheckExact(__pyx_v_trim_span))) { PyObject* sequence = __pyx_v_trim_span; Py_ssize_t size = __Pyx_PySequence_SIZE(sequence); if (unlikely(size != 2)) { if (size > 2) __Pyx_RaiseTooManyValuesError(2); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); __PYX_ERR(0, 4050, __pyx_L1_error) } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS if (likely(PyTuple_CheckExact(sequence))) { __pyx_t_1 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_2 = PyTuple_GET_ITEM(sequence, 1); } else { __pyx_t_1 = PyList_GET_ITEM(sequence, 0); __pyx_t_2 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_1); __Pyx_INCREF(__pyx_t_2); #else __pyx_t_1 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 4050, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4050, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); #endif } else { Py_ssize_t index = -1; __pyx_t_3 = PyObject_GetIter(__pyx_v_trim_span); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4050, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = Py_TYPE(__pyx_t_3)->tp_iternext; index = 0; __pyx_t_1 = __pyx_t_4(__pyx_t_3); if (unlikely(!__pyx_t_1)) goto __pyx_L3_unpacking_failed; __Pyx_GOTREF(__pyx_t_1); index = 1; __pyx_t_2 = __pyx_t_4(__pyx_t_3); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed; __Pyx_GOTREF(__pyx_t_2); if (__Pyx_IternextUnpackEndCheck(__pyx_t_4(__pyx_t_3), 2) < 0) __PYX_ERR(0, 4050, __pyx_L1_error) __pyx_t_4 = NULL; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; goto __pyx_L4_unpacking_done; __pyx_L3_unpacking_failed:; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_4 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); __PYX_ERR(0, 4050, __pyx_L1_error) __pyx_L4_unpacking_done:; } __pyx_v_trim_start = __pyx_t_1; __pyx_t_1 = 0; __pyx_v_trim_endex = __pyx_t_2; __pyx_t_2 = 0;
4051:
+4052: if trim_start is None:
__pyx_t_5 = (__pyx_v_trim_start == Py_None); __pyx_t_6 = (__pyx_t_5 != 0); if (__pyx_t_6) { /* … */ goto __pyx_L5; }
+4053: trim_start_ = 0
__pyx_v_trim_start_ = 0;
+4054: that.trim_start_ = False
__pyx_v_that->trim_start_ = 0;
4055: else:
+4056: trim_start_ = <addr_t>trim_start
/*else*/ { __pyx_t_7 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_trim_start); if (unlikely((__pyx_t_7 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4056, __pyx_L1_error) __pyx_v_trim_start_ = ((addr_t)__pyx_t_7);
+4057: that.trim_start_ = True
__pyx_v_that->trim_start_ = 1; } __pyx_L5:;
4058:
+4059: if trim_endex is None:
__pyx_t_6 = (__pyx_v_trim_endex == Py_None); __pyx_t_5 = (__pyx_t_6 != 0); if (__pyx_t_5) { /* … */ goto __pyx_L6; }
+4060: trim_endex_ = ADDR_MAX
__pyx_v_trim_endex_ = ADDR_MAX;
+4061: that.trim_endex_ = False
__pyx_v_that->trim_endex_ = 0;
4062: else:
+4063: trim_endex_ = <addr_t>trim_endex
/*else*/ { __pyx_t_7 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_trim_endex); if (unlikely((__pyx_t_7 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4063, __pyx_L1_error) __pyx_v_trim_endex_ = ((addr_t)__pyx_t_7);
+4064: that.trim_endex_ = True
__pyx_v_that->trim_endex_ = 1; } __pyx_L6:;
4065:
+4066: if that.trim_start_ and that.trim_endex_ and trim_endex_ < trim_start_:
__pyx_t_6 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_6) { } else { __pyx_t_5 = __pyx_t_6; goto __pyx_L8_bool_binop_done; } __pyx_t_6 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_6) { } else { __pyx_t_5 = __pyx_t_6; goto __pyx_L8_bool_binop_done; } __pyx_t_6 = ((__pyx_v_trim_endex_ < __pyx_v_trim_start_) != 0); __pyx_t_5 = __pyx_t_6; __pyx_L8_bool_binop_done:; if (__pyx_t_5) { /* … */ }
+4067: trim_endex_ = trim_start_
__pyx_v_trim_endex_ = __pyx_v_trim_start_;
4068:
+4069: that.trim_start = trim_start_
__pyx_v_that->trim_start = __pyx_v_trim_start_;
+4070: that.trim_endex = trim_endex_
__pyx_v_that->trim_endex = __pyx_v_trim_endex_;
+4071: if that.trim_start_ or that.trim_endex_:
__pyx_t_6 = (__pyx_v_that->trim_start_ != 0); if (!__pyx_t_6) { } else { __pyx_t_5 = __pyx_t_6; goto __pyx_L12_bool_binop_done; } __pyx_t_6 = (__pyx_v_that->trim_endex_ != 0); __pyx_t_5 = __pyx_t_6; __pyx_L12_bool_binop_done:; if (__pyx_t_5) { /* … */ }
+4072: Memory_Crop_(that, trim_start_, trim_endex_)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_that, __pyx_v_trim_start_, __pyx_v_trim_endex_); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4072, __pyx_L1_error)
4073:
4074:
+4075: cdef addr_t Memory_Start(const Memory_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Memory_Start(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
4076: cdef:
4077: const Rack_* blocks
4078:
+4079: if not that.trim_start_:
__pyx_t_1 = ((!(__pyx_v_that->trim_start_ != 0)) != 0); if (__pyx_t_1) { /* … */ }
4080: # Return actual
+4081: blocks = that.blocks
__pyx_t_2 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_2;
+4082: if Rack_Length(blocks):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_1) { /* … */ }
+4083: return Block_Start(Rack_First__(blocks))
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_f_11cbytesparse_1c_Rack_First__(__pyx_v_blocks)); goto __pyx_L0;
4084: else:
+4085: return 0
/*else*/ { __pyx_r = 0; goto __pyx_L0; }
4086: else:
+4087: return that.trim_start
/*else*/ { __pyx_r = __pyx_v_that->trim_start; goto __pyx_L0; }
4088:
4089:
+4090: cdef addr_t Memory_Endex(const Memory_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Memory_Endex(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
4091: cdef:
4092: const Rack_* blocks
4093:
+4094: if not that.trim_endex_:
__pyx_t_1 = ((!(__pyx_v_that->trim_endex_ != 0)) != 0); if (__pyx_t_1) { /* … */ }
4095: # Return actual
+4096: blocks = that.blocks
__pyx_t_2 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_2;
+4097: if Rack_Length(blocks):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_1) { /* … */ }
+4098: return Block_Endex(Rack_Last__(blocks))
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks)); goto __pyx_L0;
4099: else:
+4100: return Memory_Start(that)
/*else*/ { __pyx_r = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); goto __pyx_L0; }
4101: else:
+4102: return that.trim_endex
/*else*/ { __pyx_r = __pyx_v_that->trim_endex; goto __pyx_L0; }
4103:
4104:
+4105: cdef (addr_t, addr_t) Memory_Span(const Memory_* that) nogil:
static __pyx_ctuple_addr_t__and_addr_t __pyx_f_11cbytesparse_1c_Memory_Span(Memory_ const *__pyx_v_that) { __pyx_ctuple_addr_t__and_addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+4106: return Memory_Start(that), Memory_Endex(that)
__pyx_t_1.f0 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); __pyx_t_1.f1 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); __pyx_r = __pyx_t_1; goto __pyx_L0;
4107:
4108:
+4109: cdef object Memory_Endin(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Endin(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Endin", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory_Endin", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
4110: cdef:
4111: const Rack_* blocks
4112:
+4113: if not that.trim_endex_:
__pyx_t_1 = ((!(__pyx_v_that->trim_endex_ != 0)) != 0); if (__pyx_t_1) { /* … */ }
4114: # Return actual
+4115: blocks = that.blocks
__pyx_t_2 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_2;
+4116: if Rack_Length(blocks):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_1) { /* … */ }
+4117: return <object>Block_Endex(Rack_Last__(blocks)) - 1
__Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks))); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4117, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyInt_SubtractObjC(__pyx_t_3, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 4117, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0;
4118: else:
+4119: return <object>Memory_Start(that) - 1
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 4119, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __Pyx_PyInt_SubtractObjC(__pyx_t_4, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4119, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; }
4120: else:
+4121: return <object>that.trim_endex - 1
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_that->trim_endex); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4121, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyInt_SubtractObjC(__pyx_t_3, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 4121, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; }
4122:
4123:
+4124: cdef addr_t Memory_ContentStart(const Memory_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Memory_ContentStart(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
4125: cdef:
+4126: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4127:
+4128: if Rack_Length(blocks):
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_2) { /* … */ }
+4129: return Block_Start(Rack_First__(blocks))
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_f_11cbytesparse_1c_Rack_First__(__pyx_v_blocks)); goto __pyx_L0;
+4130: elif not that.trim_start_:
__pyx_t_2 = ((!(__pyx_v_that->trim_start_ != 0)) != 0); if (__pyx_t_2) { /* … */ }
+4131: return 0
__pyx_r = 0; goto __pyx_L0;
4132: else:
+4133: return that.trim_start
/*else*/ { __pyx_r = __pyx_v_that->trim_start; goto __pyx_L0; }
4134:
4135:
+4136: cdef addr_t Memory_ContentEndex(const Memory_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Memory_ContentEndex(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
4137: cdef:
+4138: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4139:
+4140: if Rack_Length(blocks):
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_2) { /* … */ }
+4141: return Block_Endex(Rack_Last__(blocks))
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks)); goto __pyx_L0;
+4142: elif not that.trim_start_:
__pyx_t_2 = ((!(__pyx_v_that->trim_start_ != 0)) != 0); if (__pyx_t_2) { /* … */ }
+4143: return 0 # default to start
__pyx_r = 0; goto __pyx_L0;
4144: else:
+4145: return that.trim_start # default to start
/*else*/ { __pyx_r = __pyx_v_that->trim_start; goto __pyx_L0; }
4146:
4147:
+4148: cdef (addr_t, addr_t) Memory_ContentSpan(const Memory_* that) nogil:
static __pyx_ctuple_addr_t__and_addr_t __pyx_f_11cbytesparse_1c_Memory_ContentSpan(Memory_ const *__pyx_v_that) { __pyx_ctuple_addr_t__and_addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+4149: return Memory_ContentStart(that), Memory_ContentEndex(that)
__pyx_t_1.f0 = __pyx_f_11cbytesparse_1c_Memory_ContentStart(__pyx_v_that); __pyx_t_1.f1 = __pyx_f_11cbytesparse_1c_Memory_ContentEndex(__pyx_v_that); __pyx_r = __pyx_t_1; goto __pyx_L0;
4150:
4151:
+4152: cdef object Memory_ContentEndin(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_ContentEndin(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ContentEndin", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory_ContentEndin", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
4153: cdef:
+4154: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4155:
+4156: if Rack_Length(blocks):
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_2) { /* … */ }
+4157: return <object>Block_Endex(Rack_Last__(blocks)) - 1
__Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks))); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4157, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyInt_SubtractObjC(__pyx_t_3, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 4157, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0;
+4158: elif not that.trim_start_: # default to start-1
__pyx_t_2 = ((!(__pyx_v_that->trim_start_ != 0)) != 0); if (__pyx_t_2) { /* … */ }
+4159: return -1
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_int_neg_1); __pyx_r = __pyx_int_neg_1; goto __pyx_L0;
4160: else:
+4161: return <object>that.trim_start - 1 # default to start-1
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_that->trim_start); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 4161, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __Pyx_PyInt_SubtractObjC(__pyx_t_4, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 4161, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; }
4162:
4163:
+4164: cdef addr_t Memory_ContentSize(const Memory_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Memory_ContentSize(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_content_size; addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
4165: cdef:
+4166: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4167: size_t block_index
4168: const Block_* block
+4169: addr_t content_size = 0
__pyx_v_content_size = 0;
4170:
+4171: for block_index in range(Rack_Length(blocks)):
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_3 = __pyx_t_2; for (__pyx_t_4 = 0; __pyx_t_4 < __pyx_t_3; __pyx_t_4+=1) { __pyx_v_block_index = __pyx_t_4;
+4172: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4173: content_size += Block_Length(block)
__pyx_v_content_size = (__pyx_v_content_size + __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block)); }
+4174: return content_size
__pyx_r = __pyx_v_content_size; goto __pyx_L0;
4175:
4176:
+4177: cdef size_t Memory_ContentParts(const Memory_* that) nogil:
static size_t __pyx_f_11cbytesparse_1c_Memory_ContentParts(Memory_ const *__pyx_v_that) { size_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+4178: return Rack_Length(that.blocks)
__pyx_r = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks); goto __pyx_L0;
4179:
4180:
+4181: cdef vint Memory_Validate(const Memory_* that) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Validate(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_count; addr_t __pyx_v_start; addr_t __pyx_v_endex; addr_t __pyx_v_previous_endex; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Validate", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.Memory_Validate", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4182: cdef:
+4183: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
+4184: size_t block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
4185:
4186: addr_t start
4187: addr_t endex
+4188: addr_t previous_endex = 0
__pyx_v_previous_endex = 0;
4189:
4190: size_t block_index
4191: const Block_* block
4192: addr_t block_start
4193: addr_t block_endex
4194:
+4195: start, endex = Memory_Bound(that, None, None)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, Py_None, Py_None); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 4195, __pyx_L1_error)
__pyx_t_3 = __pyx_t_2.f0;
__pyx_t_4 = __pyx_t_2.f1;
__pyx_v_start = __pyx_t_3;
__pyx_v_endex = __pyx_t_4;
+4196: block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
4197:
+4198: if block_count:
__pyx_t_5 = (__pyx_v_block_count != 0); if (__pyx_t_5) { /* … */ goto __pyx_L3; }
+4199: if endex <= start:
__pyx_t_5 = ((__pyx_v_endex <= __pyx_v_start) != 0); if (unlikely(__pyx_t_5)) { /* … */ }
+4200: raise ValueError('invalid bounds')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__21, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 4200, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 4200, __pyx_L1_error) /* … */ __pyx_tuple__21 = PyTuple_Pack(1, __pyx_kp_u_invalid_bounds); if (unlikely(!__pyx_tuple__21)) __PYX_ERR(0, 4200, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__21); __Pyx_GIVEREF(__pyx_tuple__21);
4201:
+4202: for block_index in range(block_count):
__pyx_t_7 = __pyx_v_block_count; __pyx_t_8 = __pyx_t_7; for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_8; __pyx_t_9+=1) { __pyx_v_block_index = __pyx_t_9;
+4203: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4204: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+4205: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
4206:
+4207: if block_index: # skip first
__pyx_t_5 = (__pyx_v_block_index != 0); if (__pyx_t_5) { /* … */ }
+4208: if block_start <= previous_endex:
__pyx_t_5 = ((__pyx_v_block_start <= __pyx_v_previous_endex) != 0); if (unlikely(__pyx_t_5)) { /* … */ }
+4209: raise ValueError('invalid block interleaving')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__22, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 4209, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 4209, __pyx_L1_error) /* … */ __pyx_tuple__22 = PyTuple_Pack(1, __pyx_kp_u_invalid_block_interleaving); if (unlikely(!__pyx_tuple__22)) __PYX_ERR(0, 4209, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__22); __Pyx_GIVEREF(__pyx_tuple__22);
4210:
+4211: if block_endex <= block_start:
__pyx_t_5 = ((__pyx_v_block_endex <= __pyx_v_block_start) != 0); if (unlikely(__pyx_t_5)) { /* … */ }
+4212: raise ValueError('invalid block data size')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__4, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 4212, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 4212, __pyx_L1_error)
4213:
+4214: if block_start < start or endex < block_endex:
__pyx_t_10 = ((__pyx_v_block_start < __pyx_v_start) != 0); if (!__pyx_t_10) { } else { __pyx_t_5 = __pyx_t_10; goto __pyx_L11_bool_binop_done; } __pyx_t_10 = ((__pyx_v_endex < __pyx_v_block_endex) != 0); __pyx_t_5 = __pyx_t_10; __pyx_L11_bool_binop_done:; if (unlikely(__pyx_t_5)) { /* … */ }
+4215: raise ValueError('invalid block bounds')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__23, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 4215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 4215, __pyx_L1_error) /* … */ __pyx_tuple__23 = PyTuple_Pack(1, __pyx_kp_u_invalid_block_bounds); if (unlikely(!__pyx_tuple__23)) __PYX_ERR(0, 4215, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__23); __Pyx_GIVEREF(__pyx_tuple__23);
4216:
+4217: previous_endex = block_endex
__pyx_v_previous_endex = __pyx_v_block_endex; }
4218:
4219: else:
+4220: if endex < start:
/*else*/ { __pyx_t_5 = ((__pyx_v_endex < __pyx_v_start) != 0); if (unlikely(__pyx_t_5)) { /* … */ } } __pyx_L3:;
+4221: raise ValueError('invalid bounds')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__21, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 4221, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 4221, __pyx_L1_error)
4222:
4223:
+4224: cdef (addr_t, addr_t) Memory_Bound_(const Memory_* that, addr_t start, addr_t endex,
static __pyx_ctuple_addr_t__and_addr_t __pyx_f_11cbytesparse_1c_Memory_Bound_(Memory_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex, int __pyx_v_start_, int __pyx_v_endex_) { addr_t __pyx_v_trim_start; addr_t __pyx_v_trim_endex; __pyx_ctuple_addr_t__and_addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
4225: bint start_, bint endex_) nogil:
4226: cdef:
4227: addr_t trim_start
4228: addr_t trim_endex
4229:
+4230: trim_start = that.trim_start
__pyx_t_1 = __pyx_v_that->trim_start; __pyx_v_trim_start = __pyx_t_1;
+4231: trim_endex = that.trim_endex
__pyx_t_1 = __pyx_v_that->trim_endex; __pyx_v_trim_endex = __pyx_t_1;
4232:
+4233: if not start_:
__pyx_t_2 = ((!(__pyx_v_start_ != 0)) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+4234: if not that.trim_start_:
__pyx_t_2 = ((!(__pyx_v_that->trim_start_ != 0)) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+4235: if Rack_Length(that.blocks):
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L5; }
+4236: start = Block_Start(Rack_First__(that.blocks))
__pyx_v_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_f_11cbytesparse_1c_Rack_First__(__pyx_v_that->blocks));
4237: else:
+4238: start = 0
/*else*/ { __pyx_v_start = 0; } __pyx_L5:;
4239: else:
+4240: start = trim_start
/*else*/ { __pyx_v_start = __pyx_v_trim_start; } __pyx_L4:;
4241: else:
+4242: if that.trim_start_:
/*else*/ { __pyx_t_2 = (__pyx_v_that->trim_start_ != 0); if (__pyx_t_2) { /* … */ }
+4243: if start < trim_start:
__pyx_t_2 = ((__pyx_v_start < __pyx_v_trim_start) != 0); if (__pyx_t_2) { /* … */ }
+4244: start = trim_start
__pyx_v_start = __pyx_v_trim_start;
+4245: if endex_:
__pyx_t_2 = (__pyx_v_endex_ != 0); if (__pyx_t_2) { /* … */ } } __pyx_L3:;
+4246: if endex < start:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+4247: endex = start
__pyx_v_endex = __pyx_v_start;
4248:
+4249: if not endex_:
__pyx_t_2 = ((!(__pyx_v_endex_ != 0)) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L10; }
+4250: if not that.trim_endex_:
__pyx_t_2 = ((!(__pyx_v_that->trim_endex_ != 0)) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L11; }
+4251: if Rack_Length(that.blocks):
__pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); if (__pyx_t_2) { /* … */ goto __pyx_L12; }
+4252: endex = Block_Endex(Rack_Last__(that.blocks))
__pyx_v_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_that->blocks));
4253: else:
+4254: endex = start
/*else*/ { __pyx_v_endex = __pyx_v_start; } __pyx_L12:;
4255: else:
+4256: endex = trim_endex
/*else*/ { __pyx_v_endex = __pyx_v_trim_endex; } __pyx_L11:;
4257: else:
+4258: if that.trim_endex_:
/*else*/ { __pyx_t_2 = (__pyx_v_that->trim_endex_ != 0); if (__pyx_t_2) { /* … */ }
+4259: if endex > trim_endex:
__pyx_t_2 = ((__pyx_v_endex > __pyx_v_trim_endex) != 0); if (__pyx_t_2) { /* … */ }
+4260: endex = trim_endex
__pyx_v_endex = __pyx_v_trim_endex;
+4261: if start > endex:
__pyx_t_2 = ((__pyx_v_start > __pyx_v_endex) != 0); if (__pyx_t_2) { /* … */ } } __pyx_L10:;
+4262: start = endex
__pyx_v_start = __pyx_v_endex;
4263:
+4264: return start, endex
__pyx_t_3.f0 = __pyx_v_start; __pyx_t_3.f1 = __pyx_v_endex; __pyx_r = __pyx_t_3; goto __pyx_L0;
4265:
4266:
+4267: cdef (addr_t, addr_t) Memory_Bound(const Memory_* that, object start, object endex) except *:
static __pyx_ctuple_addr_t__and_addr_t __pyx_f_11cbytesparse_1c_Memory_Bound(Memory_ const *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { int __pyx_v_start__; int __pyx_v_endex__; addr_t __pyx_v_start_; addr_t __pyx_v_endex_; __pyx_ctuple_addr_t__and_addr_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Bound", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Bound", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_pretend_to_initialize(&__pyx_r); __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4268: cdef:
+4269: bint start__ = start is not None
__pyx_t_1 = (__pyx_v_start != Py_None); __pyx_v_start__ = __pyx_t_1;
+4270: bint endex__ = endex is not None
__pyx_t_1 = (__pyx_v_endex != Py_None); __pyx_v_endex__ = __pyx_t_1;
+4271: addr_t start_ = <addr_t>start if start__ else 0
if ((__pyx_v_start__ != 0)) { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4271, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_3); } else { __pyx_t_2 = 0; } __pyx_v_start_ = __pyx_t_2;
+4272: addr_t endex_ = <addr_t>endex if endex__ else start_
if ((__pyx_v_endex__ != 0)) { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4272, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_3); } else { __pyx_t_2 = __pyx_v_start_; } __pyx_v_endex_ = __pyx_t_2;
4273:
+4274: return Memory_Bound_(that, start_, endex_, start__, endex__)
__pyx_r = __pyx_f_11cbytesparse_1c_Memory_Bound_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_, __pyx_v_start__, __pyx_v_endex__); goto __pyx_L0;
4275:
4276:
+4277: cdef int Memory_Peek_(const Memory_* that, addr_t address) except -2:
static int __pyx_f_11cbytesparse_1c_Memory_Peek_(Memory_ const *__pyx_v_that, addr_t __pyx_v_address) { Rack_ const *__pyx_v_blocks; Py_ssize_t __pyx_v_block_index; Block_ const *__pyx_v_block; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Peek_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Peek_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -2; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4278: cdef:
+4279: const Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4280: ssize_t block_index
4281: const Block_* block
4282:
+4283: block_index = Rack_IndexAt(blocks, address)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_IndexAt(__pyx_v_blocks, __pyx_v_address); if (unlikely(__pyx_t_2 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4283, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_2;
+4284: if block_index < 0:
__pyx_t_3 = ((__pyx_v_block_index < 0) != 0); if (__pyx_t_3) { /* … */ }
+4285: return -1
__pyx_r = -1; goto __pyx_L0;
4286: else:
+4287: block = Rack_Get__(blocks, <size_t>block_index)
/*else*/ { __pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, ((size_t)__pyx_v_block_index));
+4288: return Block_Get__(block, address - Block_Start(block))
__pyx_r = __pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_block, (__pyx_v_address - __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block))); goto __pyx_L0; }
4289:
4290:
+4291: cdef object Memory_Peek(const Memory_* that, object address):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Peek(Memory_ const *__pyx_v_that, PyObject *__pyx_v_address) { int __pyx_v_value; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Peek", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory_Peek", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
4292: cdef:
4293: int value
4294:
+4295: value = Memory_Peek_(that, <addr_t>address)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4295, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Peek_(__pyx_v_that, ((addr_t)__pyx_t_1)); if (unlikely(__pyx_t_2 == ((int)-2))) __PYX_ERR(0, 4295, __pyx_L1_error) __pyx_v_value = __pyx_t_2;
+4296: return None if value < 0 else value
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_value < 0) != 0)) { __Pyx_INCREF(Py_None); __pyx_t_3 = Py_None; } else { __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_value); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 4296, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __pyx_t_4; __pyx_t_4 = 0; } __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
4297:
4298:
+4299: cdef vint Memory_PokeNone_(Memory_* that, addr_t address) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_PokeNone_(Memory_ *__pyx_v_that, addr_t __pyx_v_address) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PokeNone_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PokeNone_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4300: # Standard clear method
+4301: Memory_Erase__(that, address, address + 1, False) # clear
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_address, (__pyx_v_address + 1), 0); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4301, __pyx_L1_error)
4302:
4303:
+4304: cdef vint Memory_Poke_(Memory_* that, addr_t address, byte_t item) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Poke_(Memory_ *__pyx_v_that, addr_t __pyx_v_address, byte_t __pyx_v_item) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; Block_ *__pyx_v_block2; addr_t __pyx_v_block_start2; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Poke_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Poke_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4305: cdef:
+4306: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
+4307: size_t block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
4308: size_t block_index
4309: Block_* block
4310: addr_t block_start
4311: addr_t block_endex
4312: Block_* block2
4313: addr_t block_start2
4314:
+4315: block_index = Rack_IndexEndex(blocks, address) - 1
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_blocks, __pyx_v_address); if (unlikely(__pyx_t_2 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4315, __pyx_L1_error)
__pyx_v_block_index = (__pyx_t_2 - 1);
4316:
+4317: if block_index < block_count:
__pyx_t_3 = ((__pyx_v_block_index < __pyx_v_block_count) != 0); if (__pyx_t_3) { /* … */ }
+4318: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4319: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+4320: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
4321:
+4322: if block_start <= address < block_endex:
__pyx_t_3 = (__pyx_v_block_start <= __pyx_v_address); if (__pyx_t_3) { __pyx_t_3 = (__pyx_v_address < __pyx_v_block_endex); } __pyx_t_4 = (__pyx_t_3 != 0); if (__pyx_t_4) { /* … */ }
4323: # Address within existing block, update directly
+4324: address -= block_start
__pyx_v_address = (__pyx_v_address - __pyx_v_block_start);
+4325: Block_Set__(block, <size_t>address, item)
(void)(__pyx_f_11cbytesparse_1c_Block_Set__(__pyx_v_block, ((size_t)__pyx_v_address), __pyx_v_item));
+4326: return 0
__pyx_r = 0; goto __pyx_L0;
4327:
+4328: elif address == block_endex:
__pyx_t_4 = ((__pyx_v_address == __pyx_v_block_endex) != 0); if (__pyx_t_4) { /* … */ }
4329: # Address just after the end of the block, append
+4330: block = Block_Append(block, item)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_Append(__pyx_v_block, __pyx_v_item); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4330, __pyx_L1_error)
__pyx_v_block = __pyx_t_5;
+4331: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block));
4332:
+4333: block_index += 1
__pyx_v_block_index = (__pyx_v_block_index + 1);
+4334: if block_index < block_count:
__pyx_t_4 = ((__pyx_v_block_index < __pyx_v_block_count) != 0); if (__pyx_t_4) { /* … */ }
+4335: block2 = Rack_Get__(blocks, block_index)
__pyx_v_block2 = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4336: block_start2 = Block_Start(block2)
__pyx_v_block_start2 = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block2);
4337:
+4338: if block_endex + 1 == block_start2:
__pyx_t_4 = (((__pyx_v_block_endex + 1) == __pyx_v_block_start2) != 0); if (__pyx_t_4) { /* … */ }
4339: # Merge with the following contiguous block
+4340: block = Block_Extend(block, block2)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_Extend(__pyx_v_block, __pyx_v_block2); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4340, __pyx_L1_error)
__pyx_v_block = __pyx_t_5;
+4341: Rack_Set__(blocks, block_index - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_block_index - 1), __pyx_v_block));
+4342: that.blocks = blocks = Rack_Pop_(blocks, block_index, NULL)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Pop_(__pyx_v_blocks, __pyx_v_block_index, NULL); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4342, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_1;
__pyx_v_blocks = __pyx_t_1;
+4343: return 0
__pyx_r = 0; goto __pyx_L0;
4344:
4345: else:
+4346: block_index += 1
/*else*/ { __pyx_v_block_index = (__pyx_v_block_index + 1);
+4347: if block_index < block_count:
__pyx_t_4 = ((__pyx_v_block_index < __pyx_v_block_count) != 0); if (__pyx_t_4) { /* … */ } }
+4348: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4349: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
4350:
+4351: if address + 1 == block_start:
__pyx_t_4 = (((__pyx_v_address + 1) == __pyx_v_block_start) != 0); if (__pyx_t_4) { /* … */ }
4352: # Prepend to the next block
+4353: block = Block_AppendLeft(block, item)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_AppendLeft(__pyx_v_block, __pyx_v_item); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4353, __pyx_L1_error)
__pyx_v_block = __pyx_t_5;
+4354: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block));
+4355: block.address -= 1 # update address
__pyx_v_block->address = (__pyx_v_block->address - 1);
+4356: return 0
__pyx_r = 0; goto __pyx_L0;
4357:
4358: # There is no faster way than the standard block writing method
+4359: Memory_Erase__(that, address, address + 1, False) # clear
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_address, (__pyx_v_address + 1), 0); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4359, __pyx_L1_error)
+4360: Memory_Place__(that, address, 1, &item, False) # write
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Place__(__pyx_v_that, __pyx_v_address, 1, (&__pyx_v_item), 0); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4360, __pyx_L1_error)
4361:
+4362: Memory_Crop_(that, that.trim_start, that.trim_endex)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_that, __pyx_v_that->trim_start, __pyx_v_that->trim_endex); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4362, __pyx_L1_error)
+4363: return 0
__pyx_r = 0; goto __pyx_L0;
4364:
4365:
+4366: cdef vint Memory_Poke(Memory_* that, object address, object item) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Poke(Memory_ *__pyx_v_that, PyObject *__pyx_v_address, PyObject *__pyx_v_item) { addr_t __pyx_v_address_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Poke", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("cbytesparse.c.Memory_Poke", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4367: cdef:
+4368: addr_t address_ = <addr_t>address
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4368, __pyx_L1_error) __pyx_v_address_ = ((addr_t)__pyx_t_1);
4369:
+4370: if item is None:
__pyx_t_2 = (__pyx_v_item == Py_None); __pyx_t_3 = (__pyx_t_2 != 0); if (__pyx_t_3) { /* … */ goto __pyx_L3; }
+4371: Memory_PokeNone_(that, address_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PokeNone_(__pyx_v_that, __pyx_v_address_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4371, __pyx_L1_error)
4372: else:
+4373: if isinstance(item, int):
/*else*/ {
__pyx_t_3 = PyInt_Check(__pyx_v_item);
__pyx_t_2 = (__pyx_t_3 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L4;
}
+4374: Memory_Poke_(that, address_, <byte_t>item)
__pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4374, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Poke_(__pyx_v_that, __pyx_v_address_, ((byte_t)__pyx_t_5)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4374, __pyx_L1_error)
4375: else:
+4376: if len(item) != 1:
/*else*/ { __pyx_t_6 = PyObject_Length(__pyx_v_item); if (unlikely(__pyx_t_6 == ((Py_ssize_t)-1))) __PYX_ERR(0, 4376, __pyx_L1_error) __pyx_t_2 = ((__pyx_t_6 != 1) != 0); if (unlikely(__pyx_t_2)) { /* … */ }
+4377: raise ValueError('expecting single item')
__pyx_t_7 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 4377, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_Raise(__pyx_t_7, 0, 0, 0); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __PYX_ERR(0, 4377, __pyx_L1_error)
+4378: Memory_Poke_(that, address_, <byte_t>item[0])
__pyx_t_7 = __Pyx_GetItemInt(__pyx_v_item, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 4378, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_t_7); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4378, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Poke_(__pyx_v_that, __pyx_v_address_, ((byte_t)__pyx_t_5)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4378, __pyx_L1_error) } __pyx_L4:; } __pyx_L3:;
4379:
4380:
+4381: cdef Memory_* Memory_Extract__(const Memory_* that, addr_t start, addr_t endex,
static Memory_ *__pyx_f_11cbytesparse_1c_Memory_Extract__(Memory_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex, size_t __pyx_v_pattern_size, byte_t const *__pyx_v_pattern_ptr, saddr_t __pyx_v_step, int __pyx_v_bound) { Rack_ const *__pyx_v_blocks1; size_t __pyx_v_block_count; size_t __pyx_v_block_index; size_t __pyx_v_block_index_start; size_t __pyx_v_block_index_endex; Memory_ *__pyx_v_memory; Rack_ *__pyx_v_blocks2; Block_ *__pyx_v_block2; addr_t __pyx_v_offset; Block_ *__pyx_v_pattern; int __pyx_v_value; CYTHON_UNUSED saddr_t __pyx_v_skip; Rover_ *__pyx_v_rover; Block_ *__pyx_v_block1; Memory_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Extract__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_13); __Pyx_XDECREF(__pyx_t_14); __Pyx_XDECREF(__pyx_t_15); __Pyx_AddTraceback("cbytesparse.c.Memory_Extract__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4382: size_t pattern_size, const byte_t* pattern_ptr,
4383: saddr_t step, bint bound) except NULL:
4384: cdef:
+4385: const Rack_* blocks1 = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks1 = __pyx_t_1;
+4386: size_t block_count = Rack_Length(blocks1)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks1);
4387: size_t block_index
4388: size_t block_index_start
4389: size_t block_index_endex
+4390: Memory_* memory = Memory_Alloc()
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Alloc(); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL))) __PYX_ERR(0, 4390, __pyx_L1_error)
__pyx_v_memory = __pyx_t_2;
4391: Rack_* blocks2
4392: Block_* block2
4393: addr_t offset
+4394: Block_* pattern = NULL
__pyx_v_pattern = NULL;
4395: int value
4396: saddr_t skip
+4397: Rover_* rover = NULL
__pyx_v_rover = NULL;
4398:
+4399: if endex < start:
__pyx_t_3 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_3) { /* … */ }
+4400: endex = start
__pyx_v_endex = __pyx_v_start;
4401:
+4402: if step == 1:
__pyx_t_3 = ((__pyx_v_step == 1) != 0); if (__pyx_t_3) { /* … */ goto __pyx_L4; }
+4403: if start < endex and block_count:
__pyx_t_4 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_4) { } else { __pyx_t_3 = __pyx_t_4; goto __pyx_L6_bool_binop_done; } __pyx_t_4 = (__pyx_v_block_count != 0); __pyx_t_3 = __pyx_t_4; __pyx_L6_bool_binop_done:; if (__pyx_t_3) { /* … */ goto __pyx_L5; }
+4404: block_index_start = Rack_IndexStart(blocks1, start)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks1, __pyx_v_start); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4404, __pyx_L1_error)
__pyx_v_block_index_start = __pyx_t_5;
+4405: block_index_endex = Rack_IndexEndex(blocks1, endex)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_blocks1, __pyx_v_endex); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4405, __pyx_L1_error)
__pyx_v_block_index_endex = __pyx_t_5;
4406: else:
+4407: block_index_start = 0
/*else*/ { __pyx_v_block_index_start = 0;
+4408: block_index_endex = 0
__pyx_v_block_index_endex = 0; } __pyx_L5:;
4409:
4410: # Reserve slots to clone blocks
+4411: blocks2 = memory.blocks
__pyx_t_1 = __pyx_v_memory->blocks; __pyx_v_blocks2 = __pyx_t_1;
+4412: block_count = block_index_endex - block_index_start
__pyx_v_block_count = (__pyx_v_block_index_endex - __pyx_v_block_index_start);
+4413: memory.blocks = blocks2 = Rack_Reserve_(blocks2, 0, block_count)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Reserve_(__pyx_v_blocks2, 0, __pyx_v_block_count); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4413, __pyx_L1_error)
__pyx_v_memory->blocks = __pyx_t_1;
__pyx_v_blocks2 = __pyx_t_1;
+4414: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L13_try_end; __pyx_L8_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); goto __pyx_L1_error; __pyx_L13_try_end:; }
4415: # Clone blocks into the new memory
+4416: for block_index in range(block_count):
__pyx_t_9 = __pyx_v_block_count; __pyx_t_10 = __pyx_t_9; for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_10; __pyx_t_11+=1) { __pyx_v_block_index = __pyx_t_11;
+4417: block1 = Rack_Get__(blocks1, block_index_start + block_index)
__pyx_v_block1 = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks1, (__pyx_v_block_index_start + __pyx_v_block_index));
+4418: block2 = Block_Copy(block1)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Block_Copy(__pyx_v_block1); if (unlikely(__pyx_t_12 == ((Block_ *)NULL))) __PYX_ERR(0, 4418, __pyx_L8_error)
__pyx_v_block2 = __pyx_t_12;
+4419: Rack_Set__(blocks2, block_index, block2)
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks2, __pyx_v_block_index, __pyx_v_block2)); }
+4420: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Extract__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_13, &__pyx_t_14, &__pyx_t_15) < 0) __PYX_ERR(0, 4420, __pyx_L10_except_error) __Pyx_GOTREF(__pyx_t_13); __Pyx_GOTREF(__pyx_t_14); __Pyx_GOTREF(__pyx_t_15);
+4421: memory.blocks = blocks2 = Rack_Clear(blocks2) # orphan
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Clear(__pyx_v_blocks2); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4421, __pyx_L10_except_error)
__pyx_v_memory->blocks = __pyx_t_1;
__pyx_v_blocks2 = __pyx_t_1;
+4422: raise
__Pyx_GIVEREF(__pyx_t_13); __Pyx_GIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_ErrRestoreWithState(__pyx_t_13, __pyx_t_14, __pyx_t_15); __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __PYX_ERR(0, 4422, __pyx_L10_except_error) } __pyx_L10_except_error:;
4423:
4424: # Trim data in excess
+4425: Memory_Crop_(memory, start, endex)
__pyx_t_16 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_memory, __pyx_v_start, __pyx_v_endex); if (unlikely(__pyx_t_16 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4425, __pyx_L1_error)
4426:
+4427: if pattern_size and pattern_ptr:
__pyx_t_4 = (__pyx_v_pattern_size != 0); if (__pyx_t_4) { } else { __pyx_t_3 = __pyx_t_4; goto __pyx_L19_bool_binop_done; } __pyx_t_4 = (__pyx_v_pattern_ptr != 0); __pyx_t_3 = __pyx_t_4; __pyx_L19_bool_binop_done:; if (__pyx_t_3) { /* … */ }
+4428: pattern = Block_Create(0, pattern_size, pattern_ptr)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Block_Create(0, __pyx_v_pattern_size, __pyx_v_pattern_ptr); if (unlikely(__pyx_t_12 == ((Block_ *)NULL))) __PYX_ERR(0, 4428, __pyx_L1_error)
__pyx_v_pattern = __pyx_t_12;
+4429: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; goto __pyx_L26_try_end; __pyx_L21_error:; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_8); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_ExceptionReset(__pyx_t_8, __pyx_t_7, __pyx_t_6); goto __pyx_L1_error; __pyx_L26_try_end:; }
+4430: Memory_Flood_(memory, start, endex, &pattern)
__pyx_t_16 = __pyx_f_11cbytesparse_1c_Memory_Flood_(__pyx_v_memory, __pyx_v_start, __pyx_v_endex, (&__pyx_v_pattern)); if (unlikely(__pyx_t_16 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4430, __pyx_L21_error)
+4431: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Extract__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_15, &__pyx_t_14, &__pyx_t_13) < 0) __PYX_ERR(0, 4431, __pyx_L23_except_error) __Pyx_GOTREF(__pyx_t_15); __Pyx_GOTREF(__pyx_t_14); __Pyx_GOTREF(__pyx_t_13);
+4432: Block_Free(pattern) # orphan
(void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_pattern));
+4433: raise
__Pyx_GIVEREF(__pyx_t_15); __Pyx_GIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_13); __Pyx_ErrRestoreWithState(__pyx_t_15, __pyx_t_14, __pyx_t_13); __pyx_t_15 = 0; __pyx_t_14 = 0; __pyx_t_13 = 0; __PYX_ERR(0, 4433, __pyx_L23_except_error) } __pyx_L23_except_error:;
4434: else:
+4435: if step > 1:
/*else*/ { __pyx_t_3 = ((__pyx_v_step > 1) != 0); if (__pyx_t_3) { /* … */ } } __pyx_L4:;
+4436: block2 = NULL
__pyx_v_block2 = NULL;
+4437: offset = start
__pyx_v_offset = __pyx_v_start;
+4438: rover = Rover_Create(that, start, endex, pattern_size, pattern_ptr, True, False)
__pyx_t_17 = __pyx_f_11cbytesparse_1c_Rover_Create(__pyx_v_that, __pyx_v_start, __pyx_v_endex, __pyx_v_pattern_size, __pyx_v_pattern_ptr, 1, 0); if (unlikely(__pyx_t_17 == ((Rover_ *)NULL))) __PYX_ERR(0, 4438, __pyx_L1_error)
__pyx_v_rover = __pyx_t_17;
+4439: try:
/*try:*/ { { /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L38_try_end; __pyx_L33_error:; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); goto __pyx_L31_error; __pyx_L34_exception_handled:; __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); __pyx_L38_try_end:; } }
+4440: while True:
while (1) {
+4441: value = Rover_Next_(rover)
__pyx_t_18 = __pyx_f_11cbytesparse_1c_Rover_Next_(__pyx_v_rover); if (unlikely(__pyx_t_18 == ((int)-2))) __PYX_ERR(0, 4441, __pyx_L33_error)
__pyx_v_value = __pyx_t_18;
+4442: if value < 0:
__pyx_t_3 = ((__pyx_v_value < 0) != 0); if (__pyx_t_3) { /* … */ goto __pyx_L41; }
+4443: if block2:
__pyx_t_3 = (__pyx_v_block2 != 0); if (__pyx_t_3) { /* … */ }
+4444: memory.blocks = Rack_Append(memory.blocks, block2)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Append(__pyx_v_memory->blocks, __pyx_v_block2); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4444, __pyx_L33_error)
__pyx_v_memory->blocks = __pyx_t_1;
+4445: block2 = NULL
__pyx_v_block2 = NULL;
4446: else:
+4447: if not block2:
/*else*/ { __pyx_t_3 = ((!(__pyx_v_block2 != 0)) != 0); if (__pyx_t_3) { /* … */ }
+4448: block2 = Block_Alloc(offset, 0, False)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Block_Alloc(__pyx_v_offset, 0, 0); if (unlikely(__pyx_t_12 == ((Block_ *)NULL))) __PYX_ERR(0, 4448, __pyx_L33_error)
__pyx_v_block2 = __pyx_t_12;
+4449: block2 = Block_Append(block2, <byte_t>value)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Block_Append(__pyx_v_block2, ((byte_t)__pyx_v_value)); if (unlikely(__pyx_t_12 == ((Block_ *)NULL))) __PYX_ERR(0, 4449, __pyx_L33_error)
__pyx_v_block2 = __pyx_t_12;
}
__pyx_L41:;
4450:
+4451: offset += 1
__pyx_v_offset = (__pyx_v_offset + 1);
+4452: for skip in range(step - 1):
__pyx_t_19 = (__pyx_v_step - 1); __pyx_t_20 = __pyx_t_19; for (__pyx_t_21 = 0; __pyx_t_21 < __pyx_t_20; __pyx_t_21+=1) { __pyx_v_skip = __pyx_t_21;
+4453: Rover_Next_(rover)
__pyx_t_18 = __pyx_f_11cbytesparse_1c_Rover_Next_(__pyx_v_rover); if (unlikely(__pyx_t_18 == ((int)-2))) __PYX_ERR(0, 4453, __pyx_L33_error)
}
}
+4454: except StopIteration:
__pyx_t_18 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_StopIteration); if (__pyx_t_18) { __Pyx_AddTraceback("cbytesparse.c.Memory_Extract__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_13, &__pyx_t_14, &__pyx_t_15) < 0) __PYX_ERR(0, 4454, __pyx_L35_except_error) __Pyx_GOTREF(__pyx_t_13); __Pyx_GOTREF(__pyx_t_14); __Pyx_GOTREF(__pyx_t_15);
+4455: if block2:
__pyx_t_3 = (__pyx_v_block2 != 0); if (__pyx_t_3) { /* … */ } __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; goto __pyx_L34_exception_handled; } goto __pyx_L35_except_error; __pyx_L35_except_error:;
+4456: memory.blocks = Rack_Append(memory.blocks, block2)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Append(__pyx_v_memory->blocks, __pyx_v_block2); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4456, __pyx_L35_except_error)
__pyx_v_memory->blocks = __pyx_t_1;
+4457: block2 = NULL
__pyx_v_block2 = NULL;
4458: finally:
+4459: block2 = Block_Free(block2) # orphan
/*finally:*/ { /*normal exit:*/{ __pyx_v_block2 = __pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block2); /* … */ __pyx_v_block2 = __pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block2);
+4460: rover = Rover_Free(rover)
__pyx_t_17 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_v_rover); if (unlikely(__pyx_t_17 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4460, __pyx_L1_error) __pyx_v_rover = __pyx_t_17; goto __pyx_L32; } __pyx_L31_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_8 = 0; __pyx_t_7 = 0; __pyx_t_6 = 0; __pyx_t_24 = 0; __pyx_t_25 = 0; __pyx_t_26 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_24, &__pyx_t_25, &__pyx_t_26); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_8, &__pyx_t_7, &__pyx_t_6) < 0)) __Pyx_ErrFetch(&__pyx_t_8, &__pyx_t_7, &__pyx_t_6); __Pyx_XGOTREF(__pyx_t_8); __Pyx_XGOTREF(__pyx_t_7); __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_24); __Pyx_XGOTREF(__pyx_t_25); __Pyx_XGOTREF(__pyx_t_26); __pyx_t_18 = __pyx_lineno; __pyx_t_22 = __pyx_clineno; __pyx_t_23 = __pyx_filename; { /* … */ __pyx_t_17 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_v_rover); if (unlikely(__pyx_t_17 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4460, __pyx_L50_error) __pyx_v_rover = __pyx_t_17; } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_24); __Pyx_XGIVEREF(__pyx_t_25); __Pyx_XGIVEREF(__pyx_t_26); __Pyx_ExceptionReset(__pyx_t_24, __pyx_t_25, __pyx_t_26); } __Pyx_XGIVEREF(__pyx_t_8); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_ErrRestore(__pyx_t_8, __pyx_t_7, __pyx_t_6); __pyx_t_8 = 0; __pyx_t_7 = 0; __pyx_t_6 = 0; __pyx_t_24 = 0; __pyx_t_25 = 0; __pyx_t_26 = 0; __pyx_lineno = __pyx_t_18; __pyx_clineno = __pyx_t_22; __pyx_filename = __pyx_t_23; goto __pyx_L1_error; __pyx_L50_error:; if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_24); __Pyx_XGIVEREF(__pyx_t_25); __Pyx_XGIVEREF(__pyx_t_26); __Pyx_ExceptionReset(__pyx_t_24, __pyx_t_25, __pyx_t_26); } __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_24 = 0; __pyx_t_25 = 0; __pyx_t_26 = 0; goto __pyx_L1_error; } __pyx_L32:; }
4461:
+4462: if bound:
__pyx_t_3 = (__pyx_v_bound != 0); if (__pyx_t_3) { /* … */ }
+4463: endex = offset
__pyx_v_endex = __pyx_v_offset;
+4464: if bound:
__pyx_t_3 = (__pyx_v_bound != 0); if (__pyx_t_3) { /* … */ }
+4465: memory.trim_start_ = True
__pyx_v_memory->trim_start_ = 1;
+4466: memory.trim_endex_ = True
__pyx_v_memory->trim_endex_ = 1;
+4467: memory.trim_start = start
__pyx_v_memory->trim_start = __pyx_v_start;
+4468: memory.trim_endex = endex
__pyx_v_memory->trim_endex = __pyx_v_endex;
4469:
+4470: return memory
__pyx_r = __pyx_v_memory; goto __pyx_L0;
4471:
4472:
+4473: cdef object Memory_Extract_(const Memory_* that, addr_t start, addr_t endex,
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Extract_(Memory_ const *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex, size_t __pyx_v_pattern_size, byte_t const *__pyx_v_pattern_ptr, saddr_t __pyx_v_step, int __pyx_v_bound) { Memory_ *__pyx_v_memory_; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Extract_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory_Extract_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
4474: size_t pattern_size, const byte_t* pattern_ptr,
4475: saddr_t step, bint bound):
4476: cdef:
+4477: Memory_* memory_ = Memory_Extract__(that, start, endex, pattern_size, pattern_ptr, step, bound)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Extract__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, __pyx_v_pattern_size, __pyx_v_pattern_ptr, __pyx_v_step, __pyx_v_bound); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 4477, __pyx_L1_error)
__pyx_v_memory_ = __pyx_t_1;
4478:
+4479: return Memory_AsObject(memory_)
__Pyx_XDECREF(__pyx_r); __pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_AsObject(__pyx_v_memory_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 4479, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
4480:
4481:
+4482: cdef object Memory_Extract(const Memory_* that, object start, object endex,
static PyObject *__pyx_f_11cbytesparse_1c_Memory_Extract(Memory_ const *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern, PyObject *__pyx_v_step, int __pyx_v_bound) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; __Pyx_memviewslice __pyx_v_pattern_view = { 0, 0, { 0 }, { 0 }, { 0 } }; byte_t __pyx_v_pattern_value; size_t __pyx_v_pattern_size; byte_t const *__pyx_v_pattern_ptr; saddr_t __pyx_v_step_; int __pyx_v_bound_; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Extract", 0); /* … */ /* function exit code */ __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_6, 1); __Pyx_XDECREF(__pyx_t_11); __Pyx_AddTraceback("cbytesparse.c.Memory_Extract", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_pattern_view, 1); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
4483: object pattern, object step, bint bound):
4484: cdef:
4485: addr_t start_
4486: addr_t endex_
4487: const byte_t[:] pattern_view
4488: byte_t pattern_value
4489: size_t pattern_size
4490: const byte_t* pattern_ptr
+4491: saddr_t step_ = <saddr_t>1 if step is None else <saddr_t>step
__pyx_t_2 = (__pyx_v_step == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = ((saddr_t)1); } else { __pyx_t_3 = __Pyx_PyInt_As_int_fast64_t(__pyx_v_step); if (unlikely((__pyx_t_3 == ((saddr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4491, __pyx_L1_error) __pyx_t_1 = ((saddr_t)__pyx_t_3); } __pyx_v_step_ = __pyx_t_1;
+4492: bint bound_ = <bint>bound
__pyx_v_bound_ = (__pyx_v_bound != 0);
4493:
+4494: if pattern is None:
__pyx_t_2 = (__pyx_v_pattern == Py_None); __pyx_t_4 = (__pyx_t_2 != 0); if (__pyx_t_4) { /* … */ goto __pyx_L3; }
+4495: pattern_size = 0
__pyx_v_pattern_size = 0;
+4496: pattern_ptr = NULL
__pyx_v_pattern_ptr = NULL;
4497:
+4498: elif isinstance(pattern, int):
__pyx_t_4 = PyInt_Check(__pyx_v_pattern);
__pyx_t_2 = (__pyx_t_4 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L3;
}
+4499: pattern_value = <byte_t>pattern
__pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_v_pattern); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4499, __pyx_L1_error) __pyx_v_pattern_value = ((byte_t)__pyx_t_5);
+4500: pattern_size = 1
__pyx_v_pattern_size = 1;
+4501: pattern_ptr = &pattern_value
__pyx_v_pattern_ptr = (&__pyx_v_pattern_value);
4502:
4503: else:
+4504: pattern_view = pattern
/*else*/ { __pyx_t_6 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_pattern, 0); if (unlikely(!__pyx_t_6.memview)) __PYX_ERR(0, 4504, __pyx_L1_error) __pyx_v_pattern_view = __pyx_t_6; __pyx_t_6.memview = NULL; __pyx_t_6.data = NULL;
+4505: pattern_size = len(pattern_view)
__pyx_t_7 = __Pyx_MemoryView_Len(__pyx_v_pattern_view);
__pyx_v_pattern_size = __pyx_t_7;
4506: with cython.boundscheck(False):
+4507: pattern_ptr = &pattern_view[0]
__pyx_t_8 = 0; if (__pyx_t_8 < 0) __pyx_t_8 += __pyx_v_pattern_view.shape[0]; __pyx_v_pattern_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_pattern_view.data + __pyx_t_8 * __pyx_v_pattern_view.strides[0]) )))); } __pyx_L3:;
4508:
+4509: start_ = Memory_Start(that) if start is None else <addr_t>start
__pyx_t_2 = (__pyx_v_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_9 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_10 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_10 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4509, __pyx_L1_error) __pyx_t_9 = ((addr_t)__pyx_t_10); } __pyx_v_start_ = __pyx_t_9;
+4510: endex_ = Memory_Endex(that) if endex is None else <addr_t>endex
__pyx_t_2 = (__pyx_v_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_9 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); } else { __pyx_t_10 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_10 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4510, __pyx_L1_error) __pyx_t_9 = ((addr_t)__pyx_t_10); } __pyx_v_endex_ = __pyx_t_9;
4511:
+4512: return Memory_Extract_(that, start_, endex_, pattern_size, pattern_ptr, step_, bound_)
__Pyx_XDECREF(__pyx_r); __pyx_t_11 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_, __pyx_v_pattern_size, __pyx_v_pattern_ptr, __pyx_v_step_, __pyx_v_bound_); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 4512, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_11); __pyx_r = __pyx_t_11; __pyx_t_11 = 0; goto __pyx_L0;
4513:
4514:
+4515: cdef vint Memory_ShiftLeft_(Memory_* that, addr_t offset) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_ShiftLeft_(Memory_ *__pyx_v_that, addr_t __pyx_v_offset) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ *__pyx_v_block; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ShiftLeft_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_ShiftLeft_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4516: cdef:
+4517: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4518: size_t block_index
4519: Block_* block
4520:
+4521: if offset and Rack_Length(blocks):
__pyx_t_3 = (__pyx_v_offset != 0); if (__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L4_bool_binop_done; } __pyx_t_3 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); __pyx_t_2 = __pyx_t_3; __pyx_L4_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+4522: Memory_PretrimStart_(that, ADDR_MAX, offset)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PretrimStart_(__pyx_v_that, ADDR_MAX, __pyx_v_offset); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4522, __pyx_L1_error)
+4523: blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4524:
+4525: for block_index in range(Rack_Length(blocks)):
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_6 = __pyx_t_5; for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) { __pyx_v_block_index = __pyx_t_7;
+4526: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4527: block.address -= offset
__pyx_v_block->address = (__pyx_v_block->address - __pyx_v_offset); }
4528:
4529:
+4530: cdef vint Memory_ShiftRight_(Memory_* that, addr_t offset) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_ShiftRight_(Memory_ *__pyx_v_that, addr_t __pyx_v_offset) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ *__pyx_v_block; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ShiftRight_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_ShiftRight_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4531: cdef:
+4532: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4533: size_t block_index
4534: Block_* block
4535:
+4536: if offset and Rack_Length(blocks):
__pyx_t_3 = (__pyx_v_offset != 0); if (__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L4_bool_binop_done; } __pyx_t_3 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); __pyx_t_2 = __pyx_t_3; __pyx_L4_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+4537: Memory_PretrimEndex_(that, ADDR_MIN, offset)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PretrimEndex_(__pyx_v_that, ADDR_MIN, __pyx_v_offset); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4537, __pyx_L1_error)
+4538: blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4539:
+4540: for block_index in range(Rack_Length(blocks)):
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_6 = __pyx_t_5; for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) { __pyx_v_block_index = __pyx_t_7;
+4541: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4542: block.address += offset
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_offset); }
4543:
4544:
+4545: cdef vint Memory_Shift(Memory_* that, object offset) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Shift(Memory_ *__pyx_v_that, PyObject *__pyx_v_offset) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Shift", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory_Shift", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4546: if offset < 0:
__pyx_t_1 = PyObject_RichCompare(__pyx_v_offset, __pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 4546, __pyx_L1_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 4546, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_2) { /* … */ }
+4547: return Memory_ShiftLeft_(that, <addr_t>-offset)
__pyx_t_1 = PyNumber_Negative(__pyx_v_offset); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 4547, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_1); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4547, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_ShiftLeft_(__pyx_v_that, ((addr_t)__pyx_t_3)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4547, __pyx_L1_error) __pyx_r = __pyx_t_4; goto __pyx_L0;
4548: else:
+4549: return Memory_ShiftRight_(that, <addr_t>offset)
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4549, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_ShiftRight_(__pyx_v_that, ((addr_t)__pyx_t_3)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4549, __pyx_L1_error) __pyx_r = __pyx_t_4; goto __pyx_L0; }
4550:
4551:
+4552: cdef vint Memory_Reserve_(Memory_* that, addr_t address, addr_t size) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Reserve_(Memory_ *__pyx_v_that, addr_t __pyx_v_address, addr_t __pyx_v_size) { addr_t __pyx_v_offset; Rack_ *__pyx_v_blocks; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ *__pyx_v_block; addr_t __pyx_v_block_start; Block_ *__pyx_v_block2; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Reserve_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("cbytesparse.c.Memory_Reserve_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4553: cdef:
4554: addr_t offset
+4555: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4556: size_t block_count
4557: size_t block_index
4558: Block_* block
4559: addr_t block_start
4560: Block_* block2
4561:
+4562: if size and Rack_Length(blocks):
__pyx_t_3 = (__pyx_v_size != 0); if (__pyx_t_3) { } else { __pyx_t_2 = __pyx_t_3; goto __pyx_L4_bool_binop_done; } __pyx_t_3 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); __pyx_t_2 = __pyx_t_3; __pyx_L4_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+4563: Memory_PretrimEndex_(that, address, size)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PretrimEndex_(__pyx_v_that, __pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4563, __pyx_L1_error)
4564:
+4565: block_index = Rack_IndexStart(blocks, address)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_address); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4565, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_5;
+4566: block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
4567:
+4568: if block_index < block_count:
__pyx_t_2 = ((__pyx_v_block_index < __pyx_v_block_count) != 0); if (__pyx_t_2) { /* … */ }
+4569: block = Rack_Get_(blocks, block_index)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, __pyx_v_block_index); if (unlikely(__pyx_t_6 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4569, __pyx_L1_error) __pyx_v_block = __pyx_t_6;
+4570: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
4571:
+4572: if address > block_start:
__pyx_t_2 = ((__pyx_v_address > __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ }
4573: # Split into two blocks, reserving emptiness
+4574: CheckAddSizeU(block_count, 1) # ensure free slot
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddSizeU(__pyx_v_block_count, 1); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4574, __pyx_L1_error)
+4575: offset = address - block_start
__pyx_v_offset = (__pyx_v_address - __pyx_v_block_start);
+4576: block2 = Block_GetSlice_(block, offset, SIZE_HMAX)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Block_GetSlice_(__pyx_v_block, __pyx_v_offset, SIZE_HMAX); if (unlikely(__pyx_t_6 == ((Block_ *)NULL))) __PYX_ERR(0, 4576, __pyx_L1_error)
__pyx_v_block2 = __pyx_t_6;
+4577: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; goto __pyx_L13_try_end; __pyx_L8_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_XGIVEREF(__pyx_t_9); __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); goto __pyx_L1_error; __pyx_L13_try_end:; }
+4578: block = Block_DelSlice_(block, offset, SIZE_HMAX)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Block_DelSlice_(__pyx_v_block, __pyx_v_offset, SIZE_HMAX); if (unlikely(__pyx_t_6 == ((Block_ *)NULL))) __PYX_ERR(0, 4578, __pyx_L8_error)
__pyx_v_block = __pyx_t_6;
4579:
+4580: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block));
+4581: block_index += 1
__pyx_v_block_index = (__pyx_v_block_index + 1);
4582:
+4583: CheckAddAddrU(address, size)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4583, __pyx_L8_error)
+4584: block2.address = address + size
__pyx_v_block2->address = (__pyx_v_address + __pyx_v_size);
+4585: that.blocks = blocks = Rack_Insert(blocks, block_index, block2)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Insert(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block2); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4585, __pyx_L8_error)
__pyx_v_that->blocks = __pyx_t_1;
__pyx_v_blocks = __pyx_t_1;
+4586: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Reserve_", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12) < 0) __PYX_ERR(0, 4586, __pyx_L10_except_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11); __Pyx_GOTREF(__pyx_t_12);
+4587: block2 = Block_Free(block2) # orphan
__pyx_v_block2 = __pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block2);
+4588: raise
__Pyx_GIVEREF(__pyx_t_10); __Pyx_GIVEREF(__pyx_t_11); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_ErrRestoreWithState(__pyx_t_10, __pyx_t_11, __pyx_t_12); __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_t_12 = 0; __PYX_ERR(0, 4588, __pyx_L10_except_error) } __pyx_L10_except_error:;
+4589: block_index += 1
__pyx_v_block_index = (__pyx_v_block_index + 1);
4590:
+4591: for block_index in range(block_index, Rack_Length(blocks)):
__pyx_t_13 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_14 = __pyx_t_13; for (__pyx_t_15 = __pyx_v_block_index; __pyx_t_15 < __pyx_t_14; __pyx_t_15+=1) { __pyx_v_block_index = __pyx_t_15;
+4592: block = Rack_Get_(blocks, block_index)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, __pyx_v_block_index); if (unlikely(__pyx_t_6 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4592, __pyx_L1_error) __pyx_v_block = __pyx_t_6;
+4593: block.address += size
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_size); }
4594:
4595:
+4596: cdef vint Memory_Reserve(Memory_* that, object address, object size) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Reserve(Memory_ *__pyx_v_that, PyObject *__pyx_v_address, PyObject *__pyx_v_size) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Reserve", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Reserve", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4597: Memory_Reserve_(that, <addr_t>address, <addr_t>size)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4597, __pyx_L1_error) __pyx_t_2 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_2 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4597, __pyx_L1_error) __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Reserve_(__pyx_v_that, ((addr_t)__pyx_t_1), ((addr_t)__pyx_t_2)); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4597, __pyx_L1_error)
4598:
4599:
+4600: cdef vint Memory_Place__(Memory_* that, addr_t address, size_t size, const byte_t* buffer,
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Place__(Memory_ *__pyx_v_that, addr_t __pyx_v_address, size_t __pyx_v_size, byte_t const *__pyx_v_buffer, int __pyx_v_shift_after) { Rack_ *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; Block_ *__pyx_v_block2; addr_t __pyx_v_block_start2; size_t __pyx_v_offset; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Place__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_12); __Pyx_XDECREF(__pyx_t_13); __Pyx_XDECREF(__pyx_t_14); __Pyx_AddTraceback("cbytesparse.c.Memory_Place__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4601: bint shift_after) except -1:
4602: cdef:
4603: Rack_* blocks
4604: size_t block_index
4605: Block_* block
4606: addr_t block_start
4607: addr_t block_endex
4608: Block_* block2
4609: addr_t block_start2
4610: size_t offset
4611:
+4612: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+4613: blocks = that.blocks
__pyx_t_2 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_2;
+4614: block_index = Rack_IndexStart(blocks, address)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_address); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4614, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_3;
4615:
+4616: if block_index:
__pyx_t_1 = (__pyx_v_block_index != 0); if (__pyx_t_1) { /* … */ }
+4617: block = Rack_Get_(blocks, block_index - 1)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, (__pyx_v_block_index - 1)); if (unlikely(__pyx_t_4 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4617, __pyx_L1_error) __pyx_v_block = __pyx_t_4;
+4618: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+4619: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
4620:
+4621: if block_endex == address:
__pyx_t_1 = ((__pyx_v_block_endex == __pyx_v_address) != 0); if (__pyx_t_1) { /* … */ }
4622: # Extend previous block
+4623: block = Block_Extend_(block, size, buffer)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Extend_(__pyx_v_block, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4623, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4624: Rack_Set__(blocks, block_index - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_block_index - 1), __pyx_v_block));
4625:
4626: # Shift blocks after
+4627: if shift_after:
__pyx_t_1 = (__pyx_v_shift_after != 0); if (__pyx_t_1) { /* … */ goto __pyx_L6; }
+4628: for block_index in range(block_index, Rack_Length(blocks)):
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_6 = __pyx_t_5; for (__pyx_t_7 = __pyx_v_block_index; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) { __pyx_v_block_index = __pyx_t_7;
+4629: block = Rack_Get_(blocks, block_index)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, __pyx_v_block_index); if (unlikely(__pyx_t_4 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4629, __pyx_L1_error) __pyx_v_block = __pyx_t_4;
+4630: CheckAddAddrU(block.address, size)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_block->address, __pyx_v_size); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4630, __pyx_L1_error)
+4631: block.address += size
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_size); }
4632: else:
+4633: if block_index < Rack_Length(blocks):
/*else*/ { __pyx_t_1 = ((__pyx_v_block_index < __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks)) != 0); if (__pyx_t_1) { /* … */ } } __pyx_L6:;
+4634: CheckAddAddrU(block_endex, size)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_block_endex, __pyx_v_size); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4634, __pyx_L1_error)
+4635: block_endex += size
__pyx_v_block_endex = (__pyx_v_block_endex + __pyx_v_size);
4636:
+4637: block2 = Rack_Get_(blocks, block_index)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, __pyx_v_block_index); if (unlikely(__pyx_t_4 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4637, __pyx_L1_error) __pyx_v_block2 = __pyx_t_4;
+4638: block_start2 = Block_Start(block2)
__pyx_v_block_start2 = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block2);
4639:
4640: # Merge with next block
+4641: if block_endex == block_start2:
__pyx_t_1 = ((__pyx_v_block_endex == __pyx_v_block_start2) != 0); if (__pyx_t_1) { /* … */ }
+4642: block = Block_Extend(block, block2)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Extend(__pyx_v_block, __pyx_v_block2); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4642, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4643: Rack_Set__(blocks, block_index - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_block_index - 1), __pyx_v_block));
+4644: that.blocks = blocks = Rack_Pop_(blocks, block_index, NULL)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Pop_(__pyx_v_blocks, __pyx_v_block_index, NULL); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 4644, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_2;
__pyx_v_blocks = __pyx_t_2;
+4645: return 0
__pyx_r = 0; goto __pyx_L0;
4646:
+4647: if block_index < Rack_Length(blocks):
__pyx_t_1 = ((__pyx_v_block_index < __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks)) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L11; }
+4648: block = Rack_Get_(blocks, block_index)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, __pyx_v_block_index); if (unlikely(__pyx_t_4 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4648, __pyx_L1_error) __pyx_v_block = __pyx_t_4;
+4649: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
4650:
+4651: if address < block_start:
__pyx_t_1 = ((__pyx_v_address < __pyx_v_block_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L12; }
+4652: if shift_after:
__pyx_t_1 = (__pyx_v_shift_after != 0); if (__pyx_t_1) { /* … */ goto __pyx_L13; }
4653: # Insert a standalone block before
+4654: block = Block_Create(address, size, buffer)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Create(__pyx_v_address, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4654, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4655: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; goto __pyx_L19_try_end; __pyx_L14_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_9); __Pyx_XGIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_ExceptionReset(__pyx_t_9, __pyx_t_10, __pyx_t_11); goto __pyx_L1_error; __pyx_L19_try_end:; }
+4656: that.blocks = blocks = Rack_Insert(blocks, block_index, block)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Insert(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 4656, __pyx_L14_error)
__pyx_v_that->blocks = __pyx_t_2;
__pyx_v_blocks = __pyx_t_2;
+4657: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Place__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_12, &__pyx_t_13, &__pyx_t_14) < 0) __PYX_ERR(0, 4657, __pyx_L16_except_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_GOTREF(__pyx_t_13); __Pyx_GOTREF(__pyx_t_14);
+4658: Block_Free(block) # orphan
(void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block));
+4659: raise
__Pyx_GIVEREF(__pyx_t_12); __Pyx_GIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_14); __Pyx_ErrRestoreWithState(__pyx_t_12, __pyx_t_13, __pyx_t_14); __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __PYX_ERR(0, 4659, __pyx_L16_except_error) } __pyx_L16_except_error:;
4660: else:
+4661: CheckAddAddrU(address, size)
/*else*/ {
__pyx_t_8 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4661, __pyx_L1_error)
+4662: if address + size == block_start:
__pyx_t_1 = (((__pyx_v_address + __pyx_v_size) == __pyx_v_block_start) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L22; }
4663: # Merge with next block
+4664: block = Rack_Get_(blocks, block_index)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_blocks, __pyx_v_block_index); if (unlikely(__pyx_t_4 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 4664, __pyx_L1_error) __pyx_v_block = __pyx_t_4;
+4665: block.address = address
__pyx_v_block->address = __pyx_v_address;
+4666: block = Block_ExtendLeft_(block, size, buffer)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_ExtendLeft_(__pyx_v_block, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4666, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4667: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block));
4668: else:
4669: # Insert a standalone block before
+4670: block = Block_Create(address, size, buffer)
/*else*/ {
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Create(__pyx_v_address, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4670, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4671: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; goto __pyx_L28_try_end; __pyx_L23_error:; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_11); __Pyx_XGIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_9); __Pyx_ExceptionReset(__pyx_t_11, __pyx_t_10, __pyx_t_9); goto __pyx_L1_error; __pyx_L28_try_end:; } } __pyx_L22:; } __pyx_L13:;
+4672: that.blocks = blocks = Rack_Insert(blocks, block_index, block)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Insert(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 4672, __pyx_L23_error)
__pyx_v_that->blocks = __pyx_t_2;
__pyx_v_blocks = __pyx_t_2;
+4673: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Place__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_14, &__pyx_t_13, &__pyx_t_12) < 0) __PYX_ERR(0, 4673, __pyx_L25_except_error) __Pyx_GOTREF(__pyx_t_14); __Pyx_GOTREF(__pyx_t_13); __Pyx_GOTREF(__pyx_t_12);
+4674: Block_Free(block) # orphan
(void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block));
+4675: raise
__Pyx_GIVEREF(__pyx_t_14); __Pyx_GIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_ErrRestoreWithState(__pyx_t_14, __pyx_t_13, __pyx_t_12); __pyx_t_14 = 0; __pyx_t_13 = 0; __pyx_t_12 = 0; __PYX_ERR(0, 4675, __pyx_L25_except_error) } __pyx_L25_except_error:;
4676: else:
4677: # Insert buffer into the current block
+4678: CheckSubAddrU(address, block_start)
/*else*/ {
__pyx_t_8 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_address, __pyx_v_block_start); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4678, __pyx_L1_error)
+4679: CheckAddrToSizeU(address - block_start)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_address - __pyx_v_block_start)); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4679, __pyx_L1_error)
+4680: offset = <size_t>(address - block_start)
__pyx_v_offset = ((size_t)(__pyx_v_address - __pyx_v_block_start));
+4681: block = Block_Reserve_(block, offset, size, False)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Reserve_(__pyx_v_block, __pyx_v_offset, __pyx_v_size, 0); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4681, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4682: block = Block_Write_(block, offset, size, buffer)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Write_(__pyx_v_block, __pyx_v_offset, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4682, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4683: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block)); } __pyx_L12:;
4684:
4685: # Shift blocks after
+4686: if shift_after:
__pyx_t_1 = (__pyx_v_shift_after != 0); if (__pyx_t_1) { /* … */ }
+4687: for block_index in range(block_index + 1, Rack_Length(blocks)):
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_6 = __pyx_t_5; for (__pyx_t_7 = (__pyx_v_block_index + 1); __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) { __pyx_v_block_index = __pyx_t_7;
+4688: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4689: CheckAddAddrU(block.address, size)
__pyx_t_8 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_block->address, __pyx_v_size); if (unlikely(__pyx_t_8 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4689, __pyx_L1_error)
+4690: block.address += size
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_size); }
4691:
4692: else:
4693: # Append a standalone block after
+4694: block = Block_Create(address, size, buffer)
/*else*/ {
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_Create(__pyx_v_address, __pyx_v_size, __pyx_v_buffer); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 4694, __pyx_L1_error)
__pyx_v_block = __pyx_t_4;
+4695: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; goto __pyx_L39_try_end; __pyx_L34_error:; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_9); __Pyx_XGIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_ExceptionReset(__pyx_t_9, __pyx_t_10, __pyx_t_11); goto __pyx_L1_error; __pyx_L39_try_end:; } } __pyx_L11:;
+4696: that.blocks = blocks = Rack_Append(blocks, block)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Append(__pyx_v_blocks, __pyx_v_block); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 4696, __pyx_L34_error)
__pyx_v_that->blocks = __pyx_t_2;
__pyx_v_blocks = __pyx_t_2;
+4697: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Place__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_12, &__pyx_t_13, &__pyx_t_14) < 0) __PYX_ERR(0, 4697, __pyx_L36_except_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_GOTREF(__pyx_t_13); __Pyx_GOTREF(__pyx_t_14);
+4698: Block_Free(block) # orphan
(void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block));
+4699: raise
__Pyx_GIVEREF(__pyx_t_12); __Pyx_GIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_14); __Pyx_ErrRestoreWithState(__pyx_t_12, __pyx_t_13, __pyx_t_14); __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __PYX_ERR(0, 4699, __pyx_L36_except_error) } __pyx_L36_except_error:;
4700:
4701:
+4702: cdef vint Memory_Erase__(Memory_* that, addr_t start, addr_t endex, bint shift_after) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Erase__(Memory_ *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex, int __pyx_v_shift_after) { addr_t __pyx_v_size; addr_t __pyx_v_offset; Rack_ *__pyx_v_blocks; size_t __pyx_v_block_index; size_t __pyx_v_inner_start; size_t __pyx_v_inner_endex; Block_ *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; Block_ *__pyx_v_block2; addr_t __pyx_v_block_start2; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Erase__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_AddTraceback("cbytesparse.c.Memory_Erase__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4703: cdef:
4704: addr_t size
4705: addr_t offset
4706:
+4707: Rack_* blocks = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_1;
4708: size_t block_index
4709: size_t inner_start
4710: size_t inner_endex
4711:
+4712: Block_* block = NULL
__pyx_v_block = NULL;
4713: addr_t block_start
4714: addr_t block_endex
4715:
+4716: Block_* block2 = NULL
__pyx_v_block2 = NULL;
4717: addr_t block_start2
4718:
+4719: if endex > start:
__pyx_t_2 = ((__pyx_v_endex > __pyx_v_start) != 0); if (__pyx_t_2) { /* … */ }
+4720: size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
+4721: block_index = Rack_IndexStart(blocks, start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_start); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 4721, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_3;
4722:
4723: # Delete final/inner part of deletion start block
+4724: if block_index < Rack_Length(blocks):
__pyx_t_2 = ((__pyx_v_block_index < __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks)) != 0); if (__pyx_t_2) { /* … */ }
+4725: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4726: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+4727: if start > block_start:
__pyx_t_2 = ((__pyx_v_start > __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ }
+4728: if shift_after:
__pyx_t_2 = (__pyx_v_shift_after != 0); if (__pyx_t_2) { /* … */ goto __pyx_L6; }
+4729: CheckAddrToSizeU(start - block_start)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_start - __pyx_v_block_start)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4729, __pyx_L1_error)
+4730: CheckAddrToSizeU(endex - block_start)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_endex - __pyx_v_block_start)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4730, __pyx_L1_error)
+4731: block = Block_DelSlice_(block, start - block_start, endex - block_start)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_DelSlice_(__pyx_v_block, (__pyx_v_start - __pyx_v_block_start), (__pyx_v_endex - __pyx_v_block_start)); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4731, __pyx_L1_error)
__pyx_v_block = __pyx_t_5;
+4732: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block));
4733: else:
+4734: try:
/*else*/ { { /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L12_try_end; __pyx_L7_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); goto __pyx_L1_error; __pyx_L12_try_end:; } } __pyx_L6:;
+4735: CheckAddrToSizeU(start - block_start)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_start - __pyx_v_block_start)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4735, __pyx_L7_error)
+4736: block = Block_GetSlice_(block, 0, start - block_start)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_GetSlice_(__pyx_v_block, 0, (__pyx_v_start - __pyx_v_block_start)); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4736, __pyx_L7_error)
__pyx_v_block = __pyx_t_5;
+4737: block.address = block_start
__pyx_v_block->address = __pyx_v_block_start;
+4738: that.blocks = blocks = Rack_Insert_(blocks, block_index, block)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_Insert_(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4738, __pyx_L7_error)
__pyx_v_that->blocks = __pyx_t_1;
__pyx_v_blocks = __pyx_t_1;
+4739: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Erase__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_9, &__pyx_t_10, &__pyx_t_11) < 0) __PYX_ERR(0, 4739, __pyx_L9_except_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11);
+4740: block = Block_Free(block) # orphan
__pyx_v_block = __pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_block);
+4741: raise
__Pyx_GIVEREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_ErrRestoreWithState(__pyx_t_9, __pyx_t_10, __pyx_t_11); __pyx_t_9 = 0; __pyx_t_10 = 0; __pyx_t_11 = 0; __PYX_ERR(0, 4741, __pyx_L9_except_error) } __pyx_L9_except_error:;
+4742: block_index += 1 # skip this from inner part
__pyx_v_block_index = (__pyx_v_block_index + 1);
4743:
4744: # Delete initial part of deletion end block
+4745: inner_start = block_index
__pyx_v_inner_start = __pyx_v_block_index;
+4746: for block_index in range(block_index, Rack_Length(blocks)):
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_13 = __pyx_t_12; for (__pyx_t_14 = __pyx_v_block_index; __pyx_t_14 < __pyx_t_13; __pyx_t_14+=1) { __pyx_v_block_index = __pyx_t_14;
+4747: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
4748:
+4749: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+4750: if endex <= block_start:
__pyx_t_2 = ((__pyx_v_endex <= __pyx_v_block_start) != 0); if (__pyx_t_2) { /* … */ }
+4751: break # inner ends before here
goto __pyx_L16_break;
4752:
+4753: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+4754: if endex < block_endex:
__pyx_t_2 = ((__pyx_v_endex < __pyx_v_block_endex) != 0); if (__pyx_t_2) { /* … */ } } /*else*/ {
+4755: offset = endex - block_start
__pyx_v_offset = (__pyx_v_endex - __pyx_v_block_start);
+4756: CheckAddrToSizeU(offset)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4756, __pyx_L1_error)
+4757: CheckAddAddrU(block.address, offset)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_block->address, __pyx_v_offset); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4757, __pyx_L1_error)
+4758: block = Block_DelSlice_(block, 0, <size_t>offset)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_DelSlice_(__pyx_v_block, 0, ((size_t)__pyx_v_offset)); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4758, __pyx_L1_error)
__pyx_v_block = __pyx_t_5;
+4759: block.address += offset # update address
__pyx_v_block->address = (__pyx_v_block->address + __pyx_v_offset);
+4760: Rack_Set__(blocks, block_index, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, __pyx_v_block_index, __pyx_v_block));
+4761: break # inner ends before here
goto __pyx_L16_break;
4762: else:
+4763: block_index = Rack_Length(blocks)
__pyx_v_block_index = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); } __pyx_L16_break:;
+4764: inner_endex = block_index
__pyx_v_inner_endex = __pyx_v_block_index;
4765:
+4766: if shift_after:
__pyx_t_2 = (__pyx_v_shift_after != 0); if (__pyx_t_2) { /* … */ }
4767: # Check if inner deletion can be merged
+4768: if inner_start and inner_endex < Rack_Length(blocks):
__pyx_t_15 = (__pyx_v_inner_start != 0); if (__pyx_t_15) { } else { __pyx_t_2 = __pyx_t_15; goto __pyx_L21_bool_binop_done; } __pyx_t_15 = ((__pyx_v_inner_endex < __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks)) != 0); __pyx_t_2 = __pyx_t_15; __pyx_L21_bool_binop_done:; if (__pyx_t_2) { /* … */ }
+4769: block = Rack_Get__(blocks, inner_start - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_inner_start - 1));
+4770: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
4771:
+4772: block2 = Rack_Get__(blocks, inner_endex)
__pyx_v_block2 = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_inner_endex);
+4773: block_start2 = Block_Start(block2)
__pyx_v_block_start2 = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block2);
4774:
+4775: if block_endex + size == block_start2:
__pyx_t_2 = (((__pyx_v_block_endex + __pyx_v_size) == __pyx_v_block_start2) != 0); if (__pyx_t_2) { /* … */ }
+4776: block = Block_Extend(block, block2) # merge deletion boundaries
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_Extend(__pyx_v_block, __pyx_v_block2); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 4776, __pyx_L1_error)
__pyx_v_block = __pyx_t_5;
+4777: Rack_Set__(blocks, inner_start - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_inner_start - 1), __pyx_v_block));
+4778: inner_endex += 1 # add to inner deletion
__pyx_v_inner_endex = (__pyx_v_inner_endex + 1);
+4779: block_index += 1 # skip address update
__pyx_v_block_index = (__pyx_v_block_index + 1);
4780:
4781: # Shift blocks after deletion
+4782: for block_index in range(block_index, Rack_Length(blocks)):
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_13 = __pyx_t_12; for (__pyx_t_14 = __pyx_v_block_index; __pyx_t_14 < __pyx_t_13; __pyx_t_14+=1) { __pyx_v_block_index = __pyx_t_14;
+4783: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4784: CheckSubAddrU(block.address, size)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_block->address, __pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4784, __pyx_L1_error)
+4785: block.address -= size # update address
__pyx_v_block->address = (__pyx_v_block->address - __pyx_v_size); }
4786:
4787: # Delete inner full blocks
+4788: if inner_start < inner_endex:
__pyx_t_2 = ((__pyx_v_inner_start < __pyx_v_inner_endex) != 0); if (__pyx_t_2) { /* … */ }
+4789: that.blocks = blocks = Rack_DelSlice_(blocks, inner_start, inner_endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rack_DelSlice_(__pyx_v_blocks, __pyx_v_inner_start, __pyx_v_inner_endex); if (unlikely(__pyx_t_1 == ((Rack_ *)NULL))) __PYX_ERR(0, 4789, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_1;
__pyx_v_blocks = __pyx_t_1;
4790:
4791:
+4792: cdef vint Memory_InsertSame_(Memory_* that, addr_t address, Memory_* data) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_InsertSame_(Memory_ *__pyx_v_that, addr_t __pyx_v_address, Memory_ *__pyx_v_data) { addr_t __pyx_v_data_start; addr_t __pyx_v_data_endex; addr_t __pyx_v_data_size; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_InsertSame_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_InsertSame_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4793: cdef:
+4794: addr_t data_start = Memory_Start(data)
__pyx_v_data_start = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_data);
+4795: addr_t data_endex = Memory_Endex(data)
__pyx_v_data_endex = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_data);
+4796: addr_t data_size = data_endex - data_start
__pyx_v_data_size = (__pyx_v_data_endex - __pyx_v_data_start);
4797:
+4798: if data_size:
__pyx_t_1 = (__pyx_v_data_size != 0); if (__pyx_t_1) { /* … */ }
+4799: Memory_Reserve_(that, address, data_size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Reserve_(__pyx_v_that, __pyx_v_address, __pyx_v_data_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4799, __pyx_L1_error)
+4800: Memory_WriteSame_(that, address, data, True)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_that, __pyx_v_address, __pyx_v_data, 1); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4800, __pyx_L1_error)
4801:
4802:
+4803: cdef vint Memory_InsertRaw_(Memory_* that, addr_t address, size_t data_size, const byte_t* data_ptr) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_InsertRaw_(Memory_ *__pyx_v_that, addr_t __pyx_v_address, size_t __pyx_v_data_size, byte_t const *__pyx_v_data_ptr) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_InsertRaw_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_InsertRaw_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4804: if data_size:
__pyx_t_1 = (__pyx_v_data_size != 0); if (__pyx_t_1) { /* … */ }
+4805: Memory_Reserve_(that, address, data_size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Reserve_(__pyx_v_that, __pyx_v_address, __pyx_v_data_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4805, __pyx_L1_error)
+4806: Memory_WriteRaw_(that, address, data_size, data_ptr)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(__pyx_v_that, __pyx_v_address, __pyx_v_data_size, __pyx_v_data_ptr); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4806, __pyx_L1_error)
4807:
4808:
+4809: cdef vint Memory_Insert(Memory_* that, object address, object data) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Insert(Memory_ *__pyx_v_that, PyObject *__pyx_v_address, PyObject *__pyx_v_data) { addr_t __pyx_v_address_; __Pyx_memviewslice __pyx_v_data_view = { 0, 0, { 0 }, { 0 }, { 0 } }; byte_t __pyx_v_data_value; size_t __pyx_v_data_size; byte_t const *__pyx_v_data_ptr; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Insert", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_6, 1); __Pyx_AddTraceback("cbytesparse.c.Memory_Insert", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_data_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
4810: cdef:
+4811: addr_t address_ = <addr_t>address
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4811, __pyx_L1_error) __pyx_v_address_ = ((addr_t)__pyx_t_1);
4812: const byte_t[:] data_view
4813: byte_t data_value
4814: size_t data_size
4815: const byte_t* data_ptr
4816:
+4817: if isinstance(data, Memory):
__pyx_t_2 = __Pyx_TypeCheck(__pyx_v_data, __pyx_ptype_11cbytesparse_1c_Memory);
__pyx_t_3 = (__pyx_t_2 != 0);
if (__pyx_t_3) {
/* … */
goto __pyx_L3;
}
+4818: Memory_InsertSame_(that, address_, (<Memory>data)._)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_InsertSame_(__pyx_v_that, __pyx_v_address_, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_data)->_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4818, __pyx_L1_error)
4819:
4820: else:
+4821: if isinstance(data, int):
/*else*/ {
__pyx_t_3 = PyInt_Check(__pyx_v_data);
__pyx_t_2 = (__pyx_t_3 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L4;
}
+4822: data_value = <byte_t>data
__pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_v_data); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4822, __pyx_L1_error) __pyx_v_data_value = ((byte_t)__pyx_t_5);
+4823: data_size = 1
__pyx_v_data_size = 1;
+4824: data_ptr = &data_value
__pyx_v_data_ptr = (&__pyx_v_data_value);
4825: else:
+4826: data_view = data
/*else*/ { __pyx_t_6 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_data, 0); if (unlikely(!__pyx_t_6.memview)) __PYX_ERR(0, 4826, __pyx_L1_error) __pyx_v_data_view = __pyx_t_6; __pyx_t_6.memview = NULL; __pyx_t_6.data = NULL;
+4827: data_size = len(data_view)
__pyx_t_7 = __Pyx_MemoryView_Len(__pyx_v_data_view);
__pyx_v_data_size = __pyx_t_7;
4828: with cython.boundscheck(False):
+4829: data_ptr = &data_view[0]
__pyx_t_8 = 0; if (__pyx_t_8 < 0) __pyx_t_8 += __pyx_v_data_view.shape[0]; __pyx_v_data_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_data_view.data + __pyx_t_8 * __pyx_v_data_view.strides[0]) )))); } __pyx_L4:;
4830:
+4831: Memory_InsertRaw_(that, address_, data_size, data_ptr)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_InsertRaw_(__pyx_v_that, __pyx_v_address_, __pyx_v_data_size, __pyx_v_data_ptr); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4831, __pyx_L1_error)
}
__pyx_L3:;
4832:
4833:
+4834: cdef vint Memory_Delete_(Memory_* that, addr_t start, addr_t endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Delete_(Memory_ *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Delete_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Delete_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4835: if start < endex:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ }
+4836: Memory_Erase__(that, start, endex, True) # delete
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 1); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4836, __pyx_L1_error)
4837:
4838:
+4839: cdef vint Memory_Delete(Memory_* that, object start, object endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Delete(Memory_ *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Delete", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Delete", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4840: cdef:
+4841: addr_t start_ = Memory_Start(that) if start is None else <addr_t> start
__pyx_t_2 = (__pyx_v_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4841, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_start_ = __pyx_t_1;
+4842: addr_t endex_ = Memory_Endex(that) if endex is None else <addr_t> endex
__pyx_t_2 = (__pyx_v_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); } else { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4842, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_endex_ = __pyx_t_1;
4843:
+4844: Memory_Delete_(that, start_, endex_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Delete_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4844, __pyx_L1_error)
4845:
4846:
+4847: cdef vint Memory_Clear_(Memory_* that, addr_t start, addr_t endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Clear_(Memory_ *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Clear_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Clear_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+4848: if start < endex:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ }
+4849: Memory_Erase__(that, start, endex, False) # clear
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4849, __pyx_L1_error)
4850:
4851:
+4852: cdef vint Memory_Clear(Memory_* that, object start, object endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Clear(Memory_ *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Clear", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4853: cdef:
+4854: addr_t start_ = Memory_Start(that) if start is None else <addr_t> start
__pyx_t_2 = (__pyx_v_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4854, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_start_ = __pyx_t_1;
+4855: addr_t endex_ = Memory_Endex(that) if endex is None else <addr_t> endex
__pyx_t_2 = (__pyx_v_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_that); } else { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4855, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_endex_ = __pyx_t_1;
4856:
+4857: Memory_Clear_(that, start_, endex_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Clear_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4857, __pyx_L1_error)
4858:
4859:
+4860: cdef vint Memory_PretrimStart_(Memory_* that, addr_t endex_max, addr_t size) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_PretrimStart_(Memory_ *__pyx_v_that, addr_t __pyx_v_endex_max, addr_t __pyx_v_size) { addr_t __pyx_v_trim_start; addr_t __pyx_v_endex; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PretrimStart_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PretrimStart_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4861: cdef:
4862: addr_t trim_start
4863: addr_t endex
4864:
+4865: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+4866: trim_start = that.trim_start if that.trim_start_ else ADDR_MIN
if ((__pyx_v_that->trim_start_ != 0)) { __pyx_t_2 = __pyx_v_that->trim_start; } else { __pyx_t_2 = ADDR_MIN; } __pyx_v_trim_start = __pyx_t_2;
+4867: if CannotAddAddrU(trim_start, size):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotAddAddrU(__pyx_v_trim_start, __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+4868: endex = ADDR_MAX
__pyx_v_endex = ADDR_MAX;
4869: else:
+4870: endex = trim_start + size
/*else*/ { __pyx_v_endex = (__pyx_v_trim_start + __pyx_v_size); } __pyx_L4:;
4871:
+4872: if endex > endex_max:
__pyx_t_1 = ((__pyx_v_endex > __pyx_v_endex_max) != 0); if (__pyx_t_1) { /* … */ }
+4873: endex = endex_max
__pyx_v_endex = __pyx_v_endex_max;
4874:
+4875: Memory_Erase__(that, ADDR_MIN, endex, False) # clear
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, ADDR_MIN, __pyx_v_endex, 0); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4875, __pyx_L1_error)
4876:
4877:
+4878: cdef vint Memory_PretrimStart(Memory_* that, object endex_max, object size) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_PretrimStart(Memory_ *__pyx_v_that, PyObject *__pyx_v_endex_max, PyObject *__pyx_v_size) { addr_t __pyx_v_endex_max_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PretrimStart", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PretrimStart", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4879: cdef:
+4880: addr_t endex_max_ = ADDR_MAX if endex_max is None else <addr_t>endex_max
__pyx_t_2 = (__pyx_v_endex_max == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = ADDR_MAX; } else { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex_max); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4880, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_endex_max_ = __pyx_t_1;
4881:
+4882: Memory_PretrimStart_(that, endex_max_, <addr_t>size)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4882, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PretrimStart_(__pyx_v_that, __pyx_v_endex_max_, ((addr_t)__pyx_t_1)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4882, __pyx_L1_error)
4883:
4884:
+4885: cdef vint Memory_PretrimEndex_(Memory_* that, addr_t start_min, addr_t size) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_PretrimEndex_(Memory_ *__pyx_v_that, addr_t __pyx_v_start_min, addr_t __pyx_v_size) { addr_t __pyx_v_trim_endex; addr_t __pyx_v_start; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PretrimEndex_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PretrimEndex_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4886: cdef:
4887: addr_t trim_endex
4888: addr_t start
4889:
+4890: if size:
__pyx_t_1 = (__pyx_v_size != 0); if (__pyx_t_1) { /* … */ }
+4891: trim_endex = that.trim_endex if that.trim_endex_ else ADDR_MAX
if ((__pyx_v_that->trim_endex_ != 0)) { __pyx_t_2 = __pyx_v_that->trim_endex; } else { __pyx_t_2 = ADDR_MAX; } __pyx_v_trim_endex = __pyx_t_2;
+4892: if CannotSubAddrU(trim_endex, size):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_CannotSubAddrU(__pyx_v_trim_endex, __pyx_v_size) != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+4893: start = ADDR_MIN
__pyx_v_start = ADDR_MIN;
4894: else:
+4895: start = trim_endex - size
/*else*/ { __pyx_v_start = (__pyx_v_trim_endex - __pyx_v_size); } __pyx_L4:;
4896:
+4897: if start < start_min:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_start_min) != 0); if (__pyx_t_1) { /* … */ }
+4898: start = start_min
__pyx_v_start = __pyx_v_start_min;
4899:
+4900: Memory_Erase__(that, start, ADDR_MAX, False) # clear
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, ADDR_MAX, 0); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4900, __pyx_L1_error)
4901:
4902:
+4903: cdef vint Memory_PretrimEndex(Memory_* that, object start_min, object size) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_PretrimEndex(Memory_ *__pyx_v_that, PyObject *__pyx_v_start_min, PyObject *__pyx_v_size) { addr_t __pyx_v_start_min_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_PretrimEndex", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_PretrimEndex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4904: cdef:
+4905: addr_t start_min_ = ADDR_MIN if start_min is None else <addr_t>start_min
__pyx_t_2 = (__pyx_v_start_min == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_1 = ADDR_MIN; } else { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start_min); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4905, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_start_min_ = __pyx_t_1;
4906:
+4907: Memory_PretrimEndex_(that, start_min_, <addr_t>size)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 4907, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PretrimEndex_(__pyx_v_that, __pyx_v_start_min_, ((addr_t)__pyx_t_1)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4907, __pyx_L1_error)
4908:
4909:
+4910: cdef vint Memory_Crop_(Memory_* that, addr_t start, addr_t endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Crop_(Memory_ *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex) { addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Crop_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Crop_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4911: cdef:
4912: addr_t block_start
4913: addr_t block_endex
4914:
4915: # Trim blocks exceeding before memory start
+4916: if Rack_Length(that.blocks):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); if (__pyx_t_1) { /* … */ }
+4917: block_start = Block_Start(Rack_First_(that.blocks))
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_f_11cbytesparse_1c_Rack_First_(__pyx_v_that->blocks));
4918:
+4919: if block_start < start:
__pyx_t_1 = ((__pyx_v_block_start < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+4920: Memory_Erase__(that, block_start, start, False) # clear
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_block_start, __pyx_v_start, 0); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4920, __pyx_L1_error)
4921:
4922: # Trim blocks exceeding after memory end
+4923: if Rack_Length(that.blocks):
__pyx_t_1 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_that->blocks) != 0); if (__pyx_t_1) { /* … */ }
+4924: block_endex = Block_Endex(Rack_Last_(that.blocks))
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last_(__pyx_v_that->blocks));
4925:
+4926: if endex < block_endex:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_block_endex) != 0); if (__pyx_t_1) { /* … */ }
+4927: Memory_Erase__(that, endex, block_endex, False) # clear
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_endex, __pyx_v_block_endex, 0); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4927, __pyx_L1_error)
4928:
4929:
+4930: cdef vint Memory_Crop(Memory_* that, object start, object endex) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Crop(Memory_ *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Crop", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Crop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4931: cdef:
4932: addr_t start_
4933: addr_t endex_
4934:
+4935: start_, endex_ = Memory_Bound(that, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 4935, __pyx_L1_error)
__pyx_t_2 = __pyx_t_1.f0;
__pyx_t_3 = __pyx_t_1.f1;
__pyx_v_start_ = __pyx_t_2;
__pyx_v_endex_ = __pyx_t_3;
+4936: Memory_Crop_(that, start_, endex_)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Crop_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4936, __pyx_L1_error)
4937:
4938:
+4939: cdef vint Memory_WriteSame_(Memory_* that, addr_t address, const Memory_* data, bint clear) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_WriteSame_(Memory_ *__pyx_v_that, addr_t __pyx_v_address, Memory_ const *__pyx_v_data, int __pyx_v_clear) { addr_t __pyx_v_start; addr_t __pyx_v_endex; addr_t __pyx_v_size; addr_t __pyx_v_offset; addr_t __pyx_v_trim_start; addr_t __pyx_v_trim_endex; int __pyx_v_trim_start_; int __pyx_v_trim_endex_; Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; size_t __pyx_v_block_size; size_t __pyx_v_block_offset; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_WriteSame_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_WriteSame_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
4940: cdef:
+4941: addr_t start = Memory_Start(data)
__pyx_v_start = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_data);
+4942: addr_t endex = Memory_Endex(data)
__pyx_v_endex = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_data);
+4943: addr_t size = endex - start
__pyx_v_size = (__pyx_v_endex - __pyx_v_start);
4944: addr_t offset
4945:
4946: addr_t trim_start
4947: addr_t trim_endex
4948: bint trim_start_
4949: bint trim_endex_
4950:
4951: const Rack_* blocks
4952: size_t block_count
4953: size_t block_index
4954: const Block_* block
4955: addr_t block_start
4956: addr_t block_endex
4957: size_t block_size
4958: size_t block_offset
4959:
+4960: if not size:
__pyx_t_1 = ((!(__pyx_v_size != 0)) != 0); if (__pyx_t_1) { /* … */ }
+4961: return 0
__pyx_r = 0; goto __pyx_L0;
4962:
+4963: blocks = data.blocks
__pyx_t_2 = __pyx_v_data->blocks; __pyx_v_blocks = __pyx_t_2;
+4964: block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
+4965: if block_count:
__pyx_t_1 = (__pyx_v_block_count != 0); if (__pyx_t_1) { /* … */ }
+4966: CheckAddAddrU(Block_Endex(Rack_Last__(blocks)), address)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks)), __pyx_v_address); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4966, __pyx_L1_error)
4967:
+4968: CheckAddAddrU(endex, address)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_endex, __pyx_v_address); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4968, __pyx_L1_error)
+4969: endex += address
__pyx_v_endex = (__pyx_v_endex + __pyx_v_address);
+4970: trim_start_ = that.trim_start_
__pyx_t_1 = __pyx_v_that->trim_start_; __pyx_v_trim_start_ = __pyx_t_1;
+4971: trim_start = that.trim_start
__pyx_t_4 = __pyx_v_that->trim_start; __pyx_v_trim_start = __pyx_t_4;
4972:
+4973: if trim_start_ and endex <= trim_start:
__pyx_t_5 = (__pyx_v_trim_start_ != 0); if (__pyx_t_5) { } else { __pyx_t_1 = __pyx_t_5; goto __pyx_L6_bool_binop_done; } __pyx_t_5 = ((__pyx_v_endex <= __pyx_v_trim_start) != 0); __pyx_t_1 = __pyx_t_5; __pyx_L6_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+4974: return 0
__pyx_r = 0; goto __pyx_L0;
4975:
+4976: CheckAddAddrU(start, address)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_start, __pyx_v_address); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4976, __pyx_L1_error)
+4977: start += address
__pyx_v_start = (__pyx_v_start + __pyx_v_address);
+4978: trim_endex_ = that.trim_endex_
__pyx_t_1 = __pyx_v_that->trim_endex_; __pyx_v_trim_endex_ = __pyx_t_1;
+4979: trim_endex = that.trim_endex
__pyx_t_4 = __pyx_v_that->trim_endex; __pyx_v_trim_endex = __pyx_t_4;
4980:
+4981: if trim_endex_ and trim_endex <= start:
__pyx_t_5 = (__pyx_v_trim_endex_ != 0); if (__pyx_t_5) { } else { __pyx_t_1 = __pyx_t_5; goto __pyx_L9_bool_binop_done; } __pyx_t_5 = ((__pyx_v_trim_endex <= __pyx_v_start) != 0); __pyx_t_1 = __pyx_t_5; __pyx_L9_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+4982: return 0
__pyx_r = 0; goto __pyx_L0;
4983:
+4984: if clear:
__pyx_t_1 = (__pyx_v_clear != 0); if (__pyx_t_1) { /* … */ goto __pyx_L11; }
4985: # Clear anything between source data boundaries
+4986: Memory_Erase__(that, start, endex, False) # clear
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4986, __pyx_L1_error)
4987: else:
4988: # Clear only overwritten ranges
+4989: for block_index in range(block_count):
/*else*/ { __pyx_t_6 = __pyx_v_block_count; __pyx_t_7 = __pyx_t_6; for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) { __pyx_v_block_index = __pyx_t_8;
+4990: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+4991: block_start = Block_Start(block) + address
__pyx_v_block_start = (__pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block) + __pyx_v_address);
+4992: block_endex = Block_Endex(block) + address
__pyx_v_block_endex = (__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) + __pyx_v_address);
+4993: Memory_Erase__(that, block_start, block_endex, False) # clear
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_block_start, __pyx_v_block_endex, 0); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 4993, __pyx_L1_error)
}
}
__pyx_L11:;
4994:
+4995: for block_index in range(block_count):
__pyx_t_6 = __pyx_v_block_count; __pyx_t_7 = __pyx_t_6; for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) { __pyx_v_block_index = __pyx_t_8;
+4996: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
4997:
+4998: block_endex = Block_Endex(block) + address
__pyx_v_block_endex = (__pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block) + __pyx_v_address);
+4999: if trim_start_ and block_endex <= trim_start:
__pyx_t_5 = (__pyx_v_trim_start_ != 0); if (__pyx_t_5) { } else { __pyx_t_1 = __pyx_t_5; goto __pyx_L17_bool_binop_done; } __pyx_t_5 = ((__pyx_v_block_endex <= __pyx_v_trim_start) != 0); __pyx_t_1 = __pyx_t_5; __pyx_L17_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5000: continue
goto __pyx_L14_continue;
5001:
+5002: block_start = Block_Start(block) + address
__pyx_v_block_start = (__pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block) + __pyx_v_address);
+5003: if trim_endex_ and trim_endex <= block_start:
__pyx_t_5 = (__pyx_v_trim_endex_ != 0); if (__pyx_t_5) { } else { __pyx_t_1 = __pyx_t_5; goto __pyx_L20_bool_binop_done; } __pyx_t_5 = ((__pyx_v_trim_endex <= __pyx_v_block_start) != 0); __pyx_t_1 = __pyx_t_5; __pyx_L20_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5004: break
goto __pyx_L15_break;
5005:
+5006: block_size = block_endex - block_start
__pyx_v_block_size = (__pyx_v_block_endex - __pyx_v_block_start);
+5007: block_offset = 0
__pyx_v_block_offset = 0;
5008:
5009: # Trim before memory
+5010: if trim_start_ and block_start < trim_start:
__pyx_t_5 = (__pyx_v_trim_start_ != 0); if (__pyx_t_5) { } else { __pyx_t_1 = __pyx_t_5; goto __pyx_L23_bool_binop_done; } __pyx_t_5 = ((__pyx_v_block_start < __pyx_v_trim_start) != 0); __pyx_t_1 = __pyx_t_5; __pyx_L23_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5011: offset = trim_start - block_start
__pyx_v_offset = (__pyx_v_trim_start - __pyx_v_block_start);
+5012: block_size -= <size_t>offset
__pyx_v_block_size = (__pyx_v_block_size - ((size_t)__pyx_v_offset));
+5013: block_offset = <size_t>offset
__pyx_v_block_offset = ((size_t)__pyx_v_offset);
5014:
5015: # Trim after memory
+5016: if trim_endex_ and trim_endex < block_endex:
__pyx_t_5 = (__pyx_v_trim_endex_ != 0); if (__pyx_t_5) { } else { __pyx_t_1 = __pyx_t_5; goto __pyx_L26_bool_binop_done; } __pyx_t_5 = ((__pyx_v_trim_endex < __pyx_v_block_endex) != 0); __pyx_t_1 = __pyx_t_5; __pyx_L26_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5017: offset = block_endex - trim_endex
__pyx_v_offset = (__pyx_v_block_endex - __pyx_v_trim_endex);
+5018: block_size -= <size_t>offset
__pyx_v_block_size = (__pyx_v_block_size - ((size_t)__pyx_v_offset));
5019:
+5020: Memory_Place__(that, block_start, block_size, Block_At__(block, block_offset), False) # write
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Place__(__pyx_v_that, __pyx_v_block_start, __pyx_v_block_size, __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, __pyx_v_block_offset), 0); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5020, __pyx_L1_error)
__pyx_L14_continue:;
}
__pyx_L15_break:;
5021:
5022:
+5023: cdef vint Memory_WriteRaw_(Memory_* that, addr_t address, size_t data_size, const byte_t* data_ptr) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(Memory_ *__pyx_v_that, addr_t __pyx_v_address, size_t __pyx_v_data_size, byte_t const *__pyx_v_data_ptr) { addr_t __pyx_v_size; addr_t __pyx_v_start; addr_t __pyx_v_endex; addr_t __pyx_v_offset; addr_t __pyx_v_trim_start; addr_t __pyx_v_trim_endex; int __pyx_v_trim_start_; int __pyx_v_trim_endex_; Rack_ *__pyx_v_blocks; size_t __pyx_v_block_count; Block_ *__pyx_v_block; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_WriteRaw_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory_WriteRaw_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5024: cdef:
+5025: addr_t size = data_size
__pyx_v_size = __pyx_v_data_size;
5026: addr_t start
5027: addr_t endex
5028: addr_t offset
5029:
5030: addr_t trim_start
5031: addr_t trim_endex
5032: bint trim_start_
5033: bint trim_endex_
5034:
5035: Rack_* blocks
5036: size_t block_count
5037: Block_* block
5038:
+5039: if not size:
__pyx_t_1 = ((!(__pyx_v_size != 0)) != 0); if (__pyx_t_1) { /* … */ }
+5040: return 0
__pyx_r = 0; goto __pyx_L0;
+5041: elif size == 1:
__pyx_t_1 = ((__pyx_v_size == 1) != 0); if (__pyx_t_1) { /* … */ }
+5042: Memory_Poke(that, address, data_ptr[0]) # faster
__pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5042, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_PyInt_From_byte_t((__pyx_v_data_ptr[0])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 5042, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Poke(__pyx_v_that, __pyx_t_2, __pyx_t_3); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5042, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+5043: return 0
__pyx_r = 0; goto __pyx_L0;
5044:
+5045: CheckAddAddrU(address, size)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5045, __pyx_L1_error)
+5046: start = address
__pyx_v_start = __pyx_v_address;
+5047: endex = start + size
__pyx_v_endex = (__pyx_v_start + __pyx_v_size);
5048:
+5049: trim_start_ = that.trim_start_
__pyx_t_1 = __pyx_v_that->trim_start_; __pyx_v_trim_start_ = __pyx_t_1;
+5050: trim_start = that.trim_start
__pyx_t_5 = __pyx_v_that->trim_start; __pyx_v_trim_start = __pyx_t_5;
+5051: if trim_start_ and endex <= trim_start:
__pyx_t_6 = (__pyx_v_trim_start_ != 0); if (__pyx_t_6) { } else { __pyx_t_1 = __pyx_t_6; goto __pyx_L5_bool_binop_done; } __pyx_t_6 = ((__pyx_v_endex <= __pyx_v_trim_start) != 0); __pyx_t_1 = __pyx_t_6; __pyx_L5_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5052: return 0
__pyx_r = 0; goto __pyx_L0;
5053:
+5054: trim_endex_ = that.trim_endex_
__pyx_t_1 = __pyx_v_that->trim_endex_; __pyx_v_trim_endex_ = __pyx_t_1;
+5055: trim_endex = that.trim_endex
__pyx_t_5 = __pyx_v_that->trim_endex; __pyx_v_trim_endex = __pyx_t_5;
+5056: if trim_endex_ and trim_endex <= start:
__pyx_t_6 = (__pyx_v_trim_endex_ != 0); if (__pyx_t_6) { } else { __pyx_t_1 = __pyx_t_6; goto __pyx_L8_bool_binop_done; } __pyx_t_6 = ((__pyx_v_trim_endex <= __pyx_v_start) != 0); __pyx_t_1 = __pyx_t_6; __pyx_L8_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5057: return 0
__pyx_r = 0; goto __pyx_L0;
5058:
5059: # Trim before memory
+5060: if trim_start_ and start < trim_start:
__pyx_t_6 = (__pyx_v_trim_start_ != 0); if (__pyx_t_6) { } else { __pyx_t_1 = __pyx_t_6; goto __pyx_L11_bool_binop_done; } __pyx_t_6 = ((__pyx_v_start < __pyx_v_trim_start) != 0); __pyx_t_1 = __pyx_t_6; __pyx_L11_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5061: offset = trim_start - start
__pyx_v_offset = (__pyx_v_trim_start - __pyx_v_start);
+5062: CheckAddrToSizeU(offset)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5062, __pyx_L1_error)
+5063: start += offset
__pyx_v_start = (__pyx_v_start + __pyx_v_offset);
+5064: size -= <size_t>offset
__pyx_v_size = (__pyx_v_size - ((size_t)__pyx_v_offset));
+5065: data_ptr += <size_t>offset
__pyx_v_data_ptr = (__pyx_v_data_ptr + ((size_t)__pyx_v_offset));
5066:
5067: # Trim after memory
+5068: if trim_endex_ and trim_endex < endex:
__pyx_t_6 = (__pyx_v_trim_endex_ != 0); if (__pyx_t_6) { } else { __pyx_t_1 = __pyx_t_6; goto __pyx_L14_bool_binop_done; } __pyx_t_6 = ((__pyx_v_trim_endex < __pyx_v_endex) != 0); __pyx_t_1 = __pyx_t_6; __pyx_L14_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5069: offset = endex - trim_endex
__pyx_v_offset = (__pyx_v_endex - __pyx_v_trim_endex);
+5070: CheckAddrToSizeU(offset)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5070, __pyx_L1_error)
+5071: endex -= offset
__pyx_v_endex = (__pyx_v_endex - __pyx_v_offset);
+5072: size -= <size_t>offset
__pyx_v_size = (__pyx_v_size - ((size_t)__pyx_v_offset));
5073:
5074: # Check if extending the actual content
+5075: CheckAddrToSizeU(size)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5075, __pyx_L1_error)
+5076: blocks = that.blocks
__pyx_t_7 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_7;
+5077: block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
+5078: if block_count:
__pyx_t_1 = (__pyx_v_block_count != 0); if (__pyx_t_1) { /* … */ }
+5079: block = Rack_Last__(blocks)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks);
+5080: if start == Block_Endex(block):
__pyx_t_1 = ((__pyx_v_start == __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block)) != 0); if (__pyx_t_1) { /* … */ }
+5081: block = Block_Extend_(block, <size_t>size, data_ptr) # might be faster
__pyx_t_8 = __pyx_f_11cbytesparse_1c_Block_Extend_(__pyx_v_block, ((size_t)__pyx_v_size), __pyx_v_data_ptr); if (unlikely(__pyx_t_8 == ((Block_ *)NULL))) __PYX_ERR(0, 5081, __pyx_L1_error)
__pyx_v_block = __pyx_t_8;
+5082: Rack_Set__(blocks, block_count - 1, block) # update pointer
(void)(__pyx_f_11cbytesparse_1c_Rack_Set__(__pyx_v_blocks, (__pyx_v_block_count - 1), __pyx_v_block));
+5083: return 0
__pyx_r = 0; goto __pyx_L0;
5084:
5085: # Standard write method
+5086: Memory_Erase__(that, start, endex, False) # clear
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5086, __pyx_L1_error)
+5087: Memory_Place__(that, start, <size_t>size, data_ptr, False) # write
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Place__(__pyx_v_that, __pyx_v_start, ((size_t)__pyx_v_size), __pyx_v_data_ptr, 0); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5087, __pyx_L1_error)
+5088: return 0
__pyx_r = 0; goto __pyx_L0;
5089:
5090:
+5091: cdef vint Memory_Write(Memory_* that, object address, object data, bint clear) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Write(Memory_ *__pyx_v_that, PyObject *__pyx_v_address, PyObject *__pyx_v_data, int __pyx_v_clear) { addr_t __pyx_v_address_; __Pyx_memviewslice __pyx_v_data_view = { 0, 0, { 0 }, { 0 }, { 0 } }; byte_t __pyx_v_data_value; size_t __pyx_v_data_size; byte_t const *__pyx_v_data_ptr; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Write", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_6, 1); __Pyx_AddTraceback("cbytesparse.c.Memory_Write", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_data_view, 1); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5092: cdef:
+5093: addr_t address_ = <addr_t>address
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 5093, __pyx_L1_error) __pyx_v_address_ = ((addr_t)__pyx_t_1);
5094: const byte_t[:] data_view
5095: byte_t data_value
5096: size_t data_size
5097: const byte_t* data_ptr
5098:
+5099: if isinstance(data, Memory):
__pyx_t_2 = __Pyx_TypeCheck(__pyx_v_data, __pyx_ptype_11cbytesparse_1c_Memory);
__pyx_t_3 = (__pyx_t_2 != 0);
if (__pyx_t_3) {
/* … */
goto __pyx_L3;
}
+5100: Memory_WriteSame_(that, address_, (<Memory>data)._, <bint>clear)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_that, __pyx_v_address_, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_data)->_, (__pyx_v_clear != 0)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5100, __pyx_L1_error)
5101:
5102: else:
+5103: if isinstance(data, int):
/*else*/ {
__pyx_t_3 = PyInt_Check(__pyx_v_data);
__pyx_t_2 = (__pyx_t_3 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L4;
}
+5104: data_value = <byte_t>data
__pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_v_data); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 5104, __pyx_L1_error) __pyx_v_data_value = ((byte_t)__pyx_t_5);
+5105: data_size = 1
__pyx_v_data_size = 1;
+5106: data_ptr = &data_value
__pyx_v_data_ptr = (&__pyx_v_data_value);
5107: else:
+5108: data_view = data
/*else*/ { __pyx_t_6 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_data, 0); if (unlikely(!__pyx_t_6.memview)) __PYX_ERR(0, 5108, __pyx_L1_error) __pyx_v_data_view = __pyx_t_6; __pyx_t_6.memview = NULL; __pyx_t_6.data = NULL;
+5109: data_size = len(data_view)
__pyx_t_7 = __Pyx_MemoryView_Len(__pyx_v_data_view);
__pyx_v_data_size = __pyx_t_7;
5110: with cython.boundscheck(False):
+5111: data_ptr = &data_view[0]
__pyx_t_8 = 0; if (__pyx_t_8 < 0) __pyx_t_8 += __pyx_v_data_view.shape[0]; __pyx_v_data_ptr = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_v_data_view.data + __pyx_t_8 * __pyx_v_data_view.strides[0]) )))); } __pyx_L4:;
5112:
+5113: Memory_WriteRaw_(that, address_, data_size, data_ptr)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_WriteRaw_(__pyx_v_that, __pyx_v_address_, __pyx_v_data_size, __pyx_v_data_ptr); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5113, __pyx_L1_error)
}
__pyx_L3:;
5114:
5115:
+5116: cdef vint Memory_Fill_(Memory_* that, addr_t start, addr_t endex, Block_** pattern, addr_t start_) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Fill_(Memory_ *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex, Block_ **__pyx_v_pattern, addr_t __pyx_v_start_) { size_t __pyx_v_offset; size_t __pyx_v_size; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Fill_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory_Fill_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5117: cdef:
5118: size_t offset
5119: size_t size
5120:
+5121: if start < endex:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ }
+5122: CheckAddrToSizeU(endex - start)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_endex - __pyx_v_start)); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5122, __pyx_L1_error)
+5123: if not Block_Length(pattern[0]):
__pyx_t_1 = ((!(__pyx_f_11cbytesparse_1c_Block_Length((__pyx_v_pattern[0])) != 0)) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+5124: raise ValueError('non-empty pattern required')
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__24, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 5124, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __PYX_ERR(0, 5124, __pyx_L1_error) /* … */ __pyx_tuple__24 = PyTuple_Pack(1, __pyx_kp_u_non_empty_pattern_required); if (unlikely(!__pyx_tuple__24)) __PYX_ERR(0, 5124, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__24); __Pyx_GIVEREF(__pyx_tuple__24);
5125:
+5126: if start > start_:
__pyx_t_1 = ((__pyx_v_start > __pyx_v_start_) != 0); if (__pyx_t_1) { /* … */ }
+5127: offset = start - start_
__pyx_v_offset = (__pyx_v_start - __pyx_v_start_);
+5128: CheckAddrToSizeU(offset)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5128, __pyx_L1_error)
+5129: Block_RotateLeft_(pattern[0], <size_t>offset)
__pyx_f_11cbytesparse_1c_Block_RotateLeft_((__pyx_v_pattern[0]), ((size_t)__pyx_v_offset));
5130:
5131: # Resize the pattern to the target range
+5132: size = <size_t>(endex - start)
__pyx_v_size = ((size_t)(__pyx_v_endex - __pyx_v_start));
+5133: pattern[0] = Block_RepeatToSize(pattern[0], size)
__pyx_t_4 = __pyx_f_11cbytesparse_1c_Block_RepeatToSize((__pyx_v_pattern[0]), __pyx_v_size); if (unlikely(__pyx_t_4 == ((Block_ *)NULL))) __PYX_ERR(0, 5133, __pyx_L1_error)
(__pyx_v_pattern[0]) = __pyx_t_4;
5134:
5135: # Standard write method
+5136: Memory_Erase__(that, start, endex, False) # clear
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Erase__(__pyx_v_that, __pyx_v_start, __pyx_v_endex, 0); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5136, __pyx_L1_error)
+5137: Memory_Place__(that, start, size, Block_At__(pattern[0], 0), False) # write
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Place__(__pyx_v_that, __pyx_v_start, __pyx_v_size, __pyx_f_11cbytesparse_1c_Block_At__((__pyx_v_pattern[0]), 0), 0); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5137, __pyx_L1_error)
5138:
5139:
+5140: cdef vint Memory_Fill(Memory_* that, object start, object endex, object pattern) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Fill(Memory_ *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { addr_t __pyx_v_start__; addr_t __pyx_v_start_; addr_t __pyx_v_endex_; Block_ *__pyx_v_pattern_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Fill", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory_Fill", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5141: cdef:
5142: addr_t start__
5143: addr_t start_
5144: addr_t endex_
+5145: Block_* pattern_ = NULL
__pyx_v_pattern_ = NULL;
5146:
+5147: start_, endex_ = Memory_Bound(that, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 5147, __pyx_L1_error)
__pyx_t_2 = __pyx_t_1.f0;
__pyx_t_3 = __pyx_t_1.f1;
__pyx_v_start_ = __pyx_t_2;
__pyx_v_endex_ = __pyx_t_3;
+5148: if start_ < endex_:
__pyx_t_4 = ((__pyx_v_start_ < __pyx_v_endex_) != 0); if (__pyx_t_4) { /* … */ }
+5149: pattern_ = Block_FromObject(0, pattern, False) # size checked later on
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_FromObject(0, __pyx_v_pattern, 0); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 5149, __pyx_L1_error)
__pyx_v_pattern_ = __pyx_t_5;
+5150: try:
/*try:*/ {
+5151: start__ = Memory_Start(that) if start is None else <addr_t>start
__pyx_t_4 = (__pyx_v_start == Py_None); if ((__pyx_t_4 != 0)) { __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_that); } else { __pyx_t_2 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_2 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 5151, __pyx_L5_error) __pyx_t_3 = ((addr_t)__pyx_t_2); } __pyx_v_start__ = __pyx_t_3;
+5152: Memory_Fill_(that, start_, endex_, &pattern_, start__)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Fill_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_, (&__pyx_v_pattern_), __pyx_v_start__); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5152, __pyx_L5_error)
}
5153: finally:
+5154: Block_Free(pattern_) # orphan
/*finally:*/ { /*normal exit:*/{ (void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_pattern_)); goto __pyx_L6; } __pyx_L5_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_13, &__pyx_t_14, &__pyx_t_15); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12) < 0)) __Pyx_ErrFetch(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12); __Pyx_XGOTREF(__pyx_t_10); __Pyx_XGOTREF(__pyx_t_11); __Pyx_XGOTREF(__pyx_t_12); __Pyx_XGOTREF(__pyx_t_13); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_15); __pyx_t_7 = __pyx_lineno; __pyx_t_8 = __pyx_clineno; __pyx_t_9 = __pyx_filename; { (void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_pattern_)); } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_ExceptionReset(__pyx_t_13, __pyx_t_14, __pyx_t_15); } __Pyx_XGIVEREF(__pyx_t_10); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_ErrRestore(__pyx_t_10, __pyx_t_11, __pyx_t_12); __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_t_12 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_lineno = __pyx_t_7; __pyx_clineno = __pyx_t_8; __pyx_filename = __pyx_t_9; goto __pyx_L1_error; } __pyx_L6:; }
5155:
5156:
+5157: cdef vint Memory_Flood_(Memory_* that, addr_t start, addr_t endex, Block_** pattern) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Flood_(Memory_ *__pyx_v_that, addr_t __pyx_v_start, addr_t __pyx_v_endex, Block_ **__pyx_v_pattern) { Rack_ *__pyx_v_blocks; Block_ const *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; size_t __pyx_v_block_index_start; size_t __pyx_v_block_index_endex; addr_t __pyx_v_offset; size_t __pyx_v_size; size_t __pyx_v_block_index; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Flood_", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.Memory_Flood_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5158: cdef:
5159: Rack_* blocks
5160: const Block_* block
5161: addr_t block_start
5162: addr_t block_endex
5163: size_t block_index_start
5164: size_t block_index_endex
5165: addr_t offset
5166:
+5167: if start < endex:
__pyx_t_1 = ((__pyx_v_start < __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ }
+5168: blocks = that.blocks
__pyx_t_2 = __pyx_v_that->blocks; __pyx_v_blocks = __pyx_t_2;
+5169: block_index_start = Rack_IndexStart(blocks, start)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_start); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 5169, __pyx_L1_error)
__pyx_v_block_index_start = __pyx_t_3;
5170:
5171: # Check if touching previous block
+5172: if block_index_start:
__pyx_t_1 = (__pyx_v_block_index_start != 0); if (__pyx_t_1) { /* … */ }
+5173: block = Rack_Get__(blocks, block_index_start - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_block_index_start - 1));
+5174: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5175: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+5176: if block_endex == start:
__pyx_t_1 = ((__pyx_v_block_endex == __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+5177: block_index_start -= 1
__pyx_v_block_index_start = (__pyx_v_block_index_start - 1);
5178:
5179: # Manage block near start
+5180: if block_index_start < Rack_Length(blocks):
__pyx_t_1 = ((__pyx_v_block_index_start < __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks)) != 0); if (__pyx_t_1) { /* … */ }
+5181: block = Rack_Get__(blocks, block_index_start)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index_start);
+5182: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5183: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
5184:
+5185: if block_start <= start and endex <= block_endex:
__pyx_t_4 = ((__pyx_v_block_start <= __pyx_v_start) != 0); if (__pyx_t_4) { } else { __pyx_t_1 = __pyx_t_4; goto __pyx_L8_bool_binop_done; } __pyx_t_4 = ((__pyx_v_endex <= __pyx_v_block_endex) != 0); __pyx_t_1 = __pyx_t_4; __pyx_L8_bool_binop_done:; if (__pyx_t_1) { /* … */ }
+5186: return 0 # no emptiness to flood
__pyx_r = 0; goto __pyx_L0;
5187:
+5188: if block_start < start:
__pyx_t_1 = ((__pyx_v_block_start < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+5189: offset = start - block_start
__pyx_v_offset = (__pyx_v_start - __pyx_v_block_start);
+5190: CheckAddrToSizeU(offset)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5190, __pyx_L1_error)
+5191: Block_RotateRight_(pattern[0], <size_t>offset)
__pyx_f_11cbytesparse_1c_Block_RotateRight_((__pyx_v_pattern[0]), ((size_t)__pyx_v_offset));
+5192: start = block_start
__pyx_v_start = __pyx_v_block_start;
5193:
5194: # Manage block near end
+5195: block_index_endex = Rack_IndexEndex(blocks, endex)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_blocks, __pyx_v_endex); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 5195, __pyx_L1_error)
__pyx_v_block_index_endex = __pyx_t_3;
+5196: if block_index_start < block_index_endex:
__pyx_t_1 = ((__pyx_v_block_index_start < __pyx_v_block_index_endex) != 0); if (__pyx_t_1) { /* … */ }
+5197: block = Rack_Get__(blocks, block_index_endex - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_block_index_endex - 1));
+5198: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5199: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+5200: if endex < block_endex:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_block_endex) != 0); if (__pyx_t_1) { /* … */ }
+5201: endex = block_endex
__pyx_v_endex = __pyx_v_block_endex;
5202:
+5203: CheckAddrToSizeU(endex - start)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_endex - __pyx_v_start)); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5203, __pyx_L1_error)
+5204: if not Block_Length(pattern[0]):
__pyx_t_1 = ((!(__pyx_f_11cbytesparse_1c_Block_Length((__pyx_v_pattern[0])) != 0)) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+5205: raise ValueError('non-empty pattern required')
__pyx_t_6 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__24, NULL); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 5205, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 5205, __pyx_L1_error)
5206:
+5207: size = <size_t>(endex - start)
__pyx_v_size = ((size_t)(__pyx_v_endex - __pyx_v_start));
+5208: pattern[0] = Block_RepeatToSize(pattern[0], size)
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_RepeatToSize((__pyx_v_pattern[0]), __pyx_v_size); if (unlikely(__pyx_t_7 == ((Block_ *)NULL))) __PYX_ERR(0, 5208, __pyx_L1_error)
(__pyx_v_pattern[0]) = __pyx_t_7;
+5209: pattern[0].address = start
(__pyx_v_pattern[0])->address = __pyx_v_start;
5210:
+5211: for block_index in range(block_index_start, block_index_endex):
__pyx_t_8 = __pyx_v_block_index_endex; __pyx_t_9 = __pyx_t_8; for (__pyx_t_10 = __pyx_v_block_index_start; __pyx_t_10 < __pyx_t_9; __pyx_t_10+=1) { __pyx_v_block_index = __pyx_t_10;
+5212: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+5213: offset = Block_Start(block) - start
__pyx_v_offset = (__pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block) - __pyx_v_start);
5214: # CheckAddrToSizeU(offset) # implied
+5215: pattern[0] = Block_Write_(pattern[0], <size_t>offset, Block_Length(block), Block_At__(block, 0))
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Block_Write_((__pyx_v_pattern[0]), ((size_t)__pyx_v_offset), __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block), __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, 0)); if (unlikely(__pyx_t_7 == ((Block_ *)NULL))) __PYX_ERR(0, 5215, __pyx_L1_error)
(__pyx_v_pattern[0]) = __pyx_t_7;
}
5216:
+5217: that.blocks = blocks = Rack_DelSlice_(blocks, block_index_start, block_index_endex)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_DelSlice_(__pyx_v_blocks, __pyx_v_block_index_start, __pyx_v_block_index_endex); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 5217, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_2;
__pyx_v_blocks = __pyx_t_2;
+5218: that.blocks = blocks = Rack_Insert_(blocks, block_index_start, pattern[0])
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_Insert_(__pyx_v_blocks, __pyx_v_block_index_start, (__pyx_v_pattern[0])); if (unlikely(__pyx_t_2 == ((Rack_ *)NULL))) __PYX_ERR(0, 5218, __pyx_L1_error)
__pyx_v_that->blocks = __pyx_t_2;
__pyx_v_blocks = __pyx_t_2;
5219:
5220:
+5221: cdef vint Memory_Flood(Memory_* that, object start, object endex, object pattern) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Memory_Flood(Memory_ *__pyx_v_that, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; Block_ *__pyx_v_pattern_; __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_Flood", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("cbytesparse.c.Memory_Flood", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5222: cdef:
5223: addr_t start_
5224: addr_t endex_
+5225: Block_* pattern_ = NULL
__pyx_v_pattern_ = NULL;
5226:
+5227: start_, endex_ = Memory_Bound(that, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_that, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 5227, __pyx_L1_error)
__pyx_t_2 = __pyx_t_1.f0;
__pyx_t_3 = __pyx_t_1.f1;
__pyx_v_start_ = __pyx_t_2;
__pyx_v_endex_ = __pyx_t_3;
+5228: if start_ < endex_:
__pyx_t_4 = ((__pyx_v_start_ < __pyx_v_endex_) != 0); if (__pyx_t_4) { /* … */ }
+5229: pattern_ = Block_FromObject(0, pattern, False) # size checked later on
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_FromObject(0, __pyx_v_pattern, 0); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 5229, __pyx_L1_error)
__pyx_v_pattern_ = __pyx_t_5;
+5230: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L9_try_end; __pyx_L4_error:; /* … */ __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); goto __pyx_L1_error; __pyx_L9_try_end:; }
+5231: Memory_Flood_(that, start_, endex_, &pattern_)
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Memory_Flood_(__pyx_v_that, __pyx_v_start_, __pyx_v_endex_, (&__pyx_v_pattern_)); if (unlikely(__pyx_t_9 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5231, __pyx_L4_error)
+5232: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Memory_Flood", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12) < 0) __PYX_ERR(0, 5232, __pyx_L6_except_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11); __Pyx_GOTREF(__pyx_t_12);
+5233: Block_Free(pattern_) # orphan
(void)(__pyx_f_11cbytesparse_1c_Block_Free(__pyx_v_pattern_));
+5234: raise
__Pyx_GIVEREF(__pyx_t_10); __Pyx_GIVEREF(__pyx_t_11); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_ErrRestoreWithState(__pyx_t_10, __pyx_t_11, __pyx_t_12); __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_t_12 = 0; __PYX_ERR(0, 5234, __pyx_L6_except_error) } __pyx_L6_except_error:;
5235:
5236:
+5237: cdef list Memory_AsViews(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_AsViews(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks1; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ *__pyx_v_block; CYTHON_UNUSED size_t __pyx_v_size; __Pyx_memviewslice __pyx_v_view = { 0, 0, { 0 }, { 0 }, { 0 } }; PyObject *__pyx_v_blocks2 = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_AsViews", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(((PyObject *)__pyx_t_7)); __Pyx_XDECREF(__pyx_t_8); __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1); __Pyx_XDECREF(__pyx_t_10); __Pyx_AddTraceback("cbytesparse.c.Memory_AsViews", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __Pyx_XDECREF(__pyx_v_blocks2); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5238: cdef:
+5239: const Rack_* blocks1 = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks1 = __pyx_t_1;
+5240: size_t block_count = Rack_Length(blocks1)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks1);
5241: size_t block_index
+5242: Block_* block = NULL
__pyx_v_block = NULL;
5243: size_t size
5244: const byte_t[:] view
+5245: list blocks2 = []
__pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5245, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_blocks2 = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
5246:
+5247: for block_index in range(block_count):
__pyx_t_3 = __pyx_v_block_count; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_block_index = __pyx_t_5;
+5248: block = Rack_Get__(blocks1, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks1, __pyx_v_block_index);
+5249: size = Block_Length(block)
__pyx_v_size = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block);
+5250: view = <const byte_t[:size]>Block_At__(block, 0)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, 0); if (!__pyx_t_6) { PyErr_SetString(PyExc_ValueError,"Cannot create cython.array from NULL pointer"); __PYX_ERR(0, 5250, __pyx_L1_error) } __pyx_t_8 = __pyx_format_from_typeinfo(&__Pyx_TypeInfo_nn_byte_t__const__); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 5250, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = Py_BuildValue((char*) "(" __PYX_BUILD_PY_SSIZE_T ")", ((Py_ssize_t)__pyx_v_size)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5250, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_7 = __pyx_array_new(__pyx_t_2, sizeof(byte_t const ), PyBytes_AS_STRING(__pyx_t_8), (char *) "c", (char *) __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 5250, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(((PyObject *)__pyx_t_7), 0); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(0, 5250, __pyx_L1_error) __Pyx_DECREF(((PyObject *)__pyx_t_7)); __pyx_t_7 = 0; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __pyx_v_view = __pyx_t_9; __pyx_t_9.memview = NULL; __pyx_t_9.data = NULL;
+5251: blocks2.append([Block_Start(block), view])
__pyx_t_8 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 5251, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_view, 1, (PyObject *(*)(char *)) __pyx_memview_get_nn_byte_t__const__, (int (*)(char *, PyObject *)) NULL, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5251, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_10 = PyList_New(2); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 5251, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GIVEREF(__pyx_t_8); PyList_SET_ITEM(__pyx_t_10, 0, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_2); PyList_SET_ITEM(__pyx_t_10, 1, __pyx_t_2); __pyx_t_8 = 0; __pyx_t_2 = 0; __pyx_t_11 = __Pyx_PyList_Append(__pyx_v_blocks2, __pyx_t_10); if (unlikely(__pyx_t_11 == ((int)-1))) __PYX_ERR(0, 5251, __pyx_L1_error) __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0; }
+5252: return blocks2
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_blocks2); __pyx_r = __pyx_v_blocks2; goto __pyx_L0;
5253:
5254:
+5255: cdef list Memory_ToBlocks(const Memory_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Memory_ToBlocks(Memory_ const *__pyx_v_that) { Rack_ const *__pyx_v_blocks1; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ *__pyx_v_block; CYTHON_UNUSED size_t __pyx_v_size; __Pyx_memviewslice __pyx_v_view = { 0, 0, { 0 }, { 0 }, { 0 } }; PyObject *__pyx_v_blocks2 = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Memory_ToBlocks", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(((PyObject *)__pyx_t_7)); __Pyx_XDECREF(__pyx_t_8); __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1); __Pyx_XDECREF(__pyx_t_10); __Pyx_AddTraceback("cbytesparse.c.Memory_ToBlocks", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __Pyx_XDECREF(__pyx_v_blocks2); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5256: cdef:
+5257: const Rack_* blocks1 = that.blocks
__pyx_t_1 = __pyx_v_that->blocks; __pyx_v_blocks1 = __pyx_t_1;
+5258: size_t block_count = Rack_Length(blocks1)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks1);
5259: size_t block_index
+5260: Block_* block = NULL
__pyx_v_block = NULL;
5261: size_t size
5262: const byte_t[:] view
+5263: list blocks2 = []
__pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5263, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_blocks2 = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
5264:
+5265: for block_index in range(block_count):
__pyx_t_3 = __pyx_v_block_count; __pyx_t_4 = __pyx_t_3; for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_4; __pyx_t_5+=1) { __pyx_v_block_index = __pyx_t_5;
+5266: block = Rack_Get__(blocks1, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks1, __pyx_v_block_index);
+5267: size = Block_Length(block)
__pyx_v_size = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block);
+5268: view = <const byte_t[:size]>Block_At__(block, 0)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, 0); if (!__pyx_t_6) { PyErr_SetString(PyExc_ValueError,"Cannot create cython.array from NULL pointer"); __PYX_ERR(0, 5268, __pyx_L1_error) } __pyx_t_8 = __pyx_format_from_typeinfo(&__Pyx_TypeInfo_nn_byte_t__const__); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 5268, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = Py_BuildValue((char*) "(" __PYX_BUILD_PY_SSIZE_T ")", ((Py_ssize_t)__pyx_v_size)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5268, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_7 = __pyx_array_new(__pyx_t_2, sizeof(byte_t const ), PyBytes_AS_STRING(__pyx_t_8), (char *) "c", (char *) __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 5268, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(((PyObject *)__pyx_t_7), 0); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(0, 5268, __pyx_L1_error) __Pyx_DECREF(((PyObject *)__pyx_t_7)); __pyx_t_7 = 0; __PYX_XDEC_MEMVIEW(&__pyx_v_view, 1); __pyx_v_view = __pyx_t_9; __pyx_t_9.memview = NULL; __pyx_t_9.data = NULL;
+5269: blocks2.append([Block_Start(block), bytearray(view)])
__pyx_t_8 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 5269, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_view, 1, (PyObject *(*)(char *)) __pyx_memview_get_nn_byte_t__const__, (int (*)(char *, PyObject *)) NULL, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5269, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_10 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyByteArray_Type)), __pyx_t_2); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 5269, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyList_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5269, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_8); PyList_SET_ITEM(__pyx_t_2, 0, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_10); PyList_SET_ITEM(__pyx_t_2, 1, __pyx_t_10); __pyx_t_8 = 0; __pyx_t_10 = 0; __pyx_t_11 = __Pyx_PyList_Append(__pyx_v_blocks2, __pyx_t_2); if (unlikely(__pyx_t_11 == ((int)-1))) __PYX_ERR(0, 5269, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; }
+5270: return blocks2
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_blocks2); __pyx_r = __pyx_v_blocks2; goto __pyx_L0;
5271:
5272:
5273: # =====================================================================================================================
5274:
+5275: cdef Rover_* Rover_Alloc() except NULL:
static Rover_ *__pyx_f_11cbytesparse_1c_Rover_Alloc(void) { Rover_ *__pyx_v_that; Rover_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rover_Alloc", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rover_Alloc", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5276: cdef:
+5277: Rover_* that = <Rover_*>PyMem_Calloc(Rover_HEADING, 1)
__pyx_v_that = ((Rover_ *)__pyx_f_11cbytesparse_1c_PyMem_Calloc(Rover_HEADING, 1));
5278:
+5279: if that == NULL:
__pyx_t_1 = ((__pyx_v_that == NULL) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+5280: raise MemoryError()
PyErr_NoMemory(); __PYX_ERR(0, 5280, __pyx_L1_error)
+5281: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
5282:
5283:
+5284: cdef Rover_* Rover_Free(Rover_* that) except? NULL:
static Rover_ *__pyx_f_11cbytesparse_1c_Rover_Free(Rover_ *__pyx_v_that) { Rover_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rover_Free", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Rover_Free", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+5285: if that:
__pyx_t_1 = (__pyx_v_that != 0); if (__pyx_t_1) { /* … */ }
+5286: Rover_Dispose(that)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Rover_Dispose(__pyx_v_that); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5286, __pyx_L1_error)
+5287: PyMem_Free(that)
PyMem_Free(__pyx_v_that);
+5288: return NULL
__pyx_r = NULL; goto __pyx_L0;
5289:
5290:
+5291: cdef Rover_* Rover_Create(
static Rover_ *__pyx_f_11cbytesparse_1c_Rover_Create(Memory_ const *__pyx_v_memory, addr_t __pyx_v_start, addr_t __pyx_v_endex, size_t __pyx_v_pattern_size, byte_t const *__pyx_v_pattern_data, int __pyx_v_forward, int __pyx_v_infinite) { Block_ *__pyx_v_block; addr_t __pyx_v_offset; size_t __pyx_v_pattern_offset; Rover_ *__pyx_v_that; Rover_ *__pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rover_Create", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_13); __Pyx_XDECREF(__pyx_t_14); __Pyx_AddTraceback("cbytesparse.c.Rover_Create", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5292: const Memory_* memory,
5293: addr_t start,
5294: addr_t endex,
5295: size_t pattern_size,
5296: const byte_t* pattern_data,
5297: bint forward,
5298: bint infinite,
5299: ) except NULL:
5300: cdef:
+5301: Block_* block = NULL
__pyx_v_block = NULL;
5302: addr_t offset
5303: size_t pattern_offset
5304:
+5305: if forward:
__pyx_t_1 = (__pyx_v_forward != 0); if (__pyx_t_1) { /* … */ goto __pyx_L3; }
+5306: if endex < start:
__pyx_t_1 = ((__pyx_v_endex < __pyx_v_start) != 0); if (__pyx_t_1) { /* … */ }
+5307: endex = start
__pyx_v_endex = __pyx_v_start;
5308: else:
+5309: if start > endex:
/*else*/ { __pyx_t_1 = ((__pyx_v_start > __pyx_v_endex) != 0); if (__pyx_t_1) { /* … */ } } __pyx_L3:;
+5310: start = endex
__pyx_v_start = __pyx_v_endex;
5311:
+5312: if (not pattern_data) != (not pattern_size):
__pyx_t_1 = (((!(__pyx_v_pattern_data != 0)) != (!(__pyx_v_pattern_size != 0))) != 0); if (unlikely(__pyx_t_1)) { /* … */ }
+5313: raise ValueError('non-empty pattern required')
__pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__24, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5313, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 5313, __pyx_L1_error)
+5314: pattern_offset = pattern_size - 1 if pattern_size and not forward else 0
__pyx_t_4 = (__pyx_v_pattern_size != 0); if (__pyx_t_4) { } else { __pyx_t_1 = __pyx_t_4; goto __pyx_L7_bool_binop_done; } __pyx_t_4 = ((!(__pyx_v_forward != 0)) != 0); __pyx_t_1 = __pyx_t_4; __pyx_L7_bool_binop_done:; if (__pyx_t_1) { __pyx_t_3 = (__pyx_v_pattern_size - 1); } else { __pyx_t_3 = 0; } __pyx_v_pattern_offset = __pyx_t_3;
5315:
+5316: that = Rover_Alloc()
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rover_Alloc(); if (unlikely(__pyx_t_5 == ((Rover_ *)NULL))) __PYX_ERR(0, 5316, __pyx_L1_error)
__pyx_v_that = __pyx_t_5;
5317:
+5318: that.forward = forward
__pyx_v_that->forward = __pyx_v_forward;
+5319: that.infinite = infinite
__pyx_v_that->infinite = __pyx_v_infinite;
+5320: that.start = start
__pyx_v_that->start = __pyx_v_start;
+5321: that.endex = endex
__pyx_v_that->endex = __pyx_v_endex;
+5322: that.address = start if forward else endex
if ((__pyx_v_forward != 0)) { __pyx_t_6 = __pyx_v_start; } else { __pyx_t_6 = __pyx_v_endex; } __pyx_v_that->address = __pyx_t_6;
5323:
+5324: that.pattern_size = pattern_size
__pyx_v_that->pattern_size = __pyx_v_pattern_size;
+5325: that.pattern_data = &pattern_data[pattern_offset]
__pyx_v_that->pattern_data = (&(__pyx_v_pattern_data[__pyx_v_pattern_offset]));
+5326: that.pattern_offset = pattern_offset
__pyx_v_that->pattern_offset = __pyx_v_pattern_offset;
5327:
+5328: that.memory = memory
__pyx_v_that->memory = __pyx_v_memory;
+5329: that.block_count = Rack_Length(memory.blocks)
__pyx_v_that->block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_memory->blocks);
5330:
+5331: try:
{ /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; goto __pyx_L14_try_end; __pyx_L9_error:; __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_XGIVEREF(__pyx_t_9); __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_8, __pyx_t_9); goto __pyx_L1_error; __pyx_L14_try_end:; }
+5332: if that.block_count:
__pyx_t_1 = (__pyx_v_that->block_count != 0); if (__pyx_t_1) { /* … */ }
+5333: if forward:
__pyx_t_1 = (__pyx_v_forward != 0); if (__pyx_t_1) { /* … */ goto __pyx_L16; }
+5334: that.block_index = Rack_IndexStart(memory.blocks, start)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_memory->blocks, __pyx_v_start); if (unlikely(__pyx_t_10 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 5334, __pyx_L9_error)
__pyx_v_that->block_index = __pyx_t_10;
+5335: if that.block_index < that.block_count:
__pyx_t_1 = ((__pyx_v_that->block_index < __pyx_v_that->block_count) != 0); if (__pyx_t_1) { /* … */ }
+5336: block = Rack_Get_(memory.blocks, that.block_index)
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_memory->blocks, __pyx_v_that->block_index); if (unlikely(__pyx_t_11 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 5336, __pyx_L9_error) __pyx_v_block = __pyx_t_11;
+5337: that.block_start = Block_Start(block)
__pyx_v_that->block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5338: that.block_endex = Block_Endex(block)
__pyx_v_that->block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
5339:
+5340: offset = start if start >= that.block_start else that.block_start
if (((__pyx_v_start >= __pyx_v_that->block_start) != 0)) { __pyx_t_6 = __pyx_v_start; } else { __pyx_t_6 = __pyx_v_that->block_start; } __pyx_v_offset = __pyx_t_6;
+5341: if offset > that.block_endex:
__pyx_t_1 = ((__pyx_v_offset > __pyx_v_that->block_endex) != 0); if (__pyx_t_1) { /* … */ }
+5342: offset = that.block_endex
__pyx_t_6 = __pyx_v_that->block_endex; __pyx_v_offset = __pyx_t_6;
+5343: offset -= that.block_start
__pyx_v_offset = (__pyx_v_offset - __pyx_v_that->block_start);
+5344: CheckAddrToSizeU(offset)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_12 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5344, __pyx_L9_error)
5345:
+5346: block = Block_Acquire(block)
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_block); if (unlikely(__pyx_t_11 == ((Block_ *)NULL))) __PYX_ERR(0, 5346, __pyx_L9_error)
__pyx_v_block = __pyx_t_11;
+5347: that.block = block
__pyx_v_that->block = __pyx_v_block;
+5348: that.block_ptr = Block_At__(block, <size_t>offset)
__pyx_v_that->block_ptr = __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, ((size_t)__pyx_v_offset));
5349:
5350: else:
+5351: that.block_index = Rack_IndexEndex(memory.blocks, endex)
/*else*/ {
__pyx_t_10 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_memory->blocks, __pyx_v_endex); if (unlikely(__pyx_t_10 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 5351, __pyx_L9_error)
__pyx_v_that->block_index = __pyx_t_10;
+5352: if that.block_index:
__pyx_t_1 = (__pyx_v_that->block_index != 0); if (__pyx_t_1) { /* … */ } } __pyx_L16:;
+5353: block = Rack_Get_(memory.blocks, that.block_index - 1)
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_memory->blocks, (__pyx_v_that->block_index - 1)); if (unlikely(__pyx_t_11 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 5353, __pyx_L9_error) __pyx_v_block = __pyx_t_11;
+5354: that.block_start = Block_Start(block)
__pyx_v_that->block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5355: that.block_endex = Block_Endex(block)
__pyx_v_that->block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
5356:
+5357: offset = endex if endex >= that.block_start else that.block_start
if (((__pyx_v_endex >= __pyx_v_that->block_start) != 0)) { __pyx_t_6 = __pyx_v_endex; } else { __pyx_t_6 = __pyx_v_that->block_start; } __pyx_v_offset = __pyx_t_6;
+5358: if offset > that.block_endex:
__pyx_t_1 = ((__pyx_v_offset > __pyx_v_that->block_endex) != 0); if (__pyx_t_1) { /* … */ }
+5359: offset = that.block_endex
__pyx_t_6 = __pyx_v_that->block_endex; __pyx_v_offset = __pyx_t_6;
+5360: offset -= that.block_start
__pyx_v_offset = (__pyx_v_offset - __pyx_v_that->block_start);
+5361: CheckAddrToSizeU(offset)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_v_offset); if (unlikely(__pyx_t_12 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5361, __pyx_L9_error)
5362:
+5363: block = Block_Acquire(block)
__pyx_t_11 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_block); if (unlikely(__pyx_t_11 == ((Block_ *)NULL))) __PYX_ERR(0, 5363, __pyx_L9_error)
__pyx_v_block = __pyx_t_11;
+5364: that.block = block
__pyx_v_that->block = __pyx_v_block;
+5365: that.block_ptr = Block_At__(block, <size_t>offset)
__pyx_v_that->block_ptr = __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, ((size_t)__pyx_v_offset));
+5366: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Rover_Create", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_2, &__pyx_t_13, &__pyx_t_14) < 0) __PYX_ERR(0, 5366, __pyx_L11_except_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GOTREF(__pyx_t_13); __Pyx_GOTREF(__pyx_t_14);
+5367: that = Rover_Free(that)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_v_that); if (unlikely(__pyx_t_5 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 5367, __pyx_L11_except_error) __pyx_v_that = __pyx_t_5;
+5368: raise
__Pyx_GIVEREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_14); __Pyx_ErrRestoreWithState(__pyx_t_2, __pyx_t_13, __pyx_t_14); __pyx_t_2 = 0; __pyx_t_13 = 0; __pyx_t_14 = 0; __PYX_ERR(0, 5368, __pyx_L11_except_error) } __pyx_L11_except_error:;
5369:
+5370: return that
__pyx_r = __pyx_v_that; goto __pyx_L0;
5371:
5372:
+5373: cdef addr_t Rover_Length(const Rover_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Rover_Length(Rover_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5374: return that.endex - that.start
__pyx_r = (__pyx_v_that->endex - __pyx_v_that->start); goto __pyx_L0;
5375:
5376:
+5377: cdef bint Rover_HasNext(const Rover_* that) nogil:
static int __pyx_f_11cbytesparse_1c_Rover_HasNext(Rover_ const *__pyx_v_that) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5378: if that.forward:
__pyx_t_1 = (__pyx_v_that->forward != 0); if (__pyx_t_1) { /* … */ }
+5379: return that.address < that.endex
__pyx_r = (__pyx_v_that->address < __pyx_v_that->endex); goto __pyx_L0;
5380: else:
+5381: return that.address > that.start
/*else*/ { __pyx_r = (__pyx_v_that->address > __pyx_v_that->start); goto __pyx_L0; }
5382:
5383:
+5384: cdef int Rover_Next_(Rover_* that) except -2:
static int __pyx_f_11cbytesparse_1c_Rover_Next_(Rover_ *__pyx_v_that) { Block_ *__pyx_v_block; int __pyx_v_value; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rover_Next_", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("cbytesparse.c.Rover_Next_", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -2; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5385: cdef:
+5386: Block_* block = NULL
__pyx_v_block = NULL;
+5387: int value = -1
__pyx_v_value = -1;
5388:
+5389: try:
{ /*try:*/ { /* … */ } __pyx_L3_error:; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; /* … */ __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L1_error; __pyx_L7_try_return:; __Pyx_XGIVEREF(__pyx_t_1); __Pyx_XGIVEREF(__pyx_t_2); __Pyx_XGIVEREF(__pyx_t_3); __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); goto __pyx_L0; }
+5390: if that.forward:
__pyx_t_4 = (__pyx_v_that->forward != 0); if (__pyx_t_4) { /* … */ goto __pyx_L9; }
+5391: while True: # loop to move to the next block when necessary
while (1) {
+5392: if that.address < that.endex:
__pyx_t_4 = ((__pyx_v_that->address < __pyx_v_that->endex) != 0); if (__pyx_t_4) { /* … */ }
+5393: if that.block_index < that.block_count:
__pyx_t_4 = ((__pyx_v_that->block_index < __pyx_v_that->block_count) != 0); if (__pyx_t_4) { /* … */ }
+5394: if that.address < that.block_start:
__pyx_t_4 = ((__pyx_v_that->address < __pyx_v_that->block_start) != 0); if (__pyx_t_4) { /* … */ }
+5395: that.address += 1
__pyx_v_that->address = (__pyx_v_that->address + 1);
+5396: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ goto __pyx_L15; }
+5397: value = <int><unsigned>that.pattern_data[that.pattern_offset]
__pyx_v_value = ((int)((unsigned int)(__pyx_v_that->pattern_data[__pyx_v_that->pattern_offset])));
5398: else:
+5399: value = -1
/*else*/ { __pyx_v_value = -1; } __pyx_L15:;
+5400: break
goto __pyx_L11_break;
5401:
+5402: elif that.address < that.block_endex:
__pyx_t_4 = ((__pyx_v_that->address < __pyx_v_that->block_endex) != 0); if (__pyx_t_4) { /* … */ }
+5403: that.address += 1
__pyx_v_that->address = (__pyx_v_that->address + 1);
+5404: value = that.block_ptr[0]
__pyx_v_value = (__pyx_v_that->block_ptr[0]);
+5405: that.block_ptr += 1
__pyx_v_that->block_ptr = (__pyx_v_that->block_ptr + 1);
+5406: break
goto __pyx_L11_break;
5407:
5408: else:
+5409: that.block_index += 1
/*else*/ { __pyx_v_that->block_index = (__pyx_v_that->block_index + 1);
+5410: if that.block_index < that.block_count:
__pyx_t_4 = ((__pyx_v_that->block_index < __pyx_v_that->block_count) != 0); if (__pyx_t_4) { /* … */ }
+5411: that.block = Block_Release(that.block)
__pyx_v_that->block = __pyx_f_11cbytesparse_1c_Block_Release(__pyx_v_that->block);
+5412: that.block = NULL
__pyx_v_that->block = NULL;
+5413: block = Rack_Get_(that.memory.blocks, that.block_index)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_that->memory->blocks, __pyx_v_that->block_index); if (unlikely(__pyx_t_5 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 5413, __pyx_L3_error) __pyx_v_block = __pyx_t_5;
+5414: block = Block_Acquire(block)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_block); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 5414, __pyx_L3_error)
__pyx_v_block = __pyx_t_5;
+5415: that.block = block
__pyx_v_that->block = __pyx_v_block;
+5416: that.block_start = Block_Start(block)
__pyx_v_that->block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5417: that.block_endex = Block_Endex(block)
__pyx_v_that->block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+5418: that.block_ptr = Block_At_(block, 0)
__pyx_v_that->block_ptr = __pyx_f_11cbytesparse_1c_Block_At_(__pyx_v_block, 0);
+5419: continue
goto __pyx_L10_continue; }
5420: else:
+5421: that.address += 1
/*else*/ { __pyx_v_that->address = (__pyx_v_that->address + 1);
+5422: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ goto __pyx_L17; }
+5423: value = <int><unsigned>that.pattern_data[that.pattern_offset]
__pyx_v_value = ((int)((unsigned int)(__pyx_v_that->pattern_data[__pyx_v_that->pattern_offset])));
5424: else:
+5425: value = -1
/*else*/ { __pyx_v_value = -1; } __pyx_L17:;
+5426: break
goto __pyx_L11_break; }
5427:
+5428: elif that.infinite:
__pyx_t_4 = (__pyx_v_that->infinite != 0); if (likely(__pyx_t_4)) { /* … */ goto __pyx_L12; }
+5429: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ goto __pyx_L18; }
+5430: value = <int><unsigned>that.pattern_data[that.pattern_offset]
__pyx_v_value = ((int)((unsigned int)(__pyx_v_that->pattern_data[__pyx_v_that->pattern_offset])));
5431: else:
+5432: value = -1
/*else*/ { __pyx_v_value = -1; } __pyx_L18:;
5433:
5434: else:
+5435: raise StopIteration()
/*else*/ { __pyx_t_6 = __Pyx_PyObject_CallNoArg(__pyx_builtin_StopIteration); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 5435, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 5435, __pyx_L3_error) } __pyx_L12:; __pyx_L10_continue:; } __pyx_L11_break:;
5436: else:
+5437: while True: # loop to move to the next block when necessary
/*else*/ { while (1) {
+5438: if that.address > that.start:
__pyx_t_4 = ((__pyx_v_that->address > __pyx_v_that->start) != 0); if (__pyx_t_4) { /* … */ }
+5439: if that.block_index:
__pyx_t_4 = (__pyx_v_that->block_index != 0); if (__pyx_t_4) { /* … */ }
+5440: if that.address > that.block_endex:
__pyx_t_4 = ((__pyx_v_that->address > __pyx_v_that->block_endex) != 0); if (__pyx_t_4) { /* … */ }
+5441: that.address -= 1
__pyx_v_that->address = (__pyx_v_that->address - 1);
+5442: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ goto __pyx_L24; }
+5443: value = <int><unsigned>that.pattern_data[that.pattern_offset]
__pyx_v_value = ((int)((unsigned int)(__pyx_v_that->pattern_data[__pyx_v_that->pattern_offset])));
5444: else:
+5445: value = -1
/*else*/ { __pyx_v_value = -1; } __pyx_L24:;
+5446: break
goto __pyx_L20_break;
5447:
+5448: elif that.address > that.block_start:
__pyx_t_4 = ((__pyx_v_that->address > __pyx_v_that->block_start) != 0); if (__pyx_t_4) { /* … */ }
+5449: that.address -= 1
__pyx_v_that->address = (__pyx_v_that->address - 1);
+5450: that.block_ptr -= 1
__pyx_v_that->block_ptr = (__pyx_v_that->block_ptr - 1);
+5451: value = that.block_ptr[0]
__pyx_v_value = (__pyx_v_that->block_ptr[0]);
+5452: break
goto __pyx_L20_break;
5453:
5454: else:
+5455: that.block_index -= 1
/*else*/ { __pyx_v_that->block_index = (__pyx_v_that->block_index - 1);
+5456: if that.block_index:
__pyx_t_4 = (__pyx_v_that->block_index != 0); if (__pyx_t_4) { /* … */ }
+5457: that.block = Block_Release(that.block)
__pyx_v_that->block = __pyx_f_11cbytesparse_1c_Block_Release(__pyx_v_that->block);
+5458: that.block = NULL
__pyx_v_that->block = NULL;
+5459: block = Rack_Get_(that.memory.blocks, that.block_index - 1)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_Get_(__pyx_v_that->memory->blocks, (__pyx_v_that->block_index - 1)); if (unlikely(__pyx_t_5 == ((Block_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 5459, __pyx_L3_error) __pyx_v_block = __pyx_t_5;
+5460: block = Block_Acquire(block)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Block_Acquire(__pyx_v_block); if (unlikely(__pyx_t_5 == ((Block_ *)NULL))) __PYX_ERR(0, 5460, __pyx_L3_error)
__pyx_v_block = __pyx_t_5;
+5461: that.block = block
__pyx_v_that->block = __pyx_v_block;
+5462: that.block_start = Block_Start(block)
__pyx_v_that->block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+5463: that.block_endex = Block_Endex(block)
__pyx_v_that->block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+5464: that.block_ptr = Block_At__(block, Block_Length(block))
__pyx_v_that->block_ptr = __pyx_f_11cbytesparse_1c_Block_At__(__pyx_v_block, __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block));
+5465: value = -1
__pyx_v_value = -1;
+5466: continue
goto __pyx_L19_continue; }
5467: else:
+5468: that.address -= 1
/*else*/ { __pyx_v_that->address = (__pyx_v_that->address - 1);
+5469: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ goto __pyx_L26; }
+5470: value = <int><unsigned>that.pattern_data[that.pattern_offset]
__pyx_v_value = ((int)((unsigned int)(__pyx_v_that->pattern_data[__pyx_v_that->pattern_offset])));
5471: else:
+5472: value = -1
/*else*/ { __pyx_v_value = -1; } __pyx_L26:;
+5473: break
goto __pyx_L20_break; }
5474:
+5475: elif that.infinite:
__pyx_t_4 = (__pyx_v_that->infinite != 0); if (likely(__pyx_t_4)) { /* … */ goto __pyx_L21; }
+5476: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ goto __pyx_L27; }
+5477: value = <int><unsigned>that.pattern_data[that.pattern_offset]
__pyx_v_value = ((int)((unsigned int)(__pyx_v_that->pattern_data[__pyx_v_that->pattern_offset])));
5478: else:
+5479: value = -1
/*else*/ { __pyx_v_value = -1; } __pyx_L27:;
5480:
5481: else:
+5482: raise StopIteration()
/*else*/ { __pyx_t_6 = __Pyx_PyObject_CallNoArg(__pyx_builtin_StopIteration); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 5482, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 5482, __pyx_L3_error) } __pyx_L21:; __pyx_L19_continue:; } __pyx_L20_break:; } __pyx_L9:;
5483:
+5484: if that.pattern_size:
__pyx_t_4 = (__pyx_v_that->pattern_size != 0); if (__pyx_t_4) { /* … */ }
+5485: if that.forward:
__pyx_t_4 = (__pyx_v_that->forward != 0); if (__pyx_t_4) { /* … */ goto __pyx_L29; }
+5486: if that.pattern_offset < that.pattern_size - 1:
__pyx_t_4 = ((__pyx_v_that->pattern_offset < (__pyx_v_that->pattern_size - 1)) != 0); if (__pyx_t_4) { /* … */ goto __pyx_L30; }
+5487: that.pattern_offset += 1
__pyx_v_that->pattern_offset = (__pyx_v_that->pattern_offset + 1);
5488: else:
+5489: that.pattern_offset = 0
/*else*/ { __pyx_v_that->pattern_offset = 0; } __pyx_L30:;
5490: else:
+5491: if that.pattern_offset > 0:
/*else*/ { __pyx_t_4 = ((__pyx_v_that->pattern_offset > 0) != 0); if (__pyx_t_4) { /* … */ goto __pyx_L31; }
+5492: that.pattern_offset -= 1
__pyx_v_that->pattern_offset = (__pyx_v_that->pattern_offset - 1);
5493: else:
+5494: that.pattern_offset = that.pattern_size - 1
/*else*/ { __pyx_v_that->pattern_offset = (__pyx_v_that->pattern_size - 1); } __pyx_L31:; } __pyx_L29:;
5495:
+5496: return value
__pyx_r = __pyx_v_value; goto __pyx_L7_try_return;
5497:
+5498: except:
/*except:*/ { __Pyx_AddTraceback("cbytesparse.c.Rover_Next_", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8) < 0) __PYX_ERR(0, 5498, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GOTREF(__pyx_t_7); __Pyx_GOTREF(__pyx_t_8);
+5499: that.block = Block_Release(that.block) # preempt
__pyx_v_that->block = __pyx_f_11cbytesparse_1c_Block_Release(__pyx_v_that->block);
+5500: raise
__Pyx_GIVEREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ErrRestoreWithState(__pyx_t_6, __pyx_t_7, __pyx_t_8); __pyx_t_6 = 0; __pyx_t_7 = 0; __pyx_t_8 = 0; __PYX_ERR(0, 5500, __pyx_L5_except_error) } __pyx_L5_except_error:;
5501:
5502:
+5503: cdef object Rover_Next(Rover_* that):
static PyObject *__pyx_f_11cbytesparse_1c_Rover_Next(Rover_ *__pyx_v_that) { int __pyx_v_value; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rover_Next", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Rover_Next", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5504: cdef:
+5505: int value = Rover_Next_(that)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Rover_Next_(__pyx_v_that); if (unlikely(__pyx_t_1 == ((int)-2))) __PYX_ERR(0, 5505, __pyx_L1_error)
__pyx_v_value = __pyx_t_1;
5506:
+5507: return None if value < 0 else <object>value
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_value < 0) != 0)) { __Pyx_INCREF(Py_None); __pyx_t_2 = Py_None; } else { __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_value); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 5507, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_INCREF(((PyObject *)__pyx_t_3)); __pyx_t_2 = __pyx_t_3; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
5508:
5509:
+5510: cdef vint Rover_Dispose(Rover_* that) except -1:
static __pyx_t_11cbytesparse_1c_vint __pyx_f_11cbytesparse_1c_Rover_Dispose(Rover_ *__pyx_v_that) { __pyx_t_11cbytesparse_1c_vint __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("Rover_Dispose", 0); /* … */ /* function exit code */ __pyx_r = 0; __Pyx_RefNannyFinishContext(); return __pyx_r; }
+5511: that.address = that.endex if that.forward else that.start
if ((__pyx_v_that->forward != 0)) { __pyx_t_1 = __pyx_v_that->endex; } else { __pyx_t_1 = __pyx_v_that->start; } __pyx_v_that->address = __pyx_t_1;
+5512: that.block = Block_Release(that.block)
__pyx_v_that->block = __pyx_f_11cbytesparse_1c_Block_Release(__pyx_v_that->block);
+5513: that.memory = NULL
__pyx_v_that->memory = NULL;
5514:
5515:
+5516: cdef bint Rover_Forward(const Rover_* that) nogil:
static int __pyx_f_11cbytesparse_1c_Rover_Forward(Rover_ const *__pyx_v_that) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5517: return that.forward
__pyx_r = __pyx_v_that->forward; goto __pyx_L0;
5518:
5519:
+5520: cdef bint Rover_Infinite(const Rover_* that) nogil:
static int __pyx_f_11cbytesparse_1c_Rover_Infinite(Rover_ const *__pyx_v_that) { int __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5521: return that.infinite
__pyx_r = __pyx_v_that->infinite; goto __pyx_L0;
5522:
5523:
+5524: cdef addr_t Rover_Address(const Rover_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Rover_Address(Rover_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5525: return that.address
__pyx_r = __pyx_v_that->address; goto __pyx_L0;
5526:
5527:
+5528: cdef addr_t Rover_Start(const Rover_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Rover_Start(Rover_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5529: return that.start
__pyx_r = __pyx_v_that->start; goto __pyx_L0;
5530:
5531:
+5532: cdef addr_t Rover_Endex(const Rover_* that) nogil:
static addr_t __pyx_f_11cbytesparse_1c_Rover_Endex(Rover_ const *__pyx_v_that) { addr_t __pyx_r; /* … */ /* function exit code */ __pyx_L0:; return __pyx_r; }
+5533: return that.endex
__pyx_r = __pyx_v_that->endex; goto __pyx_L0;
5534:
5535:
5536: # =====================================================================================================================
5537:
5538: cdef class Memory:
5539: r"""Virtual memory.
5540:
5541: This class is a handy wrapper around `blocks`, so that it can behave mostly
5542: like a :obj:`bytearray`, but on sparse chunks of data.
5543:
5544: Please look at examples of each method to get a glimpse of the features of
5545: this class.
5546:
5547: On creation, at most one of `memory`, `blocks`, or `data` can be specified.
5548:
5549: The Cython implementation limits the address range to that of the integral
5550: type ``uint_fast64_t``.
5551:
5552: Attributes:
5553: _blocks (list of blocks):
5554: A sequence of spaced blocks, sorted by address.
5555:
5556: _trim_start (int):
5557: Memory trimming start address. Any data before this address is
5558: automatically discarded; disabled if ``None``.
5559:
5560: _trim_endex (int):
5561: Memory trimming exclusive end address. Any data at or after this
5562: address is automatically discarded; disabled if ``None``.
5563:
5564: Arguments:
5565: start (int):
5566: Optional memory start address.
5567: Anything before will be trimmed away.
5568:
5569: endex (int):
5570: Optional memory exclusive end address.
5571: Anything at or after it will be trimmed away.
5572:
5573: Examples:
5574: >>> memory = Memory()
5575: >>> memory._blocks
5576: []
5577:
5578: >>> memory = Memory.from_bytes(b'Hello, World!', offset=5)
5579: >>> memory._blocks
5580: [[5, b'Hello, World!']]
5581: """
5582:
+5583: def __add__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_1__add__(PyObject *__pyx_v_self, PyObject *__pyx_v_value); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_1__add__(PyObject *__pyx_v_self, PyObject *__pyx_v_value) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__add__ (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_self), __pyx_ptype_11cbytesparse_1c_Memory, 1, "self", 0))) __PYX_ERR(0, 5584, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory___add__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_value)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory___add__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_value) { Memory_ *__pyx_v_memory_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__add__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.__add__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5584: self: Memory,
5585: value: Union[AnyBytes, Memory],
5586: ) -> Memory:
5587: cdef:
+5588: Memory_* memory_ = Memory_Add(self._, value)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Add(__pyx_v_self->_, __pyx_v_value); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 5588, __pyx_L1_error)
__pyx_v_memory_ = __pyx_t_1;
+5589: Memory memory = Memory_AsObject(memory_)
__pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_AsObject(__pyx_v_memory_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5589, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_2); __pyx_t_2 = 0;
5590:
+5591: return memory
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = ((PyObject *)__pyx_v_memory); goto __pyx_L0;
5592:
+5593: def __bool__(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_3__bool__(PyObject *__pyx_v_self); /*proto*/ static int __pyx_pw_11cbytesparse_1c_6Memory_3__bool__(PyObject *__pyx_v_self) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bool__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_2__bool__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_2__bool__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bool__", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5594: self: Memory,
5595: ) -> bool:
5596: r"""Has any items.
5597:
5598: Returns:
5599: bool: Has any items.
5600:
5601: Examples:
5602: >>> memory = Memory()
5603: >>> bool(memory)
5604: False
5605:
5606: >>> memory = Memory.from_bytes(b'Hello, World!', 5)
5607: >>> bool(memory)
5608: True
5609: """
5610:
+5611: return not Memory_IsEmpty(self._)
__pyx_r = (!(__pyx_f_11cbytesparse_1c_Memory_IsEmpty(__pyx_v_self->_) != 0)); goto __pyx_L0;
5612:
+5613: def __bytes__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5__bytes__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_4__bytes__[] = "Memory.__bytes__(self: Memory) -> bytes\nCreates a bytes clone.\n\n Returns:\n :obj:`bytes`: Cloned data.\n\n Raises:\n :obj:`ValueError`: Data not contiguous (see :attr:`contiguous`).\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_5__bytes__ = {"__bytes__", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_5__bytes__, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_4__bytes__}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5__bytes__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bytes__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_4__bytes__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_4__bytes__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { Memory_ const *__pyx_v_memory; addr_t __pyx_v_start; addr_t __pyx_v_endex; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_v_view = 0; PyObject *__pyx_v_data = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__bytes__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory.__bytes__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_view); __Pyx_XDECREF(__pyx_v_data); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__73 = PyTuple_Pack(6, __pyx_n_s_self, __pyx_n_s_memory, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_view, __pyx_n_s_data); if (unlikely(!__pyx_tuple__73)) __PYX_ERR(0, 5613, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__73); __Pyx_GIVEREF(__pyx_tuple__73); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5613, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 5613, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_n_u_bytes_2) < 0) __PYX_ERR(0, 5613, __pyx_L1_error) __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_5__bytes__, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory___bytes, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__74)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5613, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_bytes, __pyx_t_2) < 0) __PYX_ERR(0, 5613, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__74 = (PyObject*)__Pyx_PyCode_New(1, 0, 6, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__73, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_bytes, 5613, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__74)) __PYX_ERR(0, 5613, __pyx_L1_error)
5614: self: Memory,
5615: ) -> bytes:
5616: r"""Creates a bytes clone.
5617:
5618: Returns:
5619: :obj:`bytes`: Cloned data.
5620:
5621: Raises:
5622: :obj:`ValueError`: Data not contiguous (see :attr:`contiguous`).
5623: """
5624: cdef:
+5625: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+5626: addr_t start = Memory_Start(memory)
__pyx_v_start = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_memory);
+5627: addr_t endex = Memory_Endex(memory)
__pyx_v_endex = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_memory);
+5628: BlockView view = Memory_View(memory, start, endex)
__pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_View(__pyx_v_memory, __pyx_v_start, __pyx_v_endex)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5628, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_view = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_2); __pyx_t_2 = 0;
5629: bytes data
5630:
+5631: data = view.__bytes__()
__pyx_t_3 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_view), __pyx_n_s_bytes); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 5631, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3); if (likely(__pyx_t_4)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_4); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_3, function); } } __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5631, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (!(likely(PyBytes_CheckExact(__pyx_t_2))||((__pyx_t_2) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "bytes", Py_TYPE(__pyx_t_2)->tp_name), 0))) __PYX_ERR(0, 5631, __pyx_L1_error) __pyx_v_data = ((PyObject*)__pyx_t_2); __pyx_t_2 = 0;
+5632: view.dispose()
__pyx_t_3 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_view), __pyx_n_s_dispose); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 5632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3); if (likely(__pyx_t_4)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_4); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_3, function); } } __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+5633: return data
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_data); __pyx_r = __pyx_v_data; goto __pyx_L0;
5634:
+5635: def __cinit__(self):
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_7__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static int __pyx_pw_11cbytesparse_1c_6Memory_7__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__ (wrapper)", 0); if (unlikely(PyTuple_GET_SIZE(__pyx_args) > 0)) { __Pyx_RaiseArgtupleInvalid("__cinit__", 1, 0, 0, PyTuple_GET_SIZE(__pyx_args)); return -1;} if (unlikely(__pyx_kwds) && unlikely(PyDict_Size(__pyx_kwds) > 0) && unlikely(!__Pyx_CheckKeywordStrings(__pyx_kwds, "__cinit__", 0))) return -1; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_6__cinit__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_6__cinit__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__", 0); /* … */ /* function exit code */ __pyx_r = 0; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5636: r"""Cython constructor."""
+5637: self._ = NULL
__pyx_v_self->_ = NULL;
5638:
+5639: def __contains__(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_9__contains__(PyObject *__pyx_v_self, PyObject *__pyx_v_item); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_8__contains__[] = "Checks if some items are contained.\n\n Arguments:\n item (items):\n Items to find. Can be either some byte string or an integer.\n\n Returns:\n bool: Item is contained.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[1 | 2 | 3]| |[x | y | z]|\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'123'], [9, b'xyz']])\n >>> b'23' in memory\n True\n >>> ord('y') in memory\n True\n >>> b'$' in memory\n False\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_8__contains__; #endif static int __pyx_pw_11cbytesparse_1c_6Memory_9__contains__(PyObject *__pyx_v_self, PyObject *__pyx_v_item) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__contains__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_8__contains__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_item)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_8__contains__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__contains__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.__contains__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5640: self: Memory,
5641: item: Union[AnyBytes, Value],
5642: ) -> bool:
5643: r"""Checks if some items are contained.
5644:
5645: Arguments:
5646: item (items):
5647: Items to find. Can be either some byte string or an integer.
5648:
5649: Returns:
5650: bool: Item is contained.
5651:
5652: Example:
5653: +---+---+---+---+---+---+---+---+---+---+---+---+
5654: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
5655: +===+===+===+===+===+===+===+===+===+===+===+===+
5656: | |[A | B | C]| |[1 | 2 | 3]| |[x | y | z]|
5657: +---+---+---+---+---+---+---+---+---+---+---+---+
5658:
5659: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'123'], [9, b'xyz']])
5660: >>> b'23' in memory
5661: True
5662: >>> ord('y') in memory
5663: True
5664: >>> b'$' in memory
5665: False
5666: """
5667:
+5668: return Memory_Contains(self._, item)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Contains(__pyx_v_self->_, __pyx_v_item); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 5668, __pyx_L1_error)
__pyx_r = __pyx_t_1;
goto __pyx_L0;
5669:
+5670: def __copy__(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_11__copy__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_10__copy__[] = "Memory.__copy__(self: Memory) -> Memory\nCreates a shallow copy.\n\n Note:\n The Cython implementation actually creates a deep copy.\n\n Returns:\n :obj:`Memory`: Shallow copy.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_11__copy__ = {"__copy__", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_11__copy__, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_10__copy__}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_11__copy__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__copy__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_10__copy__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_10__copy__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { Memory_ *__pyx_v_memory_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__copy__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.__copy__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__75 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_memory_2, __pyx_n_s_memory); if (unlikely(!__pyx_tuple__75)) __PYX_ERR(0, 5670, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__75); __Pyx_GIVEREF(__pyx_tuple__75); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5670, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 5670, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 5670, __pyx_L1_error) __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_11__copy__, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory___copy, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__76)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5670, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_copy_2, __pyx_t_1) < 0) __PYX_ERR(0, 5670, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__76 = (PyObject*)__Pyx_PyCode_New(1, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__75, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_copy_2, 5670, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__76)) __PYX_ERR(0, 5670, __pyx_L1_error)
5671: self: Memory,
5672: ) -> Memory:
5673: r"""Creates a shallow copy.
5674:
5675: Note:
5676: The Cython implementation actually creates a deep copy.
5677:
5678: Returns:
5679: :obj:`Memory`: Shallow copy.
5680: """
5681: cdef:
+5682: Memory_* memory_ = Memory_Copy(self._)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Copy(__pyx_v_self->_); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 5682, __pyx_L1_error)
__pyx_v_memory_ = __pyx_t_1;
+5683: Memory memory = Memory_AsObject(memory_)
__pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_AsObject(__pyx_v_memory_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5683, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_2); __pyx_t_2 = 0;
5684:
+5685: return memory
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = __pyx_v_memory; goto __pyx_L0;
5686:
+5687: def __dealloc__(self):
/* Python wrapper */ static void __pyx_pw_11cbytesparse_1c_6Memory_13__dealloc__(PyObject *__pyx_v_self); /*proto*/ static void __pyx_pw_11cbytesparse_1c_6Memory_13__dealloc__(PyObject *__pyx_v_self) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__dealloc__ (wrapper)", 0); __pyx_pf_11cbytesparse_1c_6Memory_12__dealloc__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); } static void __pyx_pf_11cbytesparse_1c_6Memory_12__dealloc__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__dealloc__", 0); /* … */ /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __Pyx_WriteUnraisable("cbytesparse.c.Memory.__dealloc__", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0); __pyx_L0:; __Pyx_RefNannyFinishContext(); }
5688: r"""Cython deallocation method."""
+5689: self._ = Memory_Free(self._)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_self->_); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 5689, __pyx_L1_error) __pyx_v_self->_ = __pyx_t_1;
5690:
+5691: def __deepcopy__(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_15__deepcopy__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_14__deepcopy__[] = "Memory.__deepcopy__(self: Memory) -> Memory\nCreates a deep copy.\n\n Returns:\n :obj:`Memory`: Deep copy.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_15__deepcopy__ = {"__deepcopy__", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_15__deepcopy__, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_14__deepcopy__}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_15__deepcopy__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__deepcopy__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_14__deepcopy__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_14__deepcopy__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { Memory_ *__pyx_v_memory_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__deepcopy__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.__deepcopy__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__77 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_memory_2, __pyx_n_s_memory); if (unlikely(!__pyx_tuple__77)) __PYX_ERR(0, 5691, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__77); __Pyx_GIVEREF(__pyx_tuple__77); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5691, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 5691, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 5691, __pyx_L1_error) __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_15__deepcopy__, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory___deepcopy, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__78)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5691, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_deepcopy, __pyx_t_2) < 0) __PYX_ERR(0, 5691, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__78 = (PyObject*)__Pyx_PyCode_New(1, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__77, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_deepcopy, 5691, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__78)) __PYX_ERR(0, 5691, __pyx_L1_error)
5692: self: Memory,
5693: ) -> Memory:
5694: r"""Creates a deep copy.
5695:
5696: Returns:
5697: :obj:`Memory`: Deep copy.
5698: """
5699: cdef:
+5700: Memory_* memory_ = Memory_Copy(self._)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Copy(__pyx_v_self->_); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 5700, __pyx_L1_error)
__pyx_v_memory_ = __pyx_t_1;
+5701: Memory memory = Memory_AsObject(memory_)
__pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_AsObject(__pyx_v_memory_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5701, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_2); __pyx_t_2 = 0;
5702:
+5703: return memory
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = __pyx_v_memory; goto __pyx_L0;
5704:
+5705: def __delitem__(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_17__delitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_16__delitem__[] = "Deletes data.\n\n Arguments:\n key (slice or int):\n Deletion range or address.\n\n Note:\n This method is not optimized for a :class:`slice` where its `step`\n is an integer greater than 1.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C | y | z]| | | | | | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> del memory[4:9]\n >>> memory._blocks\n [[1, b'ABCyz']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C | D]| |[$]| |[x | z]| | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | D]| |[$]| |[x | z]| | | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | D]| | |[x]| | | | | | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> del memory[9]\n >>> memory._blocks\n [[1, b'ABCD'], [6, b'$'], [8, b'xz']]\n >>> del memory[3]\n >>> memory._blocks\n [[1, b'ABD'], [5, b'$'], [7, b'xz']]\n >>> del memory[2:10:3]\n >>> memory._blocks\n "" [[1, b'AD'], [5, b'x']]\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_16__delitem__; #endif static int __pyx_pw_11cbytesparse_1c_6Memory_17__delitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__delitem__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_16__delitem__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_key)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_16__delitem__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_key) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__delitem__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.__delitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5706: self: Memory,
5707: key: Union[Address, slice],
5708: ) -> None:
5709: r"""Deletes data.
5710:
5711: Arguments:
5712: key (slice or int):
5713: Deletion range or address.
5714:
5715: Note:
5716: This method is not optimized for a :class:`slice` where its `step`
5717: is an integer greater than 1.
5718:
5719: Examples:
5720: +---+---+---+---+---+---+---+---+---+---+---+---+
5721: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
5722: +===+===+===+===+===+===+===+===+===+===+===+===+
5723: | |[A | B | C | D]| |[$]| |[x | y | z]| |
5724: +---+---+---+---+---+---+---+---+---+---+---+---+
5725: | |[A | B | C | y | z]| | | | | | |
5726: +---+---+---+---+---+---+---+---+---+---+---+---+
5727:
5728: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
5729: >>> del memory[4:9]
5730: >>> memory._blocks
5731: [[1, b'ABCyz']]
5732:
5733: ~~~
5734:
5735: +---+---+---+---+---+---+---+---+---+---+---+---+
5736: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
5737: +===+===+===+===+===+===+===+===+===+===+===+===+
5738: | |[A | B | C | D]| |[$]| |[x | y | z]| |
5739: +---+---+---+---+---+---+---+---+---+---+---+---+
5740: | |[A | B | C | D]| |[$]| |[x | z]| | |
5741: +---+---+---+---+---+---+---+---+---+---+---+---+
5742: | |[A | B | D]| |[$]| |[x | z]| | | |
5743: +---+---+---+---+---+---+---+---+---+---+---+---+
5744: | |[A | D]| | |[x]| | | | | | |
5745: +---+---+---+---+---+---+---+---+---+---+---+---+
5746:
5747: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
5748: >>> del memory[9]
5749: >>> memory._blocks
5750: [[1, b'ABCD'], [6, b'$'], [8, b'xz']]
5751: >>> del memory[3]
5752: >>> memory._blocks
5753: [[1, b'ABD'], [5, b'$'], [7, b'xz']]
5754: >>> del memory[2:10:3]
5755: >>> memory._blocks
5756: [[1, b'AD'], [5, b'x']]
5757: """
5758:
+5759: Memory_DelItem(self._, key)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_DelItem(__pyx_v_self->_, __pyx_v_key); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 5759, __pyx_L1_error)
5760:
+5761: def __eq__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_19__eq__(PyObject *__pyx_v_self, PyObject *__pyx_v_other); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_18__eq__[] = "Equality comparison.\n\n Arguments:\n other (Memory):\n Data to compare with `self`.\n\n If it is a :obj:`Memory`, all of its blocks must match.\n\n If it is a :obj:`bytes`, a :obj:`bytearray`, or a\n :obj:`memoryview`, it is expected to match the first and only\n stored block.\n\n Otherwise, it must match the first and only stored block,\n via iteration over the stored values.\n\n Returns:\n bool: `self` is equal to `other`.\n\n Examples:\n >>> data = b'Hello, World!'\n >>> memory = Memory.from_bytes(data)\n >>> memory == data\n True\n >>> memory.shift(1)\n >>> memory == data\n True\n\n >>> data = b'Hello, World!'\n >>> memory = Memory.from_bytes(data)\n >>> memory == list(data)\n True\n >>> memory.shift(1)\n >>> memory == list(data)\n True\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_18__eq__; #endif static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_19__eq__(PyObject *__pyx_v_self, PyObject *__pyx_v_other) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__eq__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_18__eq__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_other)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_18__eq__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_other) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__eq__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.__eq__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5762: self: Memory,
5763: other: Any,
5764: ) -> bool:
5765: r"""Equality comparison.
5766:
5767: Arguments:
5768: other (Memory):
5769: Data to compare with `self`.
5770:
5771: If it is a :obj:`Memory`, all of its blocks must match.
5772:
5773: If it is a :obj:`bytes`, a :obj:`bytearray`, or a
5774: :obj:`memoryview`, it is expected to match the first and only
5775: stored block.
5776:
5777: Otherwise, it must match the first and only stored block,
5778: via iteration over the stored values.
5779:
5780: Returns:
5781: bool: `self` is equal to `other`.
5782:
5783: Examples:
5784: >>> data = b'Hello, World!'
5785: >>> memory = Memory.from_bytes(data)
5786: >>> memory == data
5787: True
5788: >>> memory.shift(1)
5789: >>> memory == data
5790: True
5791:
5792: >>> data = b'Hello, World!'
5793: >>> memory = Memory.from_bytes(data)
5794: >>> memory == list(data)
5795: True
5796: >>> memory.shift(1)
5797: >>> memory == list(data)
5798: True
5799: """
5800:
+5801: return Memory_Eq(self._, other)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Eq(__pyx_v_self->_, __pyx_v_other); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 5801, __pyx_L1_error) __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5801, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
5802:
+5803: def __getitem__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_21__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_20__getitem__[] = "Gets data.\n\n Arguments:\n key (slice or int):\n Selection range or address.\n If it is a :obj:`slice` with bytes-like `step`, the latter is\n interpreted as the filling pattern.\n\n Returns:\n items: Items from the requested range.\n\n Note:\n This method is not optimized for a :class:`slice` where its `step`\n is an integer greater than 1.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|\n +===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]|\n +---+---+---+---+---+---+---+---+---+---+---+\n | | 65| 66| 67| 68| | 36| |120|121|122|\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> memory[9] # -> ord('y') = 121\n 121\n >>> memory[:3]._blocks\n [[1, b'AB']]\n >>> memory[3:10]._blocks\n [[3, b'CD'], [6, b'$'], [8, b'xy']]\n >>> bytes(memory[3:10:b'.'])\n b'CD.$.xy'\n >>> memory[memory.endex]\n None\n >>> bytes(memory[3:10:3])\n b'C$y'\n >>> memory[3:10:2]._blocks\n [[3, b'C'], [6, b'y']]\n >>> bytes(memory[3:10:2])\n Traceback (most recent call last):\n ...\n ValueError: non-contiguous data within range\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_20__getitem__; #endif static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_21__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_20__getitem__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_key)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_20__getitem__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_key) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.__getitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5804: self: Memory,
5805: key: Union[Address, slice],
5806: ) -> Any:
5807: r"""Gets data.
5808:
5809: Arguments:
5810: key (slice or int):
5811: Selection range or address.
5812: If it is a :obj:`slice` with bytes-like `step`, the latter is
5813: interpreted as the filling pattern.
5814:
5815: Returns:
5816: items: Items from the requested range.
5817:
5818: Note:
5819: This method is not optimized for a :class:`slice` where its `step`
5820: is an integer greater than 1.
5821:
5822: Example:
5823: +---+---+---+---+---+---+---+---+---+---+---+
5824: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|
5825: +===+===+===+===+===+===+===+===+===+===+===+
5826: | |[A | B | C | D]| |[$]| |[x | y | z]|
5827: +---+---+---+---+---+---+---+---+---+---+---+
5828: | | 65| 66| 67| 68| | 36| |120|121|122|
5829: +---+---+---+---+---+---+---+---+---+---+---+
5830:
5831: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
5832: >>> memory[9] # -> ord('y') = 121
5833: 121
5834: >>> memory[:3]._blocks
5835: [[1, b'AB']]
5836: >>> memory[3:10]._blocks
5837: [[3, b'CD'], [6, b'$'], [8, b'xy']]
5838: >>> bytes(memory[3:10:b'.'])
5839: b'CD.$.xy'
5840: >>> memory[memory.endex]
5841: None
5842: >>> bytes(memory[3:10:3])
5843: b'C$y'
5844: >>> memory[3:10:2]._blocks
5845: [[3, b'C'], [6, b'y']]
5846: >>> bytes(memory[3:10:2])
5847: Traceback (most recent call last):
5848: ...
5849: ValueError: non-contiguous data within range
5850: """
5851:
+5852: return Memory_GetItem(self._, key)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_GetItem(__pyx_v_self->_, __pyx_v_key); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5852, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
5853:
+5854: def __iadd__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_23__iadd__(PyObject *__pyx_v_self, PyObject *__pyx_v_value); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_23__iadd__(PyObject *__pyx_v_self, PyObject *__pyx_v_value) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iadd__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_22__iadd__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_value)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_22__iadd__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_value) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iadd__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.__iadd__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5855: self: Memory,
5856: value: Union[AnyBytes, Memory],
5857: ) -> Memory:
5858:
+5859: Memory_IAdd(self._, value)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_IAdd(__pyx_v_self->_, __pyx_v_value); if (unlikely(__pyx_t_1 == ((Memory_ *)NULL))) __PYX_ERR(0, 5859, __pyx_L1_error)
+5860: return self
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_self)); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0;
5861:
+5862: def __imul__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_25__imul__(PyObject *__pyx_v_self, PyObject *__pyx_v_times); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_25__imul__(PyObject *__pyx_v_self, PyObject *__pyx_v_times) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__imul__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_24__imul__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_times)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_24__imul__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_times) { addr_t __pyx_v_times_; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__imul__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.__imul__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5863: self: Memory,
5864: times: int,
5865: ) -> Memory:
5866: cdef:
+5867: addr_t times_ = 0 if times < 0 else <addr_t>times
__pyx_t_2 = PyObject_RichCompare(__pyx_v_times, __pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5867, __pyx_L1_error) __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) __PYX_ERR(0, 5867, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_3) { __pyx_t_1 = 0; } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_times); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 5867, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_4); } __pyx_v_times_ = __pyx_t_1;
5868:
+5869: Memory_IMul(self._, times_)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_IMul(__pyx_v_self->_, __pyx_v_times_); if (unlikely(__pyx_t_5 == ((Memory_ *)NULL))) __PYX_ERR(0, 5869, __pyx_L1_error)
+5870: return self
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_self)); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0;
5871:
+5872: def __init__(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_27__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static int __pyx_pw_11cbytesparse_1c_6Memory_27__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__init__ (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_26__init__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__init__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1); __Pyx_AddTraceback("cbytesparse.c.Memory.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_30generator(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */
5873: self: Memory,
+5874: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None);
+5875: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__init__") < 0)) __PYX_ERR(0, 5872, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__init__", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 5872, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return -1; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_26__init__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex);
5876: ):
5877:
+5878: self._ = Memory_Create(NULL, None, None, None, start, endex, False, False)
__pyx_t_1 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(Py_None, 0); if (unlikely(!__pyx_t_1.memview)) __PYX_ERR(0, 5878, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Create(NULL, __pyx_t_1, Py_None, Py_None, __pyx_v_start, __pyx_v_endex, 0, 0); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL))) __PYX_ERR(0, 5878, __pyx_L1_error) __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1); __pyx_t_1.memview = NULL; __pyx_t_1.data = NULL; __pyx_v_self->_ = __pyx_t_2;
5879:
+5880: def __iter__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_29__iter__(PyObject *__pyx_v_self); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_28__iter__[] = "Iterates over values.\n\n Iterates over values between :attr:`start` and :attr:`endex`.\n\n Yields:\n int: Value as byte integer, or ``None``.\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_28__iter__; #endif static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_29__iter__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iter__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_28__iter__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_28__iter__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct____iter__ *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iter__", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct____iter__ *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct____iter__(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct____iter__, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct____iter__ *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 5880, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_30generator, NULL, (PyObject *) __pyx_cur_scope, __pyx_n_s_iter, __pyx_n_s_Memory___iter, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 5880, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.__iter__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_30generator(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iter__", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 5880, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("__iter__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct____iter__ { PyObject_HEAD struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; };
5881: self: Memory,
5882: ) -> Iterator[Optional[Value]]:
5883: r"""Iterates over values.
5884:
5885: Iterates over values between :attr:`start` and :attr:`endex`.
5886:
5887: Yields:
5888: int: Value as byte integer, or ``None``.
5889: """
5890:
+5891: yield from self.values()
__pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_cur_scope->__pyx_v_self), __pyx_n_s_values); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5891, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_2, function); } } __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5891, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_r = __Pyx_Generator_Yield_From(__pyx_generator, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_XGOTREF(__pyx_r); if (likely(__pyx_r)) { __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L4_resume_from_yield_from:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 5891, __pyx_L1_error) } else { PyObject* exc_type = __Pyx_PyErr_Occurred(); if (exc_type) { if (likely(exc_type == PyExc_StopIteration || (exc_type != PyExc_GeneratorExit && __Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration)))) PyErr_Clear(); else __PYX_ERR(0, 5891, __pyx_L1_error) } } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
5892:
+5893: def __len__(
/* Python wrapper */ static Py_ssize_t __pyx_pw_11cbytesparse_1c_6Memory_32__len__(PyObject *__pyx_v_self); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_31__len__[] = "Actual length.\n\n Computes the actual length of the stored items, i.e.\n (:attr:`endex` - :attr:`start`).\n This will consider any trimmings being active.\n\n Returns:\n int: Memory length.\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_31__len__; #endif static Py_ssize_t __pyx_pw_11cbytesparse_1c_6Memory_32__len__(PyObject *__pyx_v_self) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__len__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_31__len__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static Py_ssize_t __pyx_pf_11cbytesparse_1c_6Memory_31__len__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__len__", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5894: self: Memory,
5895: ) -> Address:
5896: r"""Actual length.
5897:
5898: Computes the actual length of the stored items, i.e.
5899: (:attr:`endex` - :attr:`start`).
5900: This will consider any trimmings being active.
5901:
5902: Returns:
5903: int: Memory length.
5904: """
5905:
+5906: return Memory_Length(self._)
__pyx_r = __pyx_f_11cbytesparse_1c_Memory_Length(__pyx_v_self->_); goto __pyx_L0;
5907:
+5908: def __mul__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_34__mul__(PyObject *__pyx_v_self, PyObject *__pyx_v_times); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_34__mul__(PyObject *__pyx_v_self, PyObject *__pyx_v_times) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__mul__ (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_self), __pyx_ptype_11cbytesparse_1c_Memory, 1, "self", 0))) __PYX_ERR(0, 5909, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_33__mul__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_times)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_33__mul__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_times) { addr_t __pyx_v_times_; Memory_ *__pyx_v_memory_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__mul__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.__mul__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
5909: self: Memory,
5910: times: int,
5911: ) -> Memory:
5912: cdef:
+5913: addr_t times_ = 0 if times < 0 else <addr_t>times
__pyx_t_2 = PyObject_RichCompare(__pyx_v_times, __pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5913, __pyx_L1_error) __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) __PYX_ERR(0, 5913, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_3) { __pyx_t_1 = 0; } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_times); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 5913, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_4); } __pyx_v_times_ = __pyx_t_1;
+5914: Memory_* memory_ = Memory_Mul(self._, times_)
__pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_Mul(__pyx_v_self->_, __pyx_v_times_); if (unlikely(__pyx_t_5 == ((Memory_ *)NULL))) __PYX_ERR(0, 5914, __pyx_L1_error)
__pyx_v_memory_ = __pyx_t_5;
+5915: Memory memory = Memory_AsObject(memory_)
__pyx_t_2 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_AsObject(__pyx_v_memory_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5915, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_2); __pyx_t_2 = 0;
5916:
+5917: return memory
__Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = ((PyObject *)__pyx_v_memory); goto __pyx_L0;
5918:
+5919: def __repr__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_36__repr__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_36__repr__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__repr__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_35__repr__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_35__repr__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__repr__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.__repr__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_39generator1(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */
5920: self: Memory,
5921: ) -> str:
5922:
+5923: return f'<{type(self).__name__}[0x{self.start:X}:0x{self.endex:X}]@0x{id(self):X}>'
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyTuple_New(9); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = 0; __pyx_t_3 = 127; __Pyx_INCREF(__pyx_kp_u__10); __pyx_t_2 += 1; __Pyx_GIVEREF(__pyx_kp_u__10); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_kp_u__10); __pyx_t_4 = __Pyx_PyObject_GetAttrStr(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))), __pyx_n_s_name); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_5 = __Pyx_PyObject_FormatSimple(__pyx_t_4, __pyx_empty_unicode); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_3 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_5) > __pyx_t_3) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_5) : __pyx_t_3; __pyx_t_2 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_5); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_5); __pyx_t_5 = 0; __Pyx_INCREF(__pyx_kp_u_0x); __pyx_t_2 += 3; __Pyx_GIVEREF(__pyx_kp_u_0x); PyTuple_SET_ITEM(__pyx_t_1, 2, __pyx_kp_u_0x); __pyx_t_5 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_start); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_4 = __Pyx_PyObject_Format(__pyx_t_5, __pyx_n_u_X); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_3 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_3) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_3; __pyx_t_2 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_1, 3, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u_0x_2); __pyx_t_2 += 3; __Pyx_GIVEREF(__pyx_kp_u_0x_2); PyTuple_SET_ITEM(__pyx_t_1, 4, __pyx_kp_u_0x_2); __pyx_t_4 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_endex); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_5 = __Pyx_PyObject_Format(__pyx_t_4, __pyx_n_u_X); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_3 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_5) > __pyx_t_3) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_5) : __pyx_t_3; __pyx_t_2 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_5); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_1, 5, __pyx_t_5); __pyx_t_5 = 0; __Pyx_INCREF(__pyx_kp_u_0x_3); __pyx_t_2 += 4; __Pyx_GIVEREF(__pyx_kp_u_0x_3); PyTuple_SET_ITEM(__pyx_t_1, 6, __pyx_kp_u_0x_3); __pyx_t_5 = __Pyx_PyObject_CallOneArg(__pyx_builtin_id, ((PyObject *)__pyx_v_self)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_4 = __Pyx_PyObject_Format(__pyx_t_5, __pyx_n_u_X); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_3 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_3) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_3; __pyx_t_2 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_1, 7, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u__11); __pyx_t_2 += 1; __Pyx_GIVEREF(__pyx_kp_u__11); PyTuple_SET_ITEM(__pyx_t_1, 8, __pyx_kp_u__11); __pyx_t_4 = __Pyx_PyUnicode_Join(__pyx_t_1, 9, __pyx_t_2, __pyx_t_3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 5923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0;
5924:
+5925: def __reversed__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_38__reversed__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_37__reversed__[] = "Memory.__reversed__(self: Memory) -> Iterator[Optional[Value]]\nIterates over values, reversed order.\n\n Iterates over values between :attr:`start` and :attr:`endex`, in\n reversed order.\n\n Yields:\n int: Value as byte integer, or ``None``.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_38__reversed__ = {"__reversed__", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_38__reversed__, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_37__reversed__}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_38__reversed__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__reversed__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_37__reversed__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_37__reversed__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_1___reversed__ *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__reversed__", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_1___reversed__ *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_1___reversed__(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_1___reversed__, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_1___reversed__ *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 5925, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_39generator1, __pyx_codeobj__25, (PyObject *) __pyx_cur_scope, __pyx_n_s_reversed, __pyx_n_s_Memory___reversed, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 5925, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.__reversed__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_39generator1(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__reversed__", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 5925, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("__reversed__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__79 = PyTuple_Pack(1, __pyx_n_s_self); if (unlikely(!__pyx_tuple__79)) __PYX_ERR(0, 5925, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__79); __Pyx_GIVEREF(__pyx_tuple__79); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5925, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 5925, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_38__reversed__, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory___reversed, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__25)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 5925, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_reversed, __pyx_t_6) < 0) __PYX_ERR(0, 5925, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__25 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__79, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_reversed, 5925, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__25)) __PYX_ERR(0, 5925, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_1___reversed__ { PyObject_HEAD struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; };
5926: self: Memory,
+5927: ) -> Iterator[Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5927, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 5927, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 5927, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 5927, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 5927, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_6) < 0) __PYX_ERR(0, 5925, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
5928: r"""Iterates over values, reversed order.
5929:
5930: Iterates over values between :attr:`start` and :attr:`endex`, in
5931: reversed order.
5932:
5933: Yields:
5934: int: Value as byte integer, or ``None``.
5935: """
5936:
+5937: yield from self.rvalues()
__pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_cur_scope->__pyx_v_self), __pyx_n_s_rvalues); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 5937, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = NULL; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_2, function); } } __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 5937, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_r = __Pyx_Generator_Yield_From(__pyx_generator, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_XGOTREF(__pyx_r); if (likely(__pyx_r)) { __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L4_resume_from_yield_from:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 5937, __pyx_L1_error) } else { PyObject* exc_type = __Pyx_PyErr_Occurred(); if (exc_type) { if (likely(exc_type == PyExc_StopIteration || (exc_type != PyExc_GeneratorExit && __Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration)))) PyErr_Clear(); else __PYX_ERR(0, 5937, __pyx_L1_error) } } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
5938:
+5939: def __setitem__(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_41__setitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key, PyObject *__pyx_v_value); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_40__setitem__[] = "Sets data.\n\n Arguments:\n key (slice or int):\n Selection range or address.\n\n value (items):\n Items to write at the selection address.\n If `value` is null, the range is cleared.\n\n Note:\n This method is not optimized for a :class:`slice` where its `step`\n is an integer greater than 1.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+\n | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n | |[A]| | | | |[y | z]| |\n +---+---+---+---+---+---+---+---+---+\n | |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n | |[A]| |[C]| | | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n | |[A | 1 | C]| |[2 | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])\n >>> memory[7:10] = None\n >>> memory._blocks\n [[5, b'AB'], [10, b'yz']]\n >>> memory[7] = b'C'\n >>> memory[9] = b'x'\n >>> memory._blocks == [[5, b'ABC'], [9, b'xyz']]\n True\n >>> memory[6:12:3] = None\n >>> memory._blocks\n [[5, b'A'], [7, b'C'], [10, b'yz']]\n >>> memory[6:13:3] = b'123'\n >>> memory._blocks\n [[5, b'A1C'], [9, b'2yz3']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | | | | | |[A | B | C]| |[x | y | z]|\n +---+---+---+---+---+---+---+---+---+---+---+---+\n |[$]""| |[A | B | C]| |[x | y | z]| | | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n |[$]| |[A | B | 4 | 5 | 6 | 7 | 8 | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n |[$]| |[A | B | 4 | 5 | < | > | 8 | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])\n >>> memory[0:4] = b'$'\n >>> memory._blocks\n [[0, b'$'], [2, b'ABC'], [6, b'xyz']]\n >>> memory[4:7] = b'45678'\n >>> memory._blocks\n [[0, b'$'], [2, b'AB45678yz']]\n >>> memory[6:8] = b'<>'\n >>> memory._blocks\n [[0, b'$'], [2, b'AB45<>8yz']]\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_40__setitem__; #endif static int __pyx_pw_11cbytesparse_1c_6Memory_41__setitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key, PyObject *__pyx_v_value) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__setitem__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_40__setitem__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_key), ((PyObject *)__pyx_v_value)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_40__setitem__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_key, PyObject *__pyx_v_value) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__setitem__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.__setitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
5940: self: Memory,
5941: key: Union[Address, slice],
5942: value: Optional[Union[AnyBytes, Value]],
5943: ) -> None:
5944: r"""Sets data.
5945:
5946: Arguments:
5947: key (slice or int):
5948: Selection range or address.
5949:
5950: value (items):
5951: Items to write at the selection address.
5952: If `value` is null, the range is cleared.
5953:
5954: Note:
5955: This method is not optimized for a :class:`slice` where its `step`
5956: is an integer greater than 1.
5957:
5958: Examples:
5959: +---+---+---+---+---+---+---+---+---+
5960: | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
5961: +===+===+===+===+===+===+===+===+===+
5962: | |[A | B | C]| |[x | y | z]| |
5963: +---+---+---+---+---+---+---+---+---+
5964: | |[A]| | | | |[y | z]| |
5965: +---+---+---+---+---+---+---+---+---+
5966: | |[A | B | C]| |[x | y | z]| |
5967: +---+---+---+---+---+---+---+---+---+
5968: | |[A]| |[C]| | | y | z]| |
5969: +---+---+---+---+---+---+---+---+---+
5970: | |[A | 1 | C]| |[2 | y | z]| |
5971: +---+---+---+---+---+---+---+---+---+
5972:
5973: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])
5974: >>> memory[7:10] = None
5975: >>> memory._blocks
5976: [[5, b'AB'], [10, b'yz']]
5977: >>> memory[7] = b'C'
5978: >>> memory[9] = b'x'
5979: >>> memory._blocks == [[5, b'ABC'], [9, b'xyz']]
5980: True
5981: >>> memory[6:12:3] = None
5982: >>> memory._blocks
5983: [[5, b'A'], [7, b'C'], [10, b'yz']]
5984: >>> memory[6:13:3] = b'123'
5985: >>> memory._blocks
5986: [[5, b'A1C'], [9, b'2yz3']]
5987:
5988: ~~~
5989:
5990: +---+---+---+---+---+---+---+---+---+---+---+---+
5991: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
5992: +===+===+===+===+===+===+===+===+===+===+===+===+
5993: | | | | | |[A | B | C]| |[x | y | z]|
5994: +---+---+---+---+---+---+---+---+---+---+---+---+
5995: |[$]| |[A | B | C]| |[x | y | z]| | | |
5996: +---+---+---+---+---+---+---+---+---+---+---+---+
5997: |[$]| |[A | B | 4 | 5 | 6 | 7 | 8 | y | z]| |
5998: +---+---+---+---+---+---+---+---+---+---+---+---+
5999: |[$]| |[A | B | 4 | 5 | < | > | 8 | y | z]| |
6000: +---+---+---+---+---+---+---+---+---+---+---+---+
6001:
6002: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])
6003: >>> memory[0:4] = b'$'
6004: >>> memory._blocks
6005: [[0, b'$'], [2, b'ABC'], [6, b'xyz']]
6006: >>> memory[4:7] = b'45678'
6007: >>> memory._blocks
6008: [[0, b'$'], [2, b'AB45678yz']]
6009: >>> memory[6:8] = b'<>'
6010: >>> memory._blocks
6011: [[0, b'$'], [2, b'AB45<>8yz']]
6012: """
6013:
+6014: Memory_SetItem(self._, key, value)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_SetItem(__pyx_v_self->_, __pyx_v_key, __pyx_v_value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6014, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
6015:
+6016: def __str__(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_43__str__(PyObject *__pyx_v_self); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_42__str__[] = "String representation.\n\n If :attr:`content_size` is lesser than ``STR_MAX_CONTENT_SIZE``, then\n the memory is represented as a list of blocks.\n\n If exceeding, it is equivalent to :meth:`__repr__`.\n\n\n Returns:\n str: String representation.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|\n +===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [7, b'xyz']])\n >>> str(memory)\n <[[1, b'ABC'], [7, b'xyz']]>\n "; #if CYTHON_COMPILING_IN_CPYTHON struct wrapperbase __pyx_wrapperbase_11cbytesparse_1c_6Memory_42__str__; #endif static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_43__str__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__str__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_42__str__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_42__str__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { Memory_ const *__pyx_v_memory; addr_t __pyx_v_size; Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; PyObject *__pyx_v_inner_list = 0; PyObject *__pyx_v_trim_start = NULL; PyObject *__pyx_v_trim_endex = NULL; PyObject *__pyx_v_inner = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__str__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory.__str__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_inner_list); __Pyx_XDECREF(__pyx_v_trim_start); __Pyx_XDECREF(__pyx_v_trim_endex); __Pyx_XDECREF(__pyx_v_inner); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6017: self: Memory,
6018: ) -> str:
6019: r"""String representation.
6020:
6021: If :attr:`content_size` is lesser than ``STR_MAX_CONTENT_SIZE``, then
6022: the memory is represented as a list of blocks.
6023:
6024: If exceeding, it is equivalent to :meth:`__repr__`.
6025:
6026:
6027: Returns:
6028: str: String representation.
6029:
6030: Example:
6031: +---+---+---+---+---+---+---+---+---+---+---+
6032: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|
6033: +===+===+===+===+===+===+===+===+===+===+===+
6034: | |[A | B | C]| | | |[x | y | z]| |
6035: +---+---+---+---+---+---+---+---+---+---+---+
6036:
6037: >>> memory = Memory.from_blocks([[1, b'ABC'], [7, b'xyz']])
6038: >>> str(memory)
6039: <[[1, b'ABC'], [7, b'xyz']]>
6040: """
6041: cdef:
+6042: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+6043: addr_t size = Memory_ContentSize(memory)
__pyx_v_size = __pyx_f_11cbytesparse_1c_Memory_ContentSize(__pyx_v_memory);
6044: addr_t start
6045: addr_t endex
6046: const Rack_* blocks
6047: size_t block_index
6048: const Block_* block
6049: list inner_list
6050:
+6051: if size < STR_MAX_CONTENT_SIZE:
__pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6051, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_STR_MAX_CONTENT_SIZE); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6051, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = PyObject_RichCompare(__pyx_t_2, __pyx_t_3, Py_LT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6051, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) __PYX_ERR(0, 6051, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* … */ }
+6052: trim_start = f'{memory.trim_start}, ' if memory.trim_start_ else ''
if ((__pyx_v_memory->trim_start_ != 0)) { __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_memory->trim_start); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6052, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = __Pyx_PyObject_FormatSimple(__pyx_t_3, __pyx_empty_unicode); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6052, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_PyUnicode_Concat(__pyx_t_2, __pyx_kp_u__26); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6052, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_4 = __pyx_t_3; __pyx_t_3 = 0; } else { __Pyx_INCREF(__pyx_kp_u__12); __pyx_t_4 = __pyx_kp_u__12; } __pyx_v_trim_start = ((PyObject*)__pyx_t_4); __pyx_t_4 = 0;
+6053: trim_endex = f', {memory.trim_endex}' if memory.trim_endex_ else ''
if ((__pyx_v_memory->trim_endex_ != 0)) { __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_memory->trim_endex); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6053, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = __Pyx_PyObject_FormatSimple(__pyx_t_3, __pyx_empty_unicode); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6053, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_PyUnicode_Concat(__pyx_kp_u__26, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6053, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_4 = __pyx_t_3; __pyx_t_3 = 0; } else { __Pyx_INCREF(__pyx_kp_u__12); __pyx_t_4 = __pyx_kp_u__12; } __pyx_v_trim_endex = ((PyObject*)__pyx_t_4); __pyx_t_4 = 0;
6054:
+6055: inner_list = []
__pyx_t_4 = PyList_New(0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6055, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_v_inner_list = ((PyObject*)__pyx_t_4); __pyx_t_4 = 0;
+6056: blocks = memory.blocks
__pyx_t_6 = __pyx_v_memory->blocks; __pyx_v_blocks = __pyx_t_6;
6057:
+6058: for block_index in range(Rack_Length(blocks)):
__pyx_t_7 = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks); __pyx_t_8 = __pyx_t_7; for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_8; __pyx_t_9+=1) { __pyx_v_block_index = __pyx_t_9;
+6059: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+6060: inner_list.append(f'[{Block_Start(block)}, {Block_Bytes(block)!r}]')
__pyx_t_4 = PyTuple_New(5); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_10 = 0; __pyx_t_11 = 127; __Pyx_INCREF(__pyx_kp_u__27); __pyx_t_10 += 1; __Pyx_GIVEREF(__pyx_kp_u__27); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_kp_u__27); __pyx_t_3 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = __Pyx_PyObject_FormatSimple(__pyx_t_3, __pyx_empty_unicode); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_11 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_2) > __pyx_t_11) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_2) : __pyx_t_11; __pyx_t_10 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2); __pyx_t_2 = 0; __Pyx_INCREF(__pyx_kp_u__26); __pyx_t_10 += 2; __Pyx_GIVEREF(__pyx_kp_u__26); PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_kp_u__26); __pyx_t_2 = __pyx_f_11cbytesparse_1c_Block_Bytes(__pyx_v_block); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_PyObject_FormatSimpleAndDecref(PyObject_Repr(__pyx_t_2), __pyx_empty_unicode); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_11 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3) > __pyx_t_11) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_3) : __pyx_t_11; __pyx_t_10 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_4, 3, __pyx_t_3); __pyx_t_3 = 0; __Pyx_INCREF(__pyx_kp_u__28); __pyx_t_10 += 1; __Pyx_GIVEREF(__pyx_kp_u__28); PyTuple_SET_ITEM(__pyx_t_4, 4, __pyx_kp_u__28); __pyx_t_3 = __Pyx_PyUnicode_Join(__pyx_t_4, 5, __pyx_t_10, __pyx_t_11); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_12 = __Pyx_PyList_Append(__pyx_v_inner_list, __pyx_t_3); if (unlikely(__pyx_t_12 == ((int)-1))) __PYX_ERR(0, 6060, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; }
6061:
+6062: inner = ', '.join(inner_list)
__pyx_t_3 = PyUnicode_Join(__pyx_kp_u__26, __pyx_v_inner_list); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6062, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_v_inner = ((PyObject*)__pyx_t_3); __pyx_t_3 = 0;
6063:
+6064: return f'<{trim_start}[{inner}]{trim_endex}>'
__Pyx_XDECREF(__pyx_r); __pyx_t_3 = PyTuple_New(7); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6064, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_10 = 0; __pyx_t_11 = 127; __Pyx_INCREF(__pyx_kp_u__10); __pyx_t_10 += 1; __Pyx_GIVEREF(__pyx_kp_u__10); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_kp_u__10); __pyx_t_4 = __Pyx_PyUnicode_Unicode(__pyx_v_trim_start); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6064, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_11 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_11) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_11; __pyx_t_10 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u__27); __pyx_t_10 += 1; __Pyx_GIVEREF(__pyx_kp_u__27); PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_kp_u__27); __pyx_t_4 = __Pyx_PyUnicode_Unicode(__pyx_v_inner); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6064, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_11 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_11) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_11; __pyx_t_10 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_3, 3, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u__28); __pyx_t_10 += 1; __Pyx_GIVEREF(__pyx_kp_u__28); PyTuple_SET_ITEM(__pyx_t_3, 4, __pyx_kp_u__28); __pyx_t_4 = __Pyx_PyUnicode_Unicode(__pyx_v_trim_endex); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6064, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_11 = (__Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) > __pyx_t_11) ? __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_4) : __pyx_t_11; __pyx_t_10 += __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_3, 5, __pyx_t_4); __pyx_t_4 = 0; __Pyx_INCREF(__pyx_kp_u__11); __pyx_t_10 += 1; __Pyx_GIVEREF(__pyx_kp_u__11); PyTuple_SET_ITEM(__pyx_t_3, 6, __pyx_kp_u__11); __pyx_t_4 = __Pyx_PyUnicode_Join(__pyx_t_3, 7, __pyx_t_10, __pyx_t_11); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6064, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0;
6065: else:
+6066: return repr(self)
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyObject_Repr(((PyObject *)__pyx_v_self)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6066, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; }
6067:
+6068: def _block_index_at(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_45_block_index_at(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_44_block_index_at[] = "Memory._block_index_at(self: Memory, address: Address) -> Optional[BlockIndex]\nLocates the block enclosing an address.\n\n Returns the index of the block enclosing the given address.\n\n Arguments:\n address (int):\n Address of the target item.\n\n Returns:\n int: Block index if found, ``None`` otherwise.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | | 0 | 0 | 0 | 0 | | 1 | | 2 | 2 | 2 | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> [memory._block_index_at(i) for i in range(12)]\n [None, 0, 0, 0, 0, None, 1, None, 2, 2, 2, None]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_45_block_index_at = {"_block_index_at", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_45_block_index_at, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_44_block_index_at}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_45_block_index_at(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_block_index_at (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_44_block_index_at(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_44_block_index_at(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { Py_ssize_t __pyx_v_block_index; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_block_index_at", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory._block_index_at", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__80 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_block_index); if (unlikely(!__pyx_tuple__80)) __PYX_ERR(0, 6068, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__80); __Pyx_GIVEREF(__pyx_tuple__80); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6068, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6068, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_45_block_index_at, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__block_index_at, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__81)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6068, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_block_index_at, __pyx_t_1) < 0) __PYX_ERR(0, 6068, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__81 = (PyObject*)__Pyx_PyCode_New(2, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__80, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_block_index_at, 6068, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__81)) __PYX_ERR(0, 6068, __pyx_L1_error)
6069: self: Memory,
+6070: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6070, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_address, __pyx_t_2) < 0) __PYX_ERR(0, 6068, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6071: ) -> Optional[BlockIndex]:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6071, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_BlockIndex); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6071, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6071, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, __pyx_t_1) < 0) __PYX_ERR(0, 6068, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
6072: r"""Locates the block enclosing an address.
6073:
6074: Returns the index of the block enclosing the given address.
6075:
6076: Arguments:
6077: address (int):
6078: Address of the target item.
6079:
6080: Returns:
6081: int: Block index if found, ``None`` otherwise.
6082:
6083: Example:
6084: +---+---+---+---+---+---+---+---+---+---+---+---+
6085: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
6086: +===+===+===+===+===+===+===+===+===+===+===+===+
6087: | |[A | B | C | D]| |[$]| |[x | y | z]| |
6088: +---+---+---+---+---+---+---+---+---+---+---+---+
6089: | | 0 | 0 | 0 | 0 | | 1 | | 2 | 2 | 2 | |
6090: +---+---+---+---+---+---+---+---+---+---+---+---+
6091:
6092: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
6093: >>> [memory._block_index_at(i) for i in range(12)]
6094: [None, 0, 0, 0, 0, None, 1, None, 2, 2, 2, None]
6095: """
6096: cdef:
6097: ssize_t block_index
6098:
+6099: block_index = Rack_IndexAt(self._.blocks, address)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6099, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_IndexAt(__pyx_v_self->_->blocks, __pyx_t_1); if (unlikely(__pyx_t_2 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 6099, __pyx_L1_error) __pyx_v_block_index = __pyx_t_2;
+6100: return None if block_index < 0 else block_index
__Pyx_XDECREF(__pyx_r); if (((__pyx_v_block_index < 0) != 0)) { __Pyx_INCREF(Py_None); __pyx_t_3 = Py_None; } else { __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_block_index); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 6100, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __pyx_t_4; __pyx_t_4 = 0; } __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
6101:
+6102: def _block_index_endex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_47_block_index_endex(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_46_block_index_endex[] = "Memory._block_index_endex(self: Memory, address: Address) -> BlockIndex\nLocates the first block after an address range.\n\n Returns the index of the first block whose end address is lesser than or\n equal to `address`.\n\n Useful to find the termination block index in a ranged search.\n\n Arguments:\n address (int):\n Exclusive end address of the scanned range.\n\n Returns:\n int: First block index after `address`.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 3 | 3 | 3 | 3 |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> [memory._block_index_endex(i) for i in range(12)]\n [0, 1, 1, 1, 1, 1, 2, 2, 3, 3, 3, 3]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_47_block_index_endex = {"_block_index_endex", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_47_block_index_endex, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_46_block_index_endex}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_47_block_index_endex(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_block_index_endex (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_46_block_index_endex(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_46_block_index_endex(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_block_index_endex", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory._block_index_endex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__82 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_address); if (unlikely(!__pyx_tuple__82)) __PYX_ERR(0, 6102, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__82); __Pyx_GIVEREF(__pyx_tuple__82); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6102, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6102, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_47_block_index_endex, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__block_index_endex, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__83)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6102, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_block_index_endex, __pyx_t_6) < 0) __PYX_ERR(0, 6102, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__83 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__82, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_block_index_endex, 6102, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__83)) __PYX_ERR(0, 6102, __pyx_L1_error)
6103: self: Memory,
+6104: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6104, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_address, __pyx_t_6) < 0) __PYX_ERR(0, 6102, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6105: ) -> BlockIndex:
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_BlockIndex); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6105, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_t_6) < 0) __PYX_ERR(0, 6102, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
6106: r"""Locates the first block after an address range.
6107:
6108: Returns the index of the first block whose end address is lesser than or
6109: equal to `address`.
6110:
6111: Useful to find the termination block index in a ranged search.
6112:
6113: Arguments:
6114: address (int):
6115: Exclusive end address of the scanned range.
6116:
6117: Returns:
6118: int: First block index after `address`.
6119:
6120: Example:
6121: +---+---+---+---+---+---+---+---+---+---+---+---+
6122: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
6123: +===+===+===+===+===+===+===+===+===+===+===+===+
6124: | |[A | B | C | D]| |[$]| |[x | y | z]| |
6125: +---+---+---+---+---+---+---+---+---+---+---+---+
6126: | 0 | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 3 | 3 | 3 | 3 |
6127: +---+---+---+---+---+---+---+---+---+---+---+---+
6128:
6129: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
6130: >>> [memory._block_index_endex(i) for i in range(12)]
6131: [0, 1, 1, 1, 1, 1, 2, 2, 3, 3, 3, 3]
6132: """
6133:
+6134: return Rack_IndexEndex(self._.blocks, address)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6134, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_v_self->_->blocks, __pyx_t_1); if (unlikely(__pyx_t_2 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 6134, __pyx_L1_error) __pyx_t_3 = PyInt_FromSsize_t(__pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6134, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
6135:
+6136: def _block_index_start(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_49_block_index_start(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_48_block_index_start[] = "Memory._block_index_start(self: Memory, address: Address) -> BlockIndex\nLocates the first block inside of an address range.\n\n Returns the index of the first block whose start address is greater than\n or equal to `address`.\n\n Useful to find the initial block index in a ranged search.\n\n Arguments:\n address (int):\n Inclusive start address of the scanned range.\n\n Returns:\n int: First block index since `address`.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 2 | 2 | 2 | 2 | 3 |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> [memory._block_index_start(i) for i in range(12)]\n [0, 0, 0, 0, 0, 1, 1, 2, 2, 2, 2, 3]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_49_block_index_start = {"_block_index_start", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_49_block_index_start, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_48_block_index_start}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_49_block_index_start(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_block_index_start (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_48_block_index_start(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_48_block_index_start(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_block_index_start", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("cbytesparse.c.Memory._block_index_start", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__84 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_address); if (unlikely(!__pyx_tuple__84)) __PYX_ERR(0, 6136, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__84); __Pyx_GIVEREF(__pyx_tuple__84); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6136, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6136, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_49_block_index_start, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__block_index_start, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__85)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6136, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_block_index_start, __pyx_t_1) < 0) __PYX_ERR(0, 6136, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__85 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__84, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_block_index_start, 6136, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__85)) __PYX_ERR(0, 6136, __pyx_L1_error)
6137: self: Memory,
+6138: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6138, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_address, __pyx_t_1) < 0) __PYX_ERR(0, 6136, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+6139: ) -> BlockIndex:
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_BlockIndex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6139, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, __pyx_t_1) < 0) __PYX_ERR(0, 6136, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
6140: r"""Locates the first block inside of an address range.
6141:
6142: Returns the index of the first block whose start address is greater than
6143: or equal to `address`.
6144:
6145: Useful to find the initial block index in a ranged search.
6146:
6147: Arguments:
6148: address (int):
6149: Inclusive start address of the scanned range.
6150:
6151: Returns:
6152: int: First block index since `address`.
6153:
6154: Example:
6155: +---+---+---+---+---+---+---+---+---+---+---+---+
6156: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
6157: +===+===+===+===+===+===+===+===+===+===+===+===+
6158: | |[A | B | C | D]| |[$]| |[x | y | z]| |
6159: +---+---+---+---+---+---+---+---+---+---+---+---+
6160: | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 2 | 2 | 2 | 2 | 3 |
6161: +---+---+---+---+---+---+---+---+---+---+---+---+
6162:
6163: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
6164: >>> [memory._block_index_start(i) for i in range(12)]
6165: [0, 0, 0, 0, 0, 1, 1, 2, 2, 2, 2, 3]
6166: """
6167:
+6168: return Rack_IndexStart(self._.blocks, address)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6168, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_self->_->blocks, __pyx_t_1); if (unlikely(__pyx_t_2 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 6168, __pyx_L1_error) __pyx_t_3 = PyInt_FromSsize_t(__pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 6168, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
6169:
6170: @property
+6171: def _blocks(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_7_blocks_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_7_blocks_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_7_blocks___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_7_blocks___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory._blocks.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6172: self: Memory,
6173: ) -> BlockList:
6174: r"""list of blocks: A sequence of spaced blocks, sorted by address."""
6175:
+6176: return Memory_ToBlocks(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_ToBlocks(__pyx_v_self->_); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6176, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6177:
+6178: def _pretrim_endex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_51_pretrim_endex(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_50_pretrim_endex[] = "Memory._pretrim_endex(self: Memory, start_min: Optional[Address], size: Address) -> None\nTrims final data.\n\n Low-level method to manage trimming of data starting from an address.\n\n Arguments:\n start_min (int):\n Starting address of the erasure range.\n If ``None``, :attr:`trim_endex` minus `size` is considered.\n\n size (int):\n Size of the erasure range.\n\n See Also:\n :meth:`_pretrim_endex_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_51_pretrim_endex = {"_pretrim_endex", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_51_pretrim_endex, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_50_pretrim_endex}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_51_pretrim_endex(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start_min = 0; PyObject *__pyx_v_size = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_endex (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start_min,&__pyx_n_s_size,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start_min)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_pretrim_endex", 1, 2, 2, 1); __PYX_ERR(0, 6178, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_pretrim_endex") < 0)) __PYX_ERR(0, 6178, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_start_min = values[0]; __pyx_v_size = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_pretrim_endex", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6178, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_endex", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_50_pretrim_endex(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start_min, __pyx_v_size); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_50_pretrim_endex(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start_min, PyObject *__pyx_v_size) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_endex", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_endex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__86 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_start_min, __pyx_n_s_size); if (unlikely(!__pyx_tuple__86)) __PYX_ERR(0, 6178, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__86); __Pyx_GIVEREF(__pyx_tuple__86); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6178, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6178, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_51_pretrim_endex, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__pretrim_endex, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__87)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6178, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pretrim_endex, __pyx_t_2) < 0) __PYX_ERR(0, 6178, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__87 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__86, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pretrim_endex, 6178, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__87)) __PYX_ERR(0, 6178, __pyx_L1_error)
6179: self: Memory,
+6180: start_min: Optional[Address],
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6180, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6180, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6180, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_start_min, __pyx_t_2) < 0) __PYX_ERR(0, 6178, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6181: size: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6181, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_size, __pyx_t_2) < 0) __PYX_ERR(0, 6178, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6182: ) -> None:
if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6178, __pyx_L1_error)
6183: r"""Trims final data.
6184:
6185: Low-level method to manage trimming of data starting from an address.
6186:
6187: Arguments:
6188: start_min (int):
6189: Starting address of the erasure range.
6190: If ``None``, :attr:`trim_endex` minus `size` is considered.
6191:
6192: size (int):
6193: Size of the erasure range.
6194:
6195: See Also:
6196: :meth:`_pretrim_endex_backup`
6197: """
6198:
+6199: Memory_PretrimEndex(self._, start_min, size)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_PretrimEndex(__pyx_v_self->_, __pyx_v_start_min, __pyx_v_size); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6199, __pyx_L1_error)
6200:
+6201: def _pretrim_endex_backup(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_53_pretrim_endex_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_52_pretrim_endex_backup[] = "Memory._pretrim_endex_backup(self: Memory, start_min: Optional[Address], size: Address) -> Memory\nBackups a `_pretrim_endex()` operation.\n\n Arguments:\n start_min (int):\n Starting address of the erasure range.\n If ``None``, :attr:`trim_endex` minus `size` is considered.\n\n size (int):\n Size of the erasure range.\n\n Returns:\n :obj:`Memory`: Backup memory region.\n\n See Also:\n :meth:`_pretrim_endex`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_53_pretrim_endex_backup = {"_pretrim_endex_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_53_pretrim_endex_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_52_pretrim_endex_backup}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_53_pretrim_endex_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start_min = 0; PyObject *__pyx_v_size = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_endex_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start_min,&__pyx_n_s_size,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start_min)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_pretrim_endex_backup", 1, 2, 2, 1); __PYX_ERR(0, 6201, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_pretrim_endex_backup") < 0)) __PYX_ERR(0, 6201, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_start_min = values[0]; __pyx_v_size = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_pretrim_endex_backup", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6201, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_endex_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_52_pretrim_endex_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start_min, __pyx_v_size); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_52_pretrim_endex_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start_min, PyObject *__pyx_v_size) { addr_t __pyx_v_start_min_; addr_t __pyx_v_size_; Memory_ const *__pyx_v_memory; addr_t __pyx_v_start; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_endex_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_endex_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__88 = PyTuple_Pack(7, __pyx_n_s_self, __pyx_n_s_start_min, __pyx_n_s_size, __pyx_n_s_start_min_2, __pyx_n_s_size_2, __pyx_n_s_memory, __pyx_n_s_start); if (unlikely(!__pyx_tuple__88)) __PYX_ERR(0, 6201, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__88); __Pyx_GIVEREF(__pyx_tuple__88); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6201, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6201, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_53_pretrim_endex_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__pretrim_endex_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__89)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6201, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pretrim_endex_backup, __pyx_t_6) < 0) __PYX_ERR(0, 6201, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__89 = (PyObject*)__Pyx_PyCode_New(3, 0, 7, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__88, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pretrim_endex_backup, 6201, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__89)) __PYX_ERR(0, 6201, __pyx_L1_error)
6202: self: Memory,
+6203: start_min: Optional[Address],
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6203, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6203, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6203, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start_min, __pyx_t_6) < 0) __PYX_ERR(0, 6201, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6204: size: Address,
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6204, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_size, __pyx_t_6) < 0) __PYX_ERR(0, 6201, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6201, __pyx_L1_error)
6205: ) -> Memory:
6206: r"""Backups a `_pretrim_endex()` operation.
6207:
6208: Arguments:
6209: start_min (int):
6210: Starting address of the erasure range.
6211: If ``None``, :attr:`trim_endex` minus `size` is considered.
6212:
6213: size (int):
6214: Size of the erasure range.
6215:
6216: Returns:
6217: :obj:`Memory`: Backup memory region.
6218:
6219: See Also:
6220: :meth:`_pretrim_endex`
6221: """
6222: cdef:
6223: addr_t start_min_
+6224: addr_t size_ = <addr_t>size
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6224, __pyx_L1_error) __pyx_v_size_ = ((addr_t)__pyx_t_1);
+6225: const Memory_* memory = self._
__pyx_t_2 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_2;
6226: addr_t start
6227:
+6228: if memory.trim_endex_ and size_ > 0:
__pyx_t_4 = (__pyx_v_memory->trim_endex_ != 0); if (__pyx_t_4) { } else { __pyx_t_3 = __pyx_t_4; goto __pyx_L4_bool_binop_done; } __pyx_t_4 = ((__pyx_v_size_ > 0) != 0); __pyx_t_3 = __pyx_t_4; __pyx_L4_bool_binop_done:; if (__pyx_t_3) { /* … */ }
+6229: start = memory.trim_endex
__pyx_t_1 = __pyx_v_memory->trim_endex; __pyx_v_start = __pyx_t_1;
+6230: CheckSubAddrU(start, size)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6230, __pyx_L1_error) __pyx_t_5 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_start, __pyx_t_1); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6230, __pyx_L1_error)
+6231: start -= size
__pyx_t_6 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_start); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6231, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyNumber_InPlaceSubtract(__pyx_t_6, __pyx_v_size); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6231, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_7); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6231, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_v_start = __pyx_t_1;
+6232: if start_min is not None:
__pyx_t_3 = (__pyx_v_start_min != Py_None); __pyx_t_4 = (__pyx_t_3 != 0); if (__pyx_t_4) { /* … */ }
+6233: start_min_ = <addr_t>start_min
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start_min); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6233, __pyx_L1_error) __pyx_v_start_min_ = ((addr_t)__pyx_t_1);
+6234: if start < start_min_:
__pyx_t_4 = ((__pyx_v_start < __pyx_v_start_min_) != 0); if (__pyx_t_4) { /* … */ }
+6235: start = start_min_
__pyx_v_start = __pyx_v_start_min_;
+6236: return Memory_Extract_(memory, start, Memory_Endex(memory), 0, NULL, 1, True)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_v_start, __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_memory), 0, NULL, 1, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (!(likely(((__pyx_t_7) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_7, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 6236, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L0;
6237: else:
+6238: return Memory()
/*else*/ { __Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_7 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6238, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L0; }
6239:
+6240: def _pretrim_start(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_55_pretrim_start(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_54_pretrim_start[] = "Memory._pretrim_start(self: Memory, endex_max: Optional[Address], size: Address) -> None\nTrims initial data.\n\n Low-level method to manage trimming of data starting from an address.\n\n Arguments:\n endex_max (int):\n Exclusive end address of the erasure range.\n If ``None``, :attr:`trim_start` plus `size` is considered.\n\n size (int):\n Size of the erasure range.\n\n See Also:\n :meth:`_pretrim_start_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_55_pretrim_start = {"_pretrim_start", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_55_pretrim_start, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_54_pretrim_start}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_55_pretrim_start(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_endex_max = 0; PyObject *__pyx_v_size = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_start (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_endex_max,&__pyx_n_s_size,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex_max)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_pretrim_start", 1, 2, 2, 1); __PYX_ERR(0, 6240, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_pretrim_start") < 0)) __PYX_ERR(0, 6240, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_endex_max = values[0]; __pyx_v_size = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_pretrim_start", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6240, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_start", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_54_pretrim_start(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_endex_max, __pyx_v_size); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_54_pretrim_start(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_endex_max, PyObject *__pyx_v_size) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_start", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_start", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__90 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_endex_max, __pyx_n_s_size); if (unlikely(!__pyx_tuple__90)) __PYX_ERR(0, 6240, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__90); __Pyx_GIVEREF(__pyx_tuple__90); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6240, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6240, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_55_pretrim_start, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__pretrim_start, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__91)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6240, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pretrim_start, __pyx_t_1) < 0) __PYX_ERR(0, 6240, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__91 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__90, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pretrim_start, 6240, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__91)) __PYX_ERR(0, 6240, __pyx_L1_error)
6241: self: Memory,
+6242: endex_max: Optional[Address],
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6242, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6242, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6242, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_endex_max, __pyx_t_1) < 0) __PYX_ERR(0, 6240, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+6243: size: Address,
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6243, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_size, __pyx_t_1) < 0) __PYX_ERR(0, 6240, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+6244: ) -> None:
if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6240, __pyx_L1_error)
6245: r"""Trims initial data.
6246:
6247: Low-level method to manage trimming of data starting from an address.
6248:
6249: Arguments:
6250: endex_max (int):
6251: Exclusive end address of the erasure range.
6252: If ``None``, :attr:`trim_start` plus `size` is considered.
6253:
6254: size (int):
6255: Size of the erasure range.
6256:
6257: See Also:
6258: :meth:`_pretrim_start_backup`
6259: """
6260:
+6261: Memory_PretrimStart(self._, endex_max, size)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_PretrimStart(__pyx_v_self->_, __pyx_v_endex_max, __pyx_v_size); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6261, __pyx_L1_error)
6262:
+6263: def _pretrim_start_backup(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_57_pretrim_start_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_56_pretrim_start_backup[] = "Memory._pretrim_start_backup(self: Memory, endex_max: Optional[Address], size: Address) -> Memory\nBackups a `_pretrim_start()` operation.\n\n Arguments:\n endex_max (int):\n Exclusive end address of the erasure range.\n If ``None``, :attr:`trim_start` plus `size` is considered.\n\n size (int):\n Size of the erasure range.\n\n Returns:\n :obj:`Memory`: Backup memory region.\n\n See Also:\n :meth:`_pretrim_start`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_57_pretrim_start_backup = {"_pretrim_start_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_57_pretrim_start_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_56_pretrim_start_backup}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_57_pretrim_start_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_endex_max = 0; PyObject *__pyx_v_size = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_start_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_endex_max,&__pyx_n_s_size,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex_max)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_pretrim_start_backup", 1, 2, 2, 1); __PYX_ERR(0, 6263, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_pretrim_start_backup") < 0)) __PYX_ERR(0, 6263, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_endex_max = values[0]; __pyx_v_size = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_pretrim_start_backup", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6263, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_start_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_56_pretrim_start_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_endex_max, __pyx_v_size); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_56_pretrim_start_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_endex_max, PyObject *__pyx_v_size) { addr_t __pyx_v_endex_max_; addr_t __pyx_v_size_; Memory_ const *__pyx_v_memory; addr_t __pyx_v_endex; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_pretrim_start_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("cbytesparse.c.Memory._pretrim_start_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__92 = PyTuple_Pack(7, __pyx_n_s_self, __pyx_n_s_endex_max, __pyx_n_s_size, __pyx_n_s_endex_max_2, __pyx_n_s_size_2, __pyx_n_s_memory, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__92)) __PYX_ERR(0, 6263, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__92); __Pyx_GIVEREF(__pyx_tuple__92); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6263, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6263, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_57_pretrim_start_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory__pretrim_start_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__93)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6263, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pretrim_start_backup, __pyx_t_2) < 0) __PYX_ERR(0, 6263, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__93 = (PyObject*)__Pyx_PyCode_New(3, 0, 7, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__92, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pretrim_start_backup, 6263, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__93)) __PYX_ERR(0, 6263, __pyx_L1_error)
6264: self: Memory,
+6265: endex_max: Optional[Address],
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6265, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6265, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6265, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_endex_max, __pyx_t_2) < 0) __PYX_ERR(0, 6263, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6266: size: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6266, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_size, __pyx_t_2) < 0) __PYX_ERR(0, 6263, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6263, __pyx_L1_error)
6267: ) -> Memory:
6268: r"""Backups a `_pretrim_start()` operation.
6269:
6270: Arguments:
6271: endex_max (int):
6272: Exclusive end address of the erasure range.
6273: If ``None``, :attr:`trim_start` plus `size` is considered.
6274:
6275: size (int):
6276: Size of the erasure range.
6277:
6278: Returns:
6279: :obj:`Memory`: Backup memory region.
6280:
6281: See Also:
6282: :meth:`_pretrim_start`
6283: """
6284: cdef:
6285: addr_t endex_max_
+6286: addr_t size_ = <addr_t>size
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6286, __pyx_L1_error) __pyx_v_size_ = ((addr_t)__pyx_t_1);
+6287: const Memory_* memory = self._
__pyx_t_2 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_2;
6288: addr_t endex
6289:
+6290: if memory.trim_start_ and size_ > 0:
__pyx_t_4 = (__pyx_v_memory->trim_start_ != 0); if (__pyx_t_4) { } else { __pyx_t_3 = __pyx_t_4; goto __pyx_L4_bool_binop_done; } __pyx_t_4 = ((__pyx_v_size_ > 0) != 0); __pyx_t_3 = __pyx_t_4; __pyx_L4_bool_binop_done:; if (__pyx_t_3) { /* … */ }
+6291: endex = memory.trim_start
__pyx_t_1 = __pyx_v_memory->trim_start; __pyx_v_endex = __pyx_t_1;
+6292: CheckAddAddrU(endex, size)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_size); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6292, __pyx_L1_error) __pyx_t_5 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_endex, __pyx_t_1); if (unlikely(__pyx_t_5 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6292, __pyx_L1_error)
+6293: endex += size
__pyx_t_6 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_endex); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6293, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyNumber_InPlaceAdd(__pyx_t_6, __pyx_v_size); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6293, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_7); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6293, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_v_endex = __pyx_t_1;
+6294: if endex_max is not None:
__pyx_t_3 = (__pyx_v_endex_max != Py_None); __pyx_t_4 = (__pyx_t_3 != 0); if (__pyx_t_4) { /* … */ }
+6295: endex_max_ = <addr_t>endex_max
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex_max); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6295, __pyx_L1_error) __pyx_v_endex_max_ = ((addr_t)__pyx_t_1);
+6296: if endex > endex_max_:
__pyx_t_4 = ((__pyx_v_endex > __pyx_v_endex_max_) != 0); if (__pyx_t_4) { /* … */ }
+6297: endex = endex_max_
__pyx_v_endex = __pyx_v_endex_max_;
+6298: return Memory_Extract_(memory, Memory_Start(memory), endex, 0, NULL, 1, True)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_7 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_memory), __pyx_v_endex, 0, NULL, 1, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6298, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (!(likely(((__pyx_t_7) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_7, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 6298, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L0;
6299: else:
+6300: return Memory()
/*else*/ { __Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_7 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6300, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L0; }
6301:
+6302: def append(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_59append(PyObject *__pyx_v_self, PyObject *__pyx_v_item); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_58append[] = "Memory.append(self: Memory, item: Union[AnyBytes, Value]) -> None\nAppends a single item.\n\n Arguments:\n item (int):\n Value to append. Can be a single byte string or integer.\n\n Examples:\n >>> memory = Memory()\n >>> memory.append(b'$')\n >>> memory._blocks\n [[0, b'$']]\n\n ~~~\n\n >>> memory = Memory()\n >>> memory.append(3)\n >>> memory._blocks\n [[0, b'\\x03']]\n\n See Also:\n :meth:`append_backup`\n :meth:`append_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_59append = {"append", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_59append, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_58append}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_59append(PyObject *__pyx_v_self, PyObject *__pyx_v_item) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("append (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_58append(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_item)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_58append(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("append", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.append", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__94 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_item); if (unlikely(!__pyx_tuple__94)) __PYX_ERR(0, 6302, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__94); __Pyx_GIVEREF(__pyx_tuple__94); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6302, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6302, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_59append, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_append, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__95)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6302, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_append, __pyx_t_6) < 0) __PYX_ERR(0, 6302, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__95 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__94, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_append, 6302, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__95)) __PYX_ERR(0, 6302, __pyx_L1_error)
6303: self: Memory,
+6304: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Union); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6304, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6304, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6304, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 6304, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_6); __pyx_t_7 = 0; __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6304, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_item, __pyx_t_6) < 0) __PYX_ERR(0, 6302, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6305: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6302, __pyx_L1_error)
6306: r"""Appends a single item.
6307:
6308: Arguments:
6309: item (int):
6310: Value to append. Can be a single byte string or integer.
6311:
6312: Examples:
6313: >>> memory = Memory()
6314: >>> memory.append(b'$')
6315: >>> memory._blocks
6316: [[0, b'$']]
6317:
6318: ~~~
6319:
6320: >>> memory = Memory()
6321: >>> memory.append(3)
6322: >>> memory._blocks
6323: [[0, b'\x03']]
6324:
6325: See Also:
6326: :meth:`append_backup`
6327: :meth:`append_restore`
6328: """
6329:
+6330: return Memory_Append(self._, item)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Append(__pyx_v_self->_, __pyx_v_item); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6330, __pyx_L1_error) __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6330, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
6331:
6332: # noinspection PyMethodMayBeStatic
+6333: def append_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_61append_backup(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_60append_backup[] = "Memory.append_backup(self: Memory) -> None\nBackups an `append()` operation.\n\n Returns:\n None: Nothing.\n\n See Also:\n :meth:`append`\n :meth:`append_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_61append_backup = {"append_backup", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_61append_backup, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_60append_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_61append_backup(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("append_backup (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_60append_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_60append_backup(CYTHON_UNUSED struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("append_backup", 0); /* … */ /* function exit code */ __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__96 = PyTuple_Pack(1, __pyx_n_s_self); if (unlikely(!__pyx_tuple__96)) __PYX_ERR(0, 6333, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__96); __Pyx_GIVEREF(__pyx_tuple__96); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6333, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6333, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_61append_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_append_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__97)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6333, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_append_backup, __pyx_t_2) < 0) __PYX_ERR(0, 6333, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__97 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__96, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_append_backup, 6333, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__97)) __PYX_ERR(0, 6333, __pyx_L1_error)
6334: self: Memory,
+6335: ) -> None:
if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6333, __pyx_L1_error)
6336: r"""Backups an `append()` operation.
6337:
6338: Returns:
6339: None: Nothing.
6340:
6341: See Also:
6342: :meth:`append`
6343: :meth:`append_restore`
6344: """
6345:
+6346: return None
__Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0;
6347:
+6348: def append_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_63append_restore(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_62append_restore[] = "Memory.append_restore(self: Memory) -> None\nRestores an `append()` operation.\n\n See Also:\n :meth:`append`\n :meth:`append_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_63append_restore = {"append_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_63append_restore, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_62append_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_63append_restore(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("append_restore (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_62append_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_62append_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("append_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.append_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__98 = PyTuple_Pack(1, __pyx_n_s_self); if (unlikely(!__pyx_tuple__98)) __PYX_ERR(0, 6348, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__98); __Pyx_GIVEREF(__pyx_tuple__98); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6348, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6348, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_63append_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_append_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__99)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6348, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_append_restore, __pyx_t_6) < 0) __PYX_ERR(0, 6348, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__99 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__98, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_append_restore, 6348, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__99)) __PYX_ERR(0, 6348, __pyx_L1_error)
6349: self: Memory,
+6350: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6348, __pyx_L1_error)
6351: r"""Restores an `append()` operation.
6352:
6353: See Also:
6354: :meth:`append`
6355: :meth:`append_backup`
6356: """
6357:
+6358: Memory_PopLast_(self._)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_PopLast_(__pyx_v_self->_); if (unlikely(__pyx_t_1 == ((int)-2))) __PYX_ERR(0, 6358, __pyx_L1_error)
6359:
+6360: def block_span(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_65block_span(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_64block_span[] = "Memory.block_span(self: Memory, address: Address) -> Tuple[Optional[Address], Optional[Address], Optional[Value]]\nSpan of block data.\n\n It searches for the biggest chunk of data adjacent to the given\n address.\n\n If the address is within a gap, its bounds are returned, and its\n value is ``None``.\n\n If the address is before or after any data, bounds are ``None``.\n\n Arguments:\n address (int):\n Reference address.\n\n Returns:\n tuple: Start bound, exclusive end bound, and reference value.\n\n Examples:\n >>> memory = Memory()\n >>> memory.block_span(0)\n (None, None, None)\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|\n +===+===+===+===+===+===+===+===+===+===+===+\n |[A | B | B | B | C]| | |[C | C | D]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n | 65| 66| 66| 66| 67| | | 67| 67| 68| |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[0, b'ABBBC'], [7, b'CCD']])\n >>> memory.block_span(2)\n (0, 5, 66)\n >>> memory.block_span(4)\n (0, 5, 67)\n >>> memory.block_span(5)\n (5, 7, None)\n >>> memory.block_span(10)\n (10, None, None)\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_65block_span = {"block_span", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_65block_span, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_64block_span}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_65block_span(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("block_span (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_64block_span(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_64block_span(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { addr_t __pyx_v_address_; Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; byte_t __pyx_v_value; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("block_span", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_9); __Pyx_XDECREF(__pyx_t_10); __Pyx_AddTraceback("cbytesparse.c.Memory.block_span", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__100 = PyTuple_Pack(10, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_address_2, __pyx_n_s_blocks, __pyx_n_s_block_count, __pyx_n_s_block_index, __pyx_n_s_block, __pyx_n_s_block_start, __pyx_n_s_block_endex, __pyx_n_s_value); if (unlikely(!__pyx_tuple__100)) __PYX_ERR(0, 6360, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__100); __Pyx_GIVEREF(__pyx_tuple__100); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6360, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6360, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_65block_span, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_block_span, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__101)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6360, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_block_span, __pyx_t_9) < 0) __PYX_ERR(0, 6360, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__101 = (PyObject*)__Pyx_PyCode_New(2, 0, 10, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__100, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_block_span, 6360, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__101)) __PYX_ERR(0, 6360, __pyx_L1_error)
6361: self: Memory,
+6362: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6362, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_address, __pyx_t_2) < 0) __PYX_ERR(0, 6360, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6363: ) -> Tuple[Optional[Address], Optional[Address], Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_8 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_5); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_1); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyTuple_New(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_1, 2, __pyx_t_9); __pyx_t_7 = 0; __pyx_t_8 = 0; __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, __pyx_t_9) < 0) __PYX_ERR(0, 6360, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
6364: r"""Span of block data.
6365:
6366: It searches for the biggest chunk of data adjacent to the given
6367: address.
6368:
6369: If the address is within a gap, its bounds are returned, and its
6370: value is ``None``.
6371:
6372: If the address is before or after any data, bounds are ``None``.
6373:
6374: Arguments:
6375: address (int):
6376: Reference address.
6377:
6378: Returns:
6379: tuple: Start bound, exclusive end bound, and reference value.
6380:
6381: Examples:
6382: >>> memory = Memory()
6383: >>> memory.block_span(0)
6384: (None, None, None)
6385:
6386: ~~~
6387:
6388: +---+---+---+---+---+---+---+---+---+---+---+
6389: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|
6390: +===+===+===+===+===+===+===+===+===+===+===+
6391: |[A | B | B | B | C]| | |[C | C | D]| |
6392: +---+---+---+---+---+---+---+---+---+---+---+
6393: | 65| 66| 66| 66| 67| | | 67| 67| 68| |
6394: +---+---+---+---+---+---+---+---+---+---+---+
6395:
6396: >>> memory = Memory.from_blocks([[0, b'ABBBC'], [7, b'CCD']])
6397: >>> memory.block_span(2)
6398: (0, 5, 66)
6399: >>> memory.block_span(4)
6400: (0, 5, 67)
6401: >>> memory.block_span(5)
6402: (5, 7, None)
6403: >>> memory.block_span(10)
6404: (10, None, None)
6405: """
6406: cdef:
+6407: addr_t address_ = <addr_t>address
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6407, __pyx_L1_error) __pyx_v_address_ = ((addr_t)__pyx_t_1);
+6408: const Rack_* blocks = self._.blocks
__pyx_t_2 = __pyx_v_self->_->blocks; __pyx_v_blocks = __pyx_t_2;
+6409: size_t block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
6410: size_t block_index
6411: const Block_* block
6412: addr_t block_start
6413: addr_t block_endex
6414: byte_t value
6415:
+6416: block_index = Rack_IndexStart(blocks, address_)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_address_); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 6416, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_3;
6417:
+6418: if block_index < block_count:
__pyx_t_4 = ((__pyx_v_block_index < __pyx_v_block_count) != 0); if (__pyx_t_4) { /* … */ }
+6419: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+6420: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+6421: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
6422:
+6423: if block_start <= address_ < block_endex:
__pyx_t_4 = (__pyx_v_block_start <= __pyx_v_address_); if (__pyx_t_4) { __pyx_t_4 = (__pyx_v_address_ < __pyx_v_block_endex); } __pyx_t_5 = (__pyx_t_4 != 0); if (__pyx_t_5) { /* … */ }
6424: # Address within a block
+6425: CheckSubAddrU(address_, block_start)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_address_, __pyx_v_block_start); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6425, __pyx_L1_error)
+6426: CheckAddrToSizeU(address_ - block_start)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU((__pyx_v_address_ - __pyx_v_block_start)); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6426, __pyx_L1_error)
+6427: value = Block_Get__(block, <size_t>(address_ - block_start))
__pyx_v_value = __pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_block, ((size_t)(__pyx_v_address_ - __pyx_v_block_start)));
+6428: return block_start, block_endex, value # block span
__Pyx_XDECREF(__pyx_r); __pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 6428, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_8 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_endex); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6428, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_9 = __Pyx_PyInt_From_byte_t(__pyx_v_value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6428, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_10 = PyTuple_New(3); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 6428, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_10, 1, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_10, 2, __pyx_t_9); __pyx_t_7 = 0; __pyx_t_8 = 0; __pyx_t_9 = 0; __pyx_r = __pyx_t_10; __pyx_t_10 = 0; goto __pyx_L0;
6429:
+6430: elif block_index:
__pyx_t_5 = (__pyx_v_block_index != 0); if (__pyx_t_5) { /* … */ }
6431: # Address within a gap
+6432: block_endex = block_start # end gap before next block
__pyx_v_block_endex = __pyx_v_block_start;
+6433: block = Rack_Get__(blocks, block_index - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_block_index - 1));
+6434: block_start = Block_Endex(block) # start gap after previous block
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+6435: return block_start, block_endex, None # gap span
__Pyx_XDECREF(__pyx_r); __pyx_t_10 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 6435, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_10); __pyx_t_9 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_endex); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6435, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_8 = PyTuple_New(3); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6435, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GIVEREF(__pyx_t_10); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_10); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_9); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_8, 2, Py_None); __pyx_t_10 = 0; __pyx_t_9 = 0; __pyx_r = __pyx_t_8; __pyx_t_8 = 0; goto __pyx_L0;
6436:
6437: else:
6438: # Address before content
+6439: return None, block_start, None # open left
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_8 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6439, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_9 = PyTuple_New(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6439, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_9, 0, Py_None); __Pyx_GIVEREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_8); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_9, 2, Py_None); __pyx_t_8 = 0; __pyx_r = __pyx_t_9; __pyx_t_9 = 0; goto __pyx_L0; }
6440:
6441: else:
6442: # Address after content
+6443: if block_count:
/*else*/ { __pyx_t_5 = (__pyx_v_block_count != 0); if (__pyx_t_5) { /* … */ }
+6444: block = Rack_Last__(blocks)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks);
+6445: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+6446: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+6447: return block_endex, None, None # open right
__Pyx_XDECREF(__pyx_r); __pyx_t_9 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_endex); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6447, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_8 = PyTuple_New(3); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6447, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_9); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_8, 1, Py_None); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_8, 2, Py_None); __pyx_t_9 = 0; __pyx_r = __pyx_t_8; __pyx_t_8 = 0; goto __pyx_L0;
6448:
6449: else:
+6450: return None, None, None # fully open
/*else*/ { __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_tuple__29); __pyx_r = __pyx_tuple__29; goto __pyx_L0; } } /* … */ __pyx_tuple__29 = PyTuple_Pack(3, Py_None, Py_None, Py_None); if (unlikely(!__pyx_tuple__29)) __PYX_ERR(0, 6450, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__29); __Pyx_GIVEREF(__pyx_tuple__29);
6451:
+6452: def bound(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_67bound(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_66bound[] = "Memory.bound(self: Memory, start: Optional[Address], endex: Optional[Address]) -> ClosedInterval\nBounds addresses.\n\n It bounds the given addresses to stay within memory limits.\n ``None`` is used to ignore a limit for the `start` or `endex`\n directions.\n\n In case of stored data, :attr:`content_start` and\n :attr:`content_endex` are used as bounds.\n\n In case of trimming limits, :attr:`trim_start` or :attr:`trim_endex`\n are used as bounds, when not ``None``.\n\n In case `start` and `endex` are in the wrong order, one clamps\n the other if present (see the Python implementation for details).\n\n Returns:\n tuple of int: Bounded `start` and `endex`, closed interval.\n\n Examples:\n >>> Memory().bound(None, None)\n (0, 0)\n >>> Memory().bound(None, 100)\n (0, 100)\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |\n +===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])\n >>> memory.bound(0, 30)\n (0, 30)\n >>> memory.bound(2, 6)\n (2, 6)\n >>> memory.bound(None, 6)\n (1, 6)\n >>> memory.bound(2, None)\n (2, 8)\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |\n +===+===+===+===+===+===+===+===+===+\n | |[[[| |[A | B | C]| | |)))|\n +---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[3, b'ABC']], start=1, endex=8)\n >>> memory.bound(None, None)\n (1, 8)\n >>> memory.bound(0, 30)\n (1, 8)\n >>> memory.bound(2"", 6)\n (2, 6)\n >>> memory.bound(2, None)\n (2, 8)\n >>> memory.bound(None, 6)\n (1, 6)\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_67bound = {"bound", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_67bound, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_66bound}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_67bound(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("bound (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("bound", 1, 2, 2, 1); __PYX_ERR(0, 6452, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "bound") < 0)) __PYX_ERR(0, 6452, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("bound", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6452, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.bound", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_66bound(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_66bound(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("bound", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.bound", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__102 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__102)) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__102); __Pyx_GIVEREF(__pyx_tuple__102); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6452, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_67bound, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_bound, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__103)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_bound, __pyx_t_6) < 0) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__103 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__102, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_bound, 6452, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__103)) __PYX_ERR(0, 6452, __pyx_L1_error)
6453: self: Memory,
+6454: start: Optional[Address],
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6454, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6454, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6454, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6455: endex: Optional[Address],
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6455, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6455, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6455, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_endex, __pyx_t_6) < 0) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6456: ) -> ClosedInterval:
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_ClosedInterval); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6456, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, __pyx_t_6) < 0) __PYX_ERR(0, 6452, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
6457: r"""Bounds addresses.
6458:
6459: It bounds the given addresses to stay within memory limits.
6460: ``None`` is used to ignore a limit for the `start` or `endex`
6461: directions.
6462:
6463: In case of stored data, :attr:`content_start` and
6464: :attr:`content_endex` are used as bounds.
6465:
6466: In case of trimming limits, :attr:`trim_start` or :attr:`trim_endex`
6467: are used as bounds, when not ``None``.
6468:
6469: In case `start` and `endex` are in the wrong order, one clamps
6470: the other if present (see the Python implementation for details).
6471:
6472: Returns:
6473: tuple of int: Bounded `start` and `endex`, closed interval.
6474:
6475: Examples:
6476: >>> Memory().bound(None, None)
6477: (0, 0)
6478: >>> Memory().bound(None, 100)
6479: (0, 100)
6480:
6481: ~~~
6482:
6483: +---+---+---+---+---+---+---+---+---+
6484: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6485: +===+===+===+===+===+===+===+===+===+
6486: | |[A | B | C]| |[x | y | z]| |
6487: +---+---+---+---+---+---+---+---+---+
6488:
6489: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6490: >>> memory.bound(0, 30)
6491: (0, 30)
6492: >>> memory.bound(2, 6)
6493: (2, 6)
6494: >>> memory.bound(None, 6)
6495: (1, 6)
6496: >>> memory.bound(2, None)
6497: (2, 8)
6498:
6499: ~~~
6500:
6501: +---+---+---+---+---+---+---+---+---+
6502: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6503: +===+===+===+===+===+===+===+===+===+
6504: | |[[[| |[A | B | C]| | |)))|
6505: +---+---+---+---+---+---+---+---+---+
6506:
6507: >>> memory = Memory.from_blocks([[3, b'ABC']], start=1, endex=8)
6508: >>> memory.bound(None, None)
6509: (1, 8)
6510: >>> memory.bound(0, 30)
6511: (1, 8)
6512: >>> memory.bound(2, 6)
6513: (2, 6)
6514: >>> memory.bound(2, None)
6515: (2, 8)
6516: >>> memory.bound(None, 6)
6517: (1, 6)
6518: """
6519:
+6520: return Memory_Bound(self._, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 6520, __pyx_L1_error) __pyx_t_2 = __pyx_convert__to_py___pyx_ctuple_addr_t__and_addr_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6520, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
6521:
+6522: def clear(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_69clear(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_68clear[] = "Memory.clear(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> None\nClears an address range.\n\n Arguments:\n start (int):\n Inclusive start address for clearing.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for clearing.\n If ``None``, :attr:`endex` is considered.\n\n Example:\n +---+---+---+---+---+---+---+---+---+\n | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n | |[A]| | | | |[y | z]| |\n +---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])\n >>> memory.clear(6, 10)\n >>> memory._blocks\n [[5, b'A'], [10, b'yz']]\n\n See Also:\n :meth:`clear_backup`\n :meth:`clear_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_69clear = {"clear", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_69clear, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_68clear}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_69clear(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_68clear(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__104 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__104)) __PYX_ERR(0, 6522, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__104); __Pyx_GIVEREF(__pyx_tuple__104); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6522, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6522, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_69clear, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_clear, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__105)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6522, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_clear, __pyx_t_9) < 0) __PYX_ERR(0, 6522, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__105 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__104, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_clear, 6522, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__105)) __PYX_ERR(0, 6522, __pyx_L1_error)
6523: self: Memory,
+6524: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6524, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6524, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6524, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 6522, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6525: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "clear") < 0)) __PYX_ERR(0, 6522, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("clear", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6522, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_68clear(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6525, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6525, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6525, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 6522, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+6526: ) -> None:
if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6522, __pyx_L1_error)
6527: r"""Clears an address range.
6528:
6529: Arguments:
6530: start (int):
6531: Inclusive start address for clearing.
6532: If ``None``, :attr:`start` is considered.
6533:
6534: endex (int):
6535: Exclusive end address for clearing.
6536: If ``None``, :attr:`endex` is considered.
6537:
6538: Example:
6539: +---+---+---+---+---+---+---+---+---+
6540: | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
6541: +===+===+===+===+===+===+===+===+===+
6542: | |[A | B | C]| |[x | y | z]| |
6543: +---+---+---+---+---+---+---+---+---+
6544: | |[A]| | | | |[y | z]| |
6545: +---+---+---+---+---+---+---+---+---+
6546:
6547: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])
6548: >>> memory.clear(6, 10)
6549: >>> memory._blocks
6550: [[5, b'A'], [10, b'yz']]
6551:
6552: See Also:
6553: :meth:`clear_backup`
6554: :meth:`clear_restore`
6555: """
6556:
+6557: Memory_Clear(self._, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Clear(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6557, __pyx_L1_error)
6558:
+6559: def clear_backup(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_71clear_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_70clear_backup[] = "Memory.clear_backup(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> Memory\nBackups a `clear()` operation.\n\n Arguments:\n start (int):\n Inclusive start address for clearing.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for clearing.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n :obj:`Memory`: Backup memory region.\n\n See Also:\n :meth:`clear`\n :meth:`clear_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_71clear_backup = {"clear_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_71clear_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_70clear_backup}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_71clear_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_70clear_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { Memory_ const *__pyx_v_memory; addr_t __pyx_v_start_; addr_t __pyx_v_endex_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.clear_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__106 = PyTuple_Pack(6, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_memory, __pyx_n_s_start_2, __pyx_n_s_endex_2); if (unlikely(!__pyx_tuple__106)) __PYX_ERR(0, 6559, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__106); __Pyx_GIVEREF(__pyx_tuple__106); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6559, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6559, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_71clear_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_clear_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__107)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6559, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_clear_backup, __pyx_t_6) < 0) __PYX_ERR(0, 6559, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__107 = (PyObject*)__Pyx_PyCode_New(3, 0, 6, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__106, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_clear_backup, 6559, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__107)) __PYX_ERR(0, 6559, __pyx_L1_error)
6560: self: Memory,
+6561: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6561, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6561, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6561, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 6559, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6562: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "clear_backup") < 0)) __PYX_ERR(0, 6559, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("clear_backup", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6559, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.clear_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_70clear_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6562, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6562, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6562, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_endex, __pyx_t_6) < 0) __PYX_ERR(0, 6559, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6559, __pyx_L1_error)
6563: ) -> Memory:
6564: r"""Backups a `clear()` operation.
6565:
6566: Arguments:
6567: start (int):
6568: Inclusive start address for clearing.
6569: If ``None``, :attr:`start` is considered.
6570:
6571: endex (int):
6572: Exclusive end address for clearing.
6573: If ``None``, :attr:`endex` is considered.
6574:
6575: Returns:
6576: :obj:`Memory`: Backup memory region.
6577:
6578: See Also:
6579: :meth:`clear`
6580: :meth:`clear_restore`
6581: """
6582: cdef:
+6583: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+6584: addr_t start_ = Memory_Start(memory) if start is None else <addr_t>start
__pyx_t_3 = (__pyx_v_start == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6584, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_start_ = __pyx_t_2;
+6585: addr_t endex_ = Memory_Endex(memory) if endex is None else <addr_t>endex
__pyx_t_3 = (__pyx_v_endex == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6585, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_endex_ = __pyx_t_2;
6586:
+6587: return Memory_Extract_(memory, start_, endex_, 0, NULL, 1, True)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_v_start_, __pyx_v_endex_, 0, NULL, 1, 1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 6587, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (!(likely(((__pyx_t_5) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_5, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 6587, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L0;
6588:
+6589: def clear_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_73clear_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_72clear_restore[] = "Memory.clear_restore(self: Memory, Memory backup: Memory) -> None\nRestores a `clear()` operation.\n\n Arguments:\n backup (:obj:`Memory`):\n Backup memory region to restore.\n\n See Also:\n :meth:`clear`\n :meth:`clear_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_73clear_restore = {"clear_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_73clear_restore, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_72clear_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_73clear_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear_restore (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 6591, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_72clear_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_backup)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_72clear_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.clear_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__108 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__108)) __PYX_ERR(0, 6589, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__108); __Pyx_GIVEREF(__pyx_tuple__108); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6589, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6589, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6589, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_73clear_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_clear_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__109)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6589, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_clear_restore, __pyx_t_9) < 0) __PYX_ERR(0, 6589, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__109 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__108, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_clear_restore, 6589, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__109)) __PYX_ERR(0, 6589, __pyx_L1_error)
6590: self: Memory,
6591: Memory backup not None: Memory,
+6592: ) -> None:
if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6589, __pyx_L1_error)
6593: r"""Restores a `clear()` operation.
6594:
6595: Arguments:
6596: backup (:obj:`Memory`):
6597: Backup memory region to restore.
6598:
6599: See Also:
6600: :meth:`clear`
6601: :meth:`clear_backup`
6602: """
6603:
+6604: Memory_WriteSame_(self._, 0, backup._, True)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_self->_, 0, __pyx_v_backup->_, 1); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6604, __pyx_L1_error)
6605:
6606: @property
+6607: def content_endex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_endex_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_endex_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_13content_endex___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_13content_endex___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.content_endex.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6608: self: Memory,
6609: ) -> Address:
6610: r"""int: Exclusive content end address.
6611:
6612: This property holds the exclusive end address of the memory content.
6613: By default, it is the current maximmum exclusive end address of
6614: the last stored block.
6615:
6616: If the memory has no data and no trimming, :attr:`start` is returned.
6617:
6618: Trimming is considered only for an empty memory.
6619:
6620: Examples:
6621: >>> Memory().content_endex
6622: 0
6623: >>> Memory(endex=8).content_endex
6624: 0
6625: >>> Memory(start=1, endex=8).content_endex
6626: 1
6627:
6628: ~~~
6629:
6630: +---+---+---+---+---+---+---+---+---+
6631: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6632: +===+===+===+===+===+===+===+===+===+
6633: | |[A | B | C]| |[x | y | z]| |
6634: +---+---+---+---+---+---+---+---+---+
6635:
6636: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6637: >>> memory.content_endex
6638: 8
6639:
6640: ~~~
6641:
6642: +---+---+---+---+---+---+---+---+---+
6643: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6644: +===+===+===+===+===+===+===+===+===+
6645: | |[A | B | C]| | | | |)))|
6646: +---+---+---+---+---+---+---+---+---+
6647:
6648: >>> memory = Memory.from_blocks([[1, b'ABC']], endex=8)
6649: >>> memory.content_endex
6650: 4
6651: """
6652:
+6653: return Memory_ContentEndex(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_ContentEndex(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6653, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6654:
6655: @property
+6656: def content_endin(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_endin_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_endin_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_13content_endin___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_13content_endin___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.content_endin.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6657: self: Memory,
6658: ) -> Address:
6659: r"""int: Inclusive content end address.
6660:
6661: This property holds the inclusive end address of the memory content.
6662: By default, it is the current maximmum inclusive end address of
6663: the last stored block.
6664:
6665: If the memory has no data and no trimming, :attr:`start` minus one is
6666: returned.
6667:
6668: Trimming is considered only for an empty memory.
6669:
6670: Examples:
6671: >>> Memory().content_endin
6672: -1
6673: >>> Memory(endex=8).content_endin
6674: -1
6675: >>> Memory(start=1, endex=8).content_endin
6676: 0
6677:
6678: ~~~
6679:
6680: +---+---+---+---+---+---+---+---+---+
6681: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6682: +===+===+===+===+===+===+===+===+===+
6683: | |[A | B | C]| |[x | y | z]| |
6684: +---+---+---+---+---+---+---+---+---+
6685:
6686: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6687: >>> memory.content_endin
6688: 7
6689:
6690: ~~~
6691:
6692: +---+---+---+---+---+---+---+---+---+
6693: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6694: +===+===+===+===+===+===+===+===+===+
6695: | |[A | B | C]| | | | |)))|
6696: +---+---+---+---+---+---+---+---+---+
6697:
6698: >>> memory = Memory.from_blocks([[1, b'ABC']], endex=8)
6699: >>> memory.content_endin
6700: 3
6701: """
6702:
+6703: return Memory_ContentEndin(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_ContentEndin(__pyx_v_self->_); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6703, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6704:
6705: @property
+6706: def content_parts(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_parts_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_parts_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_13content_parts___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_13content_parts___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.content_parts.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6707: self: Memory,
6708: ) -> int:
6709: r"""Number of blocks.
6710:
6711: Returns:
6712: int: The number of blocks.
6713:
6714: Examples:
6715: >>> Memory().content_parts
6716: 0
6717:
6718: ~~~
6719:
6720: +---+---+---+---+---+---+---+---+---+
6721: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6722: +===+===+===+===+===+===+===+===+===+
6723: | |[A | B | C]| |[x | y | z]| |
6724: +---+---+---+---+---+---+---+---+---+
6725:
6726: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6727: >>> memory.content_parts
6728: 2
6729:
6730: ~~~
6731:
6732: +---+---+---+---+---+---+---+---+---+
6733: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6734: +===+===+===+===+===+===+===+===+===+
6735: | |[A | B | C]| | | | |)))|
6736: +---+---+---+---+---+---+---+---+---+
6737:
6738: >>> memory = Memory.from_blocks([[1, b'ABC']], endex=8)
6739: >>> memory.content_parts
6740: 1
6741: """
6742:
+6743: return Memory_ContentParts(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_FromSize_t(__pyx_f_11cbytesparse_1c_Memory_ContentParts(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6743, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6744:
6745: @property
+6746: def content_size(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_12content_size_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_12content_size_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_12content_size___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_12content_size___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.content_size.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6747: self: Memory,
6748: ) -> Address:
6749: r"""Actual content size.
6750:
6751: Returns:
6752: int: The sum of all block lengths.
6753:
6754: Examples:
6755: >>> Memory().content_size
6756: 0
6757: >>> Memory(start=1, endex=8).content_size
6758: 0
6759:
6760: ~~~
6761:
6762: +---+---+---+---+---+---+---+---+---+
6763: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6764: +===+===+===+===+===+===+===+===+===+
6765: | |[A | B | C]| |[x | y | z]| |
6766: +---+---+---+---+---+---+---+---+---+
6767:
6768: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6769: >>> memory.content_size
6770: 6
6771:
6772: ~~~
6773:
6774: +---+---+---+---+---+---+---+---+---+
6775: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6776: +===+===+===+===+===+===+===+===+===+
6777: | |[A | B | C]| | | | |)))|
6778: +---+---+---+---+---+---+---+---+---+
6779:
6780: >>> memory = Memory.from_blocks([[1, b'ABC']], endex=8)
6781: >>> memory.content_size
6782: 3
6783: """
6784:
+6785: return Memory_ContentSize(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_ContentSize(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6785, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6786:
6787: @property
+6788: def content_span(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_12content_span_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_12content_span_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_12content_span___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_12content_span___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.content_span.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6789: self: Memory,
6790: ) -> ClosedInterval:
6791: r"""tuple of int: Memory content address span.
6792:
6793: A :attr:`tuple` holding both :attr:`content_start` and
6794: :attr:`content_endex`.
6795:
6796: Examples:
6797: >>> Memory().content_span
6798: (0, 0)
6799: >>> Memory(start=1).content_span
6800: (1, 1)
6801: >>> Memory(endex=8).content_span
6802: (0, 0)
6803: >>> Memory(start=1, endex=8).content_span
6804: (1, 1)
6805:
6806: ~~~
6807:
6808: +---+---+---+---+---+---+---+---+---+
6809: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6810: +===+===+===+===+===+===+===+===+===+
6811: | |[A | B | C]| |[x | y | z]| |
6812: +---+---+---+---+---+---+---+---+---+
6813:
6814: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6815: >>> memory.content_span
6816: (1, 8)
6817: """
6818:
+6819: return Memory_ContentSpan(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_convert__to_py___pyx_ctuple_addr_t__and_addr_t(__pyx_f_11cbytesparse_1c_Memory_ContentSpan(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6819, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6820:
6821: @property
+6822: def content_start(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_start_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_13content_start_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_13content_start___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_13content_start___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.content_start.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6823: self: Memory,
6824: ) -> Address:
6825: r"""int: Inclusive content start address.
6826:
6827: This property holds the inclusive start address of the memory content.
6828: By default, it is the current minimum inclusive start address of
6829: the first stored block.
6830:
6831: If the memory has no data and no trimming, 0 is returned.
6832:
6833: Trimming is considered only for an empty memory.
6834:
6835: Examples:
6836: >>> Memory().content_start
6837: 0
6838: >>> Memory(start=1).content_start
6839: 1
6840: >>> Memory(start=1, endex=8).content_start
6841: 1
6842:
6843: ~~~
6844:
6845: +---+---+---+---+---+---+---+---+---+
6846: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6847: +===+===+===+===+===+===+===+===+===+
6848: | |[A | B | C]| |[x | y | z]| |
6849: +---+---+---+---+---+---+---+---+---+
6850:
6851: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
6852: >>> memory.content_start
6853: 1
6854:
6855: ~~~
6856:
6857: +---+---+---+---+---+---+---+---+---+
6858: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
6859: +===+===+===+===+===+===+===+===+===+
6860: | |[[[| | | |[x | y | z]| |
6861: +---+---+---+---+---+---+---+---+---+
6862:
6863: >>> memory = Memory.from_blocks([[5, b'xyz']], start=1)
6864: >>> memory.content_start
6865: 5
6866: """
6867:
+6868: return Memory_ContentStart(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_ContentStart(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6868, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6869:
6870: @property
+6871: def contiguous(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_10contiguous_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_10contiguous_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_10contiguous___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_10contiguous___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.contiguous.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
6872: self: Memory,
6873: ) -> bool:
6874: r"""bool: Contains contiguous data.
6875:
6876: The memory is considered to have contiguous data if there is no empty
6877: space between blocks.
6878:
6879: If trimming is defined, there must be no empty space also towards it.
6880: """
6881:
+6882: return Memory_Contiguous(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_f_11cbytesparse_1c_Memory_Contiguous(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6882, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
6883:
+6884: def count(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_75count(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_74count[] = "Memory.count(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> int\nCounts items.\n\n Arguments:\n item (items):\n Reference value to count.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The number of items equal to `value`.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[B | a | t]| |[t | a | b]|\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'Bat'], [9, b'tab']])\n >>> memory.count(b'a')\n 2\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_75count = {"count", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_75count, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_74count}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_75count(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("count (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_74count(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("count", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.count", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__110 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__110)) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__110); __Pyx_GIVEREF(__pyx_tuple__110); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6884, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_75count, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_count, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__111)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_count, __pyx_t_2) < 0) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__111 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__110, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_count, 6884, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__111)) __PYX_ERR(0, 6884, __pyx_L1_error)
6885: self: Memory,
+6886: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_2); __pyx_t_1 = 0; __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_item, __pyx_t_2) < 0) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6887: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6887, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6887, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6887, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_start, __pyx_t_6) < 0) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6888: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "count") < 0)) __PYX_ERR(0, 6884, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("count", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6884, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.count", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_74count(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_endex, __pyx_t_2) < 0) __PYX_ERR(0, 6884, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, __pyx_n_u_int) < 0) __PYX_ERR(0, 6884, __pyx_L1_error)
6889: ) -> int:
6890: r"""Counts items.
6891:
6892: Arguments:
6893: item (items):
6894: Reference value to count.
6895:
6896: start (int):
6897: Inclusive start of the searched range.
6898: If ``None``, :attr:`start` is considered.
6899:
6900: endex (int):
6901: Exclusive end of the searched range.
6902: If ``None``, :attr:`endex` is considered.
6903:
6904: Returns:
6905: int: The number of items equal to `value`.
6906:
6907: Example:
6908: +---+---+---+---+---+---+---+---+---+---+---+---+
6909: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
6910: +===+===+===+===+===+===+===+===+===+===+===+===+
6911: | |[A | B | C]| |[B | a | t]| |[t | a | b]|
6912: +---+---+---+---+---+---+---+---+---+---+---+---+
6913:
6914: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'Bat'], [9, b'tab']])
6915: >>> memory.count(b'a')
6916: 2
6917: """
6918:
+6919: return Memory_Count(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Count(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(__pyx_t_1 == ((addr_t)-1LL) && PyErr_Occurred())) __PYX_ERR(0, 6919, __pyx_L1_error) __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6919, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
6920:
+6921: def crop(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_77crop(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_76crop[] = "Memory.crop(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> None\nKeeps data within an address range.\n\n Arguments:\n start (int):\n Inclusive start address for cropping.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for cropping.\n If ``None``, :attr:`endex` is considered.\n\n Example:\n +---+---+---+---+---+---+---+---+---+\n | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n | | |[B | C]| |[x]| | | |\n +---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])\n >>> memory.crop(6, 10)\n >>> memory._blocks\n [[6, b'BC'], [9, b'x']]\n\n See Also:\n :meth:`crop_backup`\n :meth:`crop_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_77crop = {"crop", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_77crop, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_76crop}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_77crop(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("crop (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_76crop(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("crop", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.crop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__112 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__112)) __PYX_ERR(0, 6921, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__112); __Pyx_GIVEREF(__pyx_tuple__112); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6921, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6921, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_77crop, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_crop, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__113)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6921, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_crop, __pyx_t_9) < 0) __PYX_ERR(0, 6921, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__113 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__112, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_crop, 6921, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__113)) __PYX_ERR(0, 6921, __pyx_L1_error)
6922: self: Memory,
+6923: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_8); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_6) < 0) __PYX_ERR(0, 6921, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6924: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "crop") < 0)) __PYX_ERR(0, 6921, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("crop", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6921, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.crop", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_76crop(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6924, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6924, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_8); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6924, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 6921, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+6925: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 6921, __pyx_L1_error)
6926: r"""Keeps data within an address range.
6927:
6928: Arguments:
6929: start (int):
6930: Inclusive start address for cropping.
6931: If ``None``, :attr:`start` is considered.
6932:
6933: endex (int):
6934: Exclusive end address for cropping.
6935: If ``None``, :attr:`endex` is considered.
6936:
6937: Example:
6938: +---+---+---+---+---+---+---+---+---+
6939: | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
6940: +===+===+===+===+===+===+===+===+===+
6941: | |[A | B | C]| |[x | y | z]| |
6942: +---+---+---+---+---+---+---+---+---+
6943: | | |[B | C]| |[x]| | | |
6944: +---+---+---+---+---+---+---+---+---+
6945:
6946: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])
6947: >>> memory.crop(6, 10)
6948: >>> memory._blocks
6949: [[6, b'BC'], [9, b'x']]
6950:
6951: See Also:
6952: :meth:`crop_backup`
6953: :meth:`crop_restore`
6954: """
6955:
+6956: Memory_Crop(self._, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Crop(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 6956, __pyx_L1_error)
6957:
+6958: def crop_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_79crop_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_78crop_backup[] = "Memory.crop_backup(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> Tuple[Optional[Memory], Optional[Memory]]\nBackups a `crop()` operation.\n\n Arguments:\n start (int):\n Inclusive start address for cropping.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for cropping.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n :obj:`Memory` couple: Backup memory regions.\n\n See Also:\n :meth:`crop`\n :meth:`crop_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_79crop_backup = {"crop_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_79crop_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_78crop_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_79crop_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("crop_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_78crop_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { addr_t __pyx_v_start_; addr_t __pyx_v_endex_; Memory_ const *__pyx_v_memory; Rack_ const *__pyx_v_blocks; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup_start = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup_endex = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("crop_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.Memory.crop_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_backup_start); __Pyx_XDECREF((PyObject *)__pyx_v_backup_endex); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__114 = PyTuple_Pack(11, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_start_2, __pyx_n_s_endex_2, __pyx_n_s_memory, __pyx_n_s_blocks, __pyx_n_s_block_start, __pyx_n_s_block_endex, __pyx_n_s_backup_start, __pyx_n_s_backup_endex); if (unlikely(!__pyx_tuple__114)) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__114); __Pyx_GIVEREF(__pyx_tuple__114); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 6958, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_79crop_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_crop_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__115)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_crop_backup, __pyx_t_1) < 0) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__115 = (PyObject*)__Pyx_PyCode_New(3, 0, 11, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__114, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_crop_backup, 6958, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__115)) __PYX_ERR(0, 6958, __pyx_L1_error)
6959: self: Memory,
+6960: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6960, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6960, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6960, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_start, __pyx_t_6) < 0) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+6961: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "crop_backup") < 0)) __PYX_ERR(0, 6958, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("crop_backup", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 6958, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.crop_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_78crop_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6961, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6961, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6961, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_endex, __pyx_t_2) < 0) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6962: ) -> Tuple[Optional[Memory], Optional[Memory]]:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Optional); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_8, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Optional); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_8, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_1); __pyx_t_6 = 0; __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 6962, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, __pyx_t_1) < 0) __PYX_ERR(0, 6958, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
6963: r"""Backups a `crop()` operation.
6964:
6965: Arguments:
6966: start (int):
6967: Inclusive start address for cropping.
6968: If ``None``, :attr:`start` is considered.
6969:
6970: endex (int):
6971: Exclusive end address for cropping.
6972: If ``None``, :attr:`endex` is considered.
6973:
6974: Returns:
6975: :obj:`Memory` couple: Backup memory regions.
6976:
6977: See Also:
6978: :meth:`crop`
6979: :meth:`crop_restore`
6980: """
6981: cdef:
6982: addr_t start_
6983: addr_t endex_
+6984: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+6985: const Rack_* blocks = memory.blocks
__pyx_t_2 = __pyx_v_memory->blocks; __pyx_v_blocks = __pyx_t_2;
6986: addr_t block_start
6987: addr_t block_endex
+6988: Memory backup_start = None
__Pyx_INCREF(Py_None);
__pyx_v_backup_start = ((struct __pyx_obj_11cbytesparse_1c_Memory *)Py_None);
+6989: Memory backup_endex = None
__Pyx_INCREF(Py_None);
__pyx_v_backup_endex = ((struct __pyx_obj_11cbytesparse_1c_Memory *)Py_None);
6990:
+6991: if Rack_Length(blocks):
__pyx_t_3 = (__pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks) != 0); if (__pyx_t_3) { /* … */ }
+6992: if start is not None:
__pyx_t_3 = (__pyx_v_start != Py_None); __pyx_t_4 = (__pyx_t_3 != 0); if (__pyx_t_4) { /* … */ }
+6993: start_ = <addr_t>start
__pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6993, __pyx_L1_error) __pyx_v_start_ = ((addr_t)__pyx_t_5);
+6994: block_start = Block_Start(Rack_First__(blocks))
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_f_11cbytesparse_1c_Rack_First__(__pyx_v_blocks));
+6995: if block_start < start_:
__pyx_t_4 = ((__pyx_v_block_start < __pyx_v_start_) != 0); if (__pyx_t_4) { /* … */ }
+6996: backup_start = Memory_Extract_(memory, block_start, start_, 0, NULL, 1, True)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_v_block_start, __pyx_v_start_, 0, NULL, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 6996, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (!(likely(((__pyx_t_6) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_6, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 6996, __pyx_L1_error) __Pyx_DECREF_SET(__pyx_v_backup_start, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_6)); __pyx_t_6 = 0;
6997:
+6998: if endex is not None:
__pyx_t_4 = (__pyx_v_endex != Py_None); __pyx_t_3 = (__pyx_t_4 != 0); if (__pyx_t_3) { /* … */ }
+6999: endex_ = <addr_t>endex
__pyx_t_5 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_5 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 6999, __pyx_L1_error) __pyx_v_endex_ = ((addr_t)__pyx_t_5);
+7000: block_endex = Block_Endex(Rack_Last__(blocks))
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks));
+7001: if endex_ < block_endex:
__pyx_t_3 = ((__pyx_v_endex_ < __pyx_v_block_endex) != 0); if (__pyx_t_3) { /* … */ }
+7002: backup_endex = Memory_Extract_(memory, endex_, block_endex, 0, NULL, 1, True)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_v_endex_, __pyx_v_block_endex, 0, NULL, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7002, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (!(likely(((__pyx_t_6) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_6, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 7002, __pyx_L1_error) __Pyx_DECREF_SET(__pyx_v_backup_endex, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_6)); __pyx_t_6 = 0;
7003:
+7004: return backup_start, backup_endex
__Pyx_XDECREF(__pyx_r); __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7004, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_INCREF(((PyObject *)__pyx_v_backup_start)); __Pyx_GIVEREF(((PyObject *)__pyx_v_backup_start)); PyTuple_SET_ITEM(__pyx_t_6, 0, ((PyObject *)__pyx_v_backup_start)); __Pyx_INCREF(((PyObject *)__pyx_v_backup_endex)); __Pyx_GIVEREF(((PyObject *)__pyx_v_backup_endex)); PyTuple_SET_ITEM(__pyx_t_6, 1, ((PyObject *)__pyx_v_backup_endex)); __pyx_r = __pyx_t_6; __pyx_t_6 = 0; goto __pyx_L0;
7005:
+7006: def crop_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_81crop_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_80crop_restore[] = "Memory.crop_restore(self: Memory, backup_start: Optional[Memory], backup_endex: Optional[Memory]) -> None\nRestores a `crop()` operation.\n\n Arguments:\n backup_start (:obj:`Memory`):\n Backup memory region to restore at the beginning.\n\n backup_endex (:obj:`Memory`):\n Backup memory region to restore at the end.\n\n See Also:\n :meth:`crop`\n :meth:`crop_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_81crop_restore = {"crop_restore", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_81crop_restore, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_80crop_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_81crop_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_backup_start = 0; PyObject *__pyx_v_backup_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("crop_restore (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_backup_start,&__pyx_n_s_backup_endex,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_backup_start)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_backup_endex)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("crop_restore", 1, 2, 2, 1); __PYX_ERR(0, 7006, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "crop_restore") < 0)) __PYX_ERR(0, 7006, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_backup_start = values[0]; __pyx_v_backup_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("crop_restore", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7006, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.crop_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_80crop_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_backup_start, __pyx_v_backup_endex); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_80crop_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_backup_start, PyObject *__pyx_v_backup_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("crop_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.crop_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__116 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_backup_start, __pyx_n_s_backup_endex); if (unlikely(!__pyx_tuple__116)) __PYX_ERR(0, 7006, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__116); __Pyx_GIVEREF(__pyx_tuple__116); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7006, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7006, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_81crop_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_crop_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__117)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7006, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_crop_restore, __pyx_t_9) < 0) __PYX_ERR(0, 7006, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__117 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__116, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_crop_restore, 7006, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__117)) __PYX_ERR(0, 7006, __pyx_L1_error)
7007: self: Memory,
+7008: backup_start: Optional[Memory],
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7008, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_8 = __Pyx_PyObject_GetItem(__pyx_t_9, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7008, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_backup_start, __pyx_t_8) < 0) __PYX_ERR(0, 7006, __pyx_L1_error) __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
+7009: backup_endex: Optional[Memory],
__Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Optional); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7009, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_8, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7009, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_backup_endex, __pyx_t_9) < 0) __PYX_ERR(0, 7006, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7010: ) -> None:
if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7006, __pyx_L1_error)
7011: r"""Restores a `crop()` operation.
7012:
7013: Arguments:
7014: backup_start (:obj:`Memory`):
7015: Backup memory region to restore at the beginning.
7016:
7017: backup_endex (:obj:`Memory`):
7018: Backup memory region to restore at the end.
7019:
7020: See Also:
7021: :meth:`crop`
7022: :meth:`crop_backup`
7023: """
7024:
+7025: if backup_start is not None:
__pyx_t_1 = (__pyx_v_backup_start != Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ }
+7026: Memory_WriteSame_(self._, 0, (<Memory>backup_start)._, True)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_self->_, 0, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_backup_start)->_, 1); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7026, __pyx_L1_error)
+7027: if backup_endex is not None:
__pyx_t_2 = (__pyx_v_backup_endex != Py_None); __pyx_t_1 = (__pyx_t_2 != 0); if (__pyx_t_1) { /* … */ }
+7028: Memory_WriteSame_(self._, 0, (<Memory>backup_endex)._, True)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_self->_, 0, ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_backup_endex)->_, 1); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7028, __pyx_L1_error)
7029:
+7030: def delete(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_83delete(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_82delete[] = "Memory.delete(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> None\nDeletes an address range.\n\n Arguments:\n start (int):\n Inclusive start address for deletion.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for deletion.\n If ``None``, :attr:`endex` is considered.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+\n | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12| 13|\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[A | y | z]| | | | | | |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])\n >>> memory.delete(6, 10)\n >>> memory._blocks\n [[5, b'Ayz']]\n\n See Also:\n :meth:`delete_backup`\n :meth:`delete_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_83delete = {"delete", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_83delete, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_82delete}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_83delete(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("delete (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_82delete(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("delete", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.delete", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__118 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__118)) __PYX_ERR(0, 7030, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__118); __Pyx_GIVEREF(__pyx_tuple__118); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7030, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7030, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_83delete, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_delete, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__119)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7030, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_delete, __pyx_t_1) < 0) __PYX_ERR(0, 7030, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__119 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__118, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_delete, 7030, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__119)) __PYX_ERR(0, 7030, __pyx_L1_error)
7031: self: Memory,
+7032: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7032, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7032, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7032, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 7030, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7033: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "delete") < 0)) __PYX_ERR(0, 7030, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("delete", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7030, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.delete", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_82delete(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7033, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7033, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7033, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_endex, __pyx_t_1) < 0) __PYX_ERR(0, 7030, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+7034: ) -> None:
if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7030, __pyx_L1_error)
7035: r"""Deletes an address range.
7036:
7037: Arguments:
7038: start (int):
7039: Inclusive start address for deletion.
7040: If ``None``, :attr:`start` is considered.
7041:
7042: endex (int):
7043: Exclusive end address for deletion.
7044: If ``None``, :attr:`endex` is considered.
7045:
7046: Example:
7047: +---+---+---+---+---+---+---+---+---+---+
7048: | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12| 13|
7049: +===+===+===+===+===+===+===+===+===+===+
7050: | |[A | B | C]| | |[x | y | z]| |
7051: +---+---+---+---+---+---+---+---+---+---+
7052: | |[A | y | z]| | | | | | |
7053: +---+---+---+---+---+---+---+---+---+---+
7054:
7055: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])
7056: >>> memory.delete(6, 10)
7057: >>> memory._blocks
7058: [[5, b'Ayz']]
7059:
7060: See Also:
7061: :meth:`delete_backup`
7062: :meth:`delete_restore`
7063: """
7064:
+7065: Memory_Delete(self._, start, endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Delete(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7065, __pyx_L1_error)
7066:
+7067: def delete_backup(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_85delete_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_84delete_backup[] = "Memory.delete_backup(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> Memory\nBackups a `delete()` operation.\n\n Arguments:\n start (int):\n Inclusive start address for deletion.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for deletion.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n :obj:`Memory`: Backup memory region.\n\n See Also:\n :meth:`delete`\n :meth:`delete_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_85delete_backup = {"delete_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_85delete_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_84delete_backup}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_85delete_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("delete_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_84delete_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { Memory_ const *__pyx_v_memory; addr_t __pyx_v_start_; addr_t __pyx_v_endex_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("delete_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.delete_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__120 = PyTuple_Pack(6, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_memory, __pyx_n_s_start_2, __pyx_n_s_endex_2); if (unlikely(!__pyx_tuple__120)) __PYX_ERR(0, 7067, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__120); __Pyx_GIVEREF(__pyx_tuple__120); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7067, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7067, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_85delete_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_delete_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__121)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7067, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_delete_backup, __pyx_t_9) < 0) __PYX_ERR(0, 7067, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__121 = (PyObject*)__Pyx_PyCode_New(3, 0, 6, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__120, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_delete_backup, 7067, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__121)) __PYX_ERR(0, 7067, __pyx_L1_error)
7068: self: Memory,
+7069: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7069, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7069, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7069, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 7067, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7070: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "delete_backup") < 0)) __PYX_ERR(0, 7067, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("delete_backup", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7067, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.delete_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_84delete_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7070, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7070, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7070, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 7067, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7067, __pyx_L1_error)
7071: ) -> Memory:
7072: r"""Backups a `delete()` operation.
7073:
7074: Arguments:
7075: start (int):
7076: Inclusive start address for deletion.
7077: If ``None``, :attr:`start` is considered.
7078:
7079: endex (int):
7080: Exclusive end address for deletion.
7081: If ``None``, :attr:`endex` is considered.
7082:
7083: Returns:
7084: :obj:`Memory`: Backup memory region.
7085:
7086: See Also:
7087: :meth:`delete`
7088: :meth:`delete_restore`
7089: """
7090: cdef:
+7091: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+7092: addr_t start_ = Memory_Start(memory) if start is None else <addr_t>start
__pyx_t_3 = (__pyx_v_start == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7092, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_start_ = __pyx_t_2;
+7093: addr_t endex_ = Memory_Endex(memory) if endex is None else <addr_t>endex
__pyx_t_3 = (__pyx_v_endex == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7093, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_endex_ = __pyx_t_2;
7094:
+7095: return Memory_Extract_(memory, start_, endex_, 0, NULL, 1, True)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_v_start_, __pyx_v_endex_, 0, NULL, 1, 1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7095, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (!(likely(((__pyx_t_5) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_5, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 7095, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L0;
7096:
+7097: def delete_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_87delete_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_86delete_restore[] = "Memory.delete_restore(self: Memory, Memory backup: Memory) -> None\nRestores a `delete()` operation.\n\n Arguments:\n backup (:obj:`Memory`):\n Backup memory region\n\n See Also:\n :meth:`delete`\n :meth:`delete_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_87delete_restore = {"delete_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_87delete_restore, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_86delete_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_87delete_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("delete_restore (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 7099, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_86delete_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_backup)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_86delete_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("delete_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.delete_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__122 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__122)) __PYX_ERR(0, 7097, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__122); __Pyx_GIVEREF(__pyx_tuple__122); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7097, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7097, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7097, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_87delete_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_delete_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__123)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7097, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_delete_restore, __pyx_t_1) < 0) __PYX_ERR(0, 7097, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__123 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__122, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_delete_restore, 7097, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__123)) __PYX_ERR(0, 7097, __pyx_L1_error)
7098: self: Memory,
7099: Memory backup not None: Memory,
+7100: ) -> None:
if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7097, __pyx_L1_error)
7101: r"""Restores a `delete()` operation.
7102:
7103: Arguments:
7104: backup (:obj:`Memory`):
7105: Backup memory region
7106:
7107: See Also:
7108: :meth:`delete`
7109: :meth:`delete_backup`
7110: """
7111:
+7112: Memory_InsertSame_(self._, 0, backup._)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_InsertSame_(__pyx_v_self->_, 0, __pyx_v_backup->_); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7112, __pyx_L1_error)
7113:
7114: @property
+7115: def endex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5endex_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5endex_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_5endex___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_5endex___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.endex.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
7116: self: Memory,
7117: ) -> Address:
7118: r"""int: Exclusive end address.
7119:
7120: This property holds the exclusive end address of the virtual space.
7121: By default, it is the current maximmum exclusive end address of
7122: the last stored block.
7123:
7124: If :attr:`trim_endex` not ``None``, that is returned.
7125:
7126: If the memory has no data and no trimming, :attr:`start` is returned.
7127:
7128: Examples:
7129: >>> Memory().endex
7130: 0
7131:
7132: ~~~
7133:
7134: +---+---+---+---+---+---+---+---+---+
7135: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
7136: +===+===+===+===+===+===+===+===+===+
7137: | |[A | B | C]| |[x | y | z]| |
7138: +---+---+---+---+---+---+---+---+---+
7139:
7140: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
7141: >>> memory.endex
7142: 8
7143:
7144: ~~~
7145:
7146: +---+---+---+---+---+---+---+---+---+
7147: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
7148: +===+===+===+===+===+===+===+===+===+
7149: | |[A | B | C]| | | | |)))|
7150: +---+---+---+---+---+---+---+---+---+
7151:
7152: >>> memory = Memory.from_blocks([[1, b'ABC']], endex=8)
7153: >>> memory.endex
7154: 8
7155: """
7156:
+7157: return Memory_Endex(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7157, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
7158:
7159: @property
+7160: def endin(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5endin_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5endin_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_5endin___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_5endin___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.endin.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
7161: self: Memory,
7162: ) -> Address:
7163: r"""int: Inclusive end address.
7164:
7165: This property holds the inclusive end address of the virtual space.
7166: By default, it is the current maximmum inclusive end address of
7167: the last stored block.
7168:
7169: If :attr:`trim_endex` not ``None``, that minus one is returned.
7170:
7171: If the memory has no data and no trimming, :attr:`start` is returned.
7172:
7173: Examples:
7174: >>> Memory().endin
7175: -1
7176:
7177: ~~~
7178:
7179: +---+---+---+---+---+---+---+---+---+
7180: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
7181: +===+===+===+===+===+===+===+===+===+
7182: | |[A | B | C]| |[x | y | z]| |
7183: +---+---+---+---+---+---+---+---+---+
7184:
7185: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
7186: >>> memory.endin
7187: 7
7188:
7189: ~~~
7190:
7191: +---+---+---+---+---+---+---+---+---+
7192: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
7193: +===+===+===+===+===+===+===+===+===+
7194: | |[A | B | C]| | | | |)))|
7195: +---+---+---+---+---+---+---+---+---+
7196:
7197: >>> memory = Memory.from_blocks([[1, b'ABC']], endex=8)
7198: >>> memory.endin
7199: 7
7200: """
7201:
+7202: return Memory_Endin(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Endin(__pyx_v_self->_); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7202, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
7203:
+7204: def equal_span(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_89equal_span(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_88equal_span[] = "Memory.equal_span(self: Memory, address: Address) -> Tuple[Optional[Address], Optional[Address], Optional[Value]]\nSpan of homogeneous data.\n\n It searches for the biggest chunk of data adjacent to the given\n address, with the same value at that address.\n\n If the address is within a gap, its bounds are returned, and its\n value is ``None``.\n\n If the address is before or after any data, bounds are ``None``.\n\n Arguments:\n address (int):\n Reference address.\n\n Returns:\n tuple: Start bound, exclusive end bound, and reference value.\n\n Examples:\n >>> memory = Memory()\n >>> memory.equal_span(0)\n (None, None, None)\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|\n +===+===+===+===+===+===+===+===+===+===+===+\n |[A | B | B | B | C]| | |[C | C | D]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n | 65| 66| 66| 66| 67| | | 67| 67| 68| |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[0, b'ABBBC'], [7, b'CCD']])\n >>> memory.equal_span(2)\n (1, 4, 66)\n >>> memory.equal_span(4)\n (4, 5, 67)\n >>> memory.equal_span(5)\n (5, 7, None)\n >>> memory.equal_span(10)\n (10, None, None)\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_89equal_span = {"equal_span", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_89equal_span, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_88equal_span}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_89equal_span(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("equal_span (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_88equal_span(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_88equal_span(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { Rack_ const *__pyx_v_blocks; size_t __pyx_v_block_count; size_t __pyx_v_block_index; Block_ const *__pyx_v_block; addr_t __pyx_v_block_start; addr_t __pyx_v_block_endex; addr_t __pyx_v_address_; addr_t __pyx_v_start; addr_t __pyx_v_endex; size_t __pyx_v_offset; byte_t __pyx_v_value; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("equal_span", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("cbytesparse.c.Memory.equal_span", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__124 = PyTuple_Pack(15, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_blocks, __pyx_n_s_block_count, __pyx_n_s_block_index, __pyx_n_s_block_index_start_2, __pyx_n_s_block_index_endex_2, __pyx_n_s_block, __pyx_n_s_block_start, __pyx_n_s_block_endex, __pyx_n_s_address_2, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_offset, __pyx_n_s_value); if (unlikely(!__pyx_tuple__124)) __PYX_ERR(0, 7204, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__124); __Pyx_GIVEREF(__pyx_tuple__124); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7204, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7204, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_89equal_span, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_equal_span, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__125)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7204, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_equal_span, __pyx_t_5) < 0) __PYX_ERR(0, 7204, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__125 = (PyObject*)__Pyx_PyCode_New(2, 0, 15, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__124, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_equal_span, 7204, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__125)) __PYX_ERR(0, 7204, __pyx_L1_error)
7205: self: Memory,
+7206: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7206, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_address, __pyx_t_9) < 0) __PYX_ERR(0, 7204, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7207: ) -> Tuple[Optional[Address], Optional[Address], Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Optional); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_8, __pyx_t_2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Address); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_Optional); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_8, __pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyTuple_New(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_2, 2, __pyx_t_5); __pyx_t_6 = 0; __pyx_t_7 = 0; __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7207, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_t_5) < 0) __PYX_ERR(0, 7204, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
7208: r"""Span of homogeneous data.
7209:
7210: It searches for the biggest chunk of data adjacent to the given
7211: address, with the same value at that address.
7212:
7213: If the address is within a gap, its bounds are returned, and its
7214: value is ``None``.
7215:
7216: If the address is before or after any data, bounds are ``None``.
7217:
7218: Arguments:
7219: address (int):
7220: Reference address.
7221:
7222: Returns:
7223: tuple: Start bound, exclusive end bound, and reference value.
7224:
7225: Examples:
7226: >>> memory = Memory()
7227: >>> memory.equal_span(0)
7228: (None, None, None)
7229:
7230: ~~~
7231:
7232: +---+---+---+---+---+---+---+---+---+---+---+
7233: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|
7234: +===+===+===+===+===+===+===+===+===+===+===+
7235: |[A | B | B | B | C]| | |[C | C | D]| |
7236: +---+---+---+---+---+---+---+---+---+---+---+
7237: | 65| 66| 66| 66| 67| | | 67| 67| 68| |
7238: +---+---+---+---+---+---+---+---+---+---+---+
7239:
7240: >>> memory = Memory.from_blocks([[0, b'ABBBC'], [7, b'CCD']])
7241: >>> memory.equal_span(2)
7242: (1, 4, 66)
7243: >>> memory.equal_span(4)
7244: (4, 5, 67)
7245: >>> memory.equal_span(5)
7246: (5, 7, None)
7247: >>> memory.equal_span(10)
7248: (10, None, None)
7249: """
7250: cdef:
+7251: const Rack_* blocks = self._.blocks
__pyx_t_1 = __pyx_v_self->_->blocks; __pyx_v_blocks = __pyx_t_1;
+7252: size_t block_count = Rack_Length(blocks)
__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_v_blocks);
7253: size_t block_index
7254: size_t block_index_start
7255: size_t block_index_endex
7256: const Block_* block
7257: addr_t block_start
7258: addr_t block_endex
+7259: addr_t address_ = <addr_t>address
__pyx_t_2 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_2 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7259, __pyx_L1_error) __pyx_v_address_ = ((addr_t)__pyx_t_2);
7260: addr_t start
7261: addr_t endex
7262: size_t offset
7263: byte_t value
7264:
+7265: block_index = Rack_IndexStart(blocks, address_)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_v_blocks, __pyx_v_address_); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 7265, __pyx_L1_error)
__pyx_v_block_index = __pyx_t_3;
7266:
+7267: if block_index < block_count:
__pyx_t_4 = ((__pyx_v_block_index < __pyx_v_block_count) != 0); if (__pyx_t_4) { /* … */ }
+7268: block = Rack_Get__(blocks, block_index)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, __pyx_v_block_index);
+7269: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+7270: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
7271:
+7272: if block_start <= address_ < block_endex:
__pyx_t_4 = (__pyx_v_block_start <= __pyx_v_address_); if (__pyx_t_4) { __pyx_t_4 = (__pyx_v_address_ < __pyx_v_block_endex); } __pyx_t_5 = (__pyx_t_4 != 0); if (__pyx_t_5) { /* … */ }
7273: # Address within a block
+7274: CheckSubAddrU(address_, block_start)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_CheckSubAddrU(__pyx_v_address_, __pyx_v_block_start); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7274, __pyx_L1_error)
+7275: CheckAddrToSizeU(address - block_start)
__pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7275, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_8 = PyNumber_Subtract(__pyx_v_address, __pyx_t_7); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7275, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_t_2 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_8); if (unlikely((__pyx_t_2 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7275, __pyx_L1_error) __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_6 = __pyx_f_11cbytesparse_1c_CheckAddrToSizeU(__pyx_t_2); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7275, __pyx_L1_error)
+7276: offset = <size_t>(address_ - block_start)
__pyx_v_offset = ((size_t)(__pyx_v_address_ - __pyx_v_block_start));
+7277: start = offset
__pyx_v_start = __pyx_v_offset;
+7278: CheckAddAddrU(offset, 1)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_offset, 1); if (unlikely(__pyx_t_6 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7278, __pyx_L1_error)
+7279: endex = offset + 1
__pyx_v_endex = (__pyx_v_offset + 1);
+7280: value = Block_Get__(block, offset)
__pyx_v_value = __pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_block, __pyx_v_offset);
7281:
+7282: for start in range(start + 1, 0, -1):
for (__pyx_t_2 = (__pyx_v_start + 1) + 1; __pyx_t_2 > 0 + 1; ) { __pyx_t_2-=1; __pyx_v_start = __pyx_t_2;
+7283: if Block_Get__(block, start - 1) != value:
__pyx_t_5 = ((__pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_block, (__pyx_v_start - 1)) != __pyx_v_value) != 0); if (__pyx_t_5) { /* … */ } } /*else*/ {
+7284: break
goto __pyx_L6_break;
7285: else:
+7286: start = 0
__pyx_v_start = 0; } __pyx_L6_break:;
7287:
+7288: for endex in range(endex, Block_Length(block)):
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block); __pyx_t_10 = __pyx_t_9; for (__pyx_t_2 = __pyx_v_endex; __pyx_t_2 < __pyx_t_10; __pyx_t_2+=1) { __pyx_v_endex = __pyx_t_2;
+7289: if Block_Get__(block, endex) != value:
__pyx_t_5 = ((__pyx_f_11cbytesparse_1c_Block_Get__(__pyx_v_block, __pyx_v_endex) != __pyx_v_value) != 0); if (__pyx_t_5) { /* … */ } } /*else*/ {
+7290: break
goto __pyx_L9_break;
7291: else:
+7292: endex = Block_Length(block)
__pyx_v_endex = __pyx_f_11cbytesparse_1c_Block_Length(__pyx_v_block); } __pyx_L9_break:;
7293:
+7294: block_endex = block_start + endex
__pyx_v_block_endex = (__pyx_v_block_start + __pyx_v_endex);
+7295: block_start = block_start + start
__pyx_v_block_start = (__pyx_v_block_start + __pyx_v_start);
+7296: return block_start, block_endex, value # equal data span
__Pyx_XDECREF(__pyx_r); __pyx_t_8 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7296, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_endex); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7296, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_11 = __Pyx_PyInt_From_byte_t(__pyx_v_value); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 7296, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_11); __pyx_t_12 = PyTuple_New(3); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 7296, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_GIVEREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_12, 2, __pyx_t_11); __pyx_t_8 = 0; __pyx_t_7 = 0; __pyx_t_11 = 0; __pyx_r = __pyx_t_12; __pyx_t_12 = 0; goto __pyx_L0;
7297:
+7298: elif block_index:
__pyx_t_5 = (__pyx_v_block_index != 0); if (__pyx_t_5) { /* … */ }
7299: # Address within a gap
+7300: block_endex = block_start # end gap before next block
__pyx_v_block_endex = __pyx_v_block_start;
+7301: block = Rack_Get__(blocks, block_index - 1)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_v_blocks, (__pyx_v_block_index - 1));
+7302: block_start = Block_Endex(block) # start gap after previous block
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+7303: return block_start, block_endex, None # gap span
__Pyx_XDECREF(__pyx_r); __pyx_t_12 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 7303, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_12); __pyx_t_11 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_endex); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 7303, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_11); __pyx_t_7 = PyTuple_New(3); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7303, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_12); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_12); __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_11); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_7, 2, Py_None); __pyx_t_12 = 0; __pyx_t_11 = 0; __pyx_r = __pyx_t_7; __pyx_t_7 = 0; goto __pyx_L0;
7304:
7305: else:
7306: # Address before content
+7307: return None, block_start, None # open left
/*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_start); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7307, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_11 = PyTuple_New(3); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 7307, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_11); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_11, 0, Py_None); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_11, 1, __pyx_t_7); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_11, 2, Py_None); __pyx_t_7 = 0; __pyx_r = __pyx_t_11; __pyx_t_11 = 0; goto __pyx_L0; }
7308:
7309: else:
7310: # Address after content
+7311: if block_count:
/*else*/ { __pyx_t_5 = (__pyx_v_block_count != 0); if (__pyx_t_5) { /* … */ }
+7312: block = Rack_Last__(blocks)
__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Last__(__pyx_v_blocks);
+7313: block_start = Block_Start(block)
__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_v_block);
+7314: block_endex = Block_Endex(block)
__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_v_block);
+7315: return block_endex, None, None # open right
__Pyx_XDECREF(__pyx_r); __pyx_t_11 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_block_endex); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 7315, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_11); __pyx_t_7 = PyTuple_New(3); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7315, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_11); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_7, 1, Py_None); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_7, 2, Py_None); __pyx_t_11 = 0; __pyx_r = __pyx_t_7; __pyx_t_7 = 0; goto __pyx_L0;
7316:
7317: else:
+7318: return None, None, None # fully open
/*else*/ { __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_tuple__29); __pyx_r = __pyx_tuple__29; goto __pyx_L0; } }
7319:
+7320: def extend(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_91extend(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_90extend[] = "Memory.extend(self: Memory, items: Union[AnyBytes, Memory], offset: Address = 0) -> None\nConcatenates items.\n\n Equivalent to ``self += items``.\n\n Arguments:\n items (items):\n Items to append at the end of the current virtual space.\n\n offset (int):\n Optional offset w.r.t. :attr:`content_endex`.\n\n See Also:\n :meth:`extend_backup`\n :meth:`extend_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_91extend = {"extend", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_91extend, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_90extend}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_91extend(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_items = 0; PyObject *__pyx_v_offset = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extend (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_items,&__pyx_n_s_offset,0}; PyObject* values[2] = {0,0}; values[1] = ((PyObject *)__pyx_int_0); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_items)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "extend") < 0)) __PYX_ERR(0, 7320, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_items = values[0]; __pyx_v_offset = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("extend", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7320, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.extend", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_90extend(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_items, __pyx_v_offset); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_90extend(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_items, PyObject *__pyx_v_offset) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extend", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.extend", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__126 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_items, __pyx_n_s_offset); if (unlikely(!__pyx_tuple__126)) __PYX_ERR(0, 7320, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__126); __Pyx_GIVEREF(__pyx_tuple__126); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7320, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7320, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_91extend, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_extend, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__127)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7320, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_extend, __pyx_t_2) < 0) __PYX_ERR(0, 7320, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__127 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__126, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_extend, 7320, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__127)) __PYX_ERR(0, 7320, __pyx_L1_error)
7321: self: Memory,
+7322: items: Union[AnyBytes, Memory],
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Union); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7322, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7322, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7322, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_2); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_9, 1, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7322, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_items, __pyx_t_2) < 0) __PYX_ERR(0, 7320, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7323: offset: Address = 0,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7323, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_offset, __pyx_t_2) < 0) __PYX_ERR(0, 7320, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7324: ) -> None:
if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7320, __pyx_L1_error)
7325: r"""Concatenates items.
7326:
7327: Equivalent to ``self += items``.
7328:
7329: Arguments:
7330: items (items):
7331: Items to append at the end of the current virtual space.
7332:
7333: offset (int):
7334: Optional offset w.r.t. :attr:`content_endex`.
7335:
7336: See Also:
7337: :meth:`extend_backup`
7338: :meth:`extend_restore`
7339: """
7340:
+7341: return Memory_Extend(self._, items, offset)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Extend(__pyx_v_self->_, __pyx_v_items, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7341, __pyx_L1_error) __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7341, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
7342:
+7343: def extend_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_93extend_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_92extend_backup[] = "Memory.extend_backup(self: Memory, offset: Address = 0) -> Address\nBackups an `extend()` operation.\n\n Arguments:\n items (items):\n Items to append at the end of the current virtual space.\n\n offset (int):\n Optional offset w.r.t. :attr:`content_endex`.\n\n Returns:\n int: Content exclusive end address.\n\n See Also:\n :meth:`extend`\n :meth:`extend_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_93extend_backup = {"extend_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_93extend_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_92extend_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_93extend_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_offset = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extend_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_offset,0}; PyObject* values[1] = {0}; values[0] = ((PyObject *)__pyx_int_0); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset); if (value) { values[0] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "extend_backup") < 0)) __PYX_ERR(0, 7343, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_offset = values[0]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("extend_backup", 0, 0, 1, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7343, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.extend_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_92extend_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_offset); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_92extend_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_offset) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extend_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.extend_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__128 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_offset); if (unlikely(!__pyx_tuple__128)) __PYX_ERR(0, 7343, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__128); __Pyx_GIVEREF(__pyx_tuple__128); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7343, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7343, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_93extend_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_extend_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__129)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7343, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_extend_backup, __pyx_t_5) < 0) __PYX_ERR(0, 7343, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__129 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__128, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_extend_backup, 7343, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__129)) __PYX_ERR(0, 7343, __pyx_L1_error)
7344: self: Memory,
+7345: offset: Address = 0,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7345, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_offset, __pyx_t_5) < 0) __PYX_ERR(0, 7343, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7346: ) -> Address:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7346, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_5) < 0) __PYX_ERR(0, 7343, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
7347: r"""Backups an `extend()` operation.
7348:
7349: Arguments:
7350: items (items):
7351: Items to append at the end of the current virtual space.
7352:
7353: offset (int):
7354: Optional offset w.r.t. :attr:`content_endex`.
7355:
7356: Returns:
7357: int: Content exclusive end address.
7358:
7359: See Also:
7360: :meth:`extend`
7361: :meth:`extend_restore`
7362: """
7363:
+7364: return Memory_ContentEndex(self._) + <addr_t>offset
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_offset); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7364, __pyx_L1_error) __pyx_t_2 = __Pyx_PyInt_From_uint_fast64_t((__pyx_f_11cbytesparse_1c_Memory_ContentEndex(__pyx_v_self->_) + ((addr_t)__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7364, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
7365:
+7366: def extend_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_95extend_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_content_endex); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_94extend_restore[] = "Memory.extend_restore(self: Memory, content_endex: Address) -> None\nRestores an `extend()` operation.\n\n Arguments:\n content_endex (int):\n Content exclusive end address to restore.\n\n See Also:\n :meth:`extend`\n :meth:`extend_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_95extend_restore = {"extend_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_95extend_restore, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_94extend_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_95extend_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_content_endex) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extend_restore (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_94extend_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_content_endex)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_94extend_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_content_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extend_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.extend_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__130 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_content_endex); if (unlikely(!__pyx_tuple__130)) __PYX_ERR(0, 7366, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__130); __Pyx_GIVEREF(__pyx_tuple__130); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7366, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7366, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_95extend_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_extend_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__131)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7366, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_extend_restore, __pyx_t_2) < 0) __PYX_ERR(0, 7366, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__131 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__130, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_extend_restore, 7366, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__131)) __PYX_ERR(0, 7366, __pyx_L1_error)
7367: self: Memory,
+7368: content_endex: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7368, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_content_endex, __pyx_t_2) < 0) __PYX_ERR(0, 7366, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7369: ) -> None:
if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7366, __pyx_L1_error)
7370: r"""Restores an `extend()` operation.
7371:
7372: Arguments:
7373: content_endex (int):
7374: Content exclusive end address to restore.
7375:
7376: See Also:
7377: :meth:`extend`
7378: :meth:`extend_backup`
7379: """
7380:
+7381: Memory_Clear_(self._, <addr_t>content_endex, ADDR_MAX)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_content_endex); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7381, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Clear_(__pyx_v_self->_, ((addr_t)__pyx_t_1), ADDR_MAX); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7381, __pyx_L1_error)
7382:
+7383: def extract(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_97extract(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_96extract[] = "Memory.extract(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None, pattern: Optional[Union[AnyBytes, Value]] = None, step: Optional[Address] = None, bound: bool = True) -> Memory\nSelects items from a range.\n\n Arguments:\n start (int):\n Inclusive start of the extracted range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the extracted range.\n If ``None``, :attr:`endex` is considered.\n\n pattern (items):\n Optional pattern of items to fill the emptiness.\n\n step (int):\n Optional address stepping between bytes extracted from the\n range. It has the same meaning of Python's :attr:`slice.step`,\n but negative steps are ignored.\n Please note that a `step` greater than 1 could take much more\n time to process than the default unitary step.\n\n bound (bool):\n The selected address range is applied to the resulting memory\n as its trimming range. This retains information about any\n initial and final emptiness of that range, which would be lost\n otherwise.\n\n Returns:\n :obj:`Memory`: A copy of the memory from the selected range.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> memory.extract()._blocks\n [[1, b'ABCD'], [6, b'$'], [8, b'xyz']]\n >>> memory.extract(2, 9)._blocks\n [[2, b'BCD'], [6, b'$'],"" [8, b'x']]\n >>> memory.extract(start=2)._blocks\n [[2, b'BCD'], [6, b'$'], [8, b'xyz']]\n >>> memory.extract(endex=9)._blocks\n [[1, b'ABCD'], [6, b'$'], [8, b'x']]\n >>> memory.extract(5, 8).span\n (5, 8)\n >>> memory.extract(pattern=b'.')._blocks\n [[1, b'ABCD.$.xyz']]\n >>> memory.extract(pattern=b'.', step=3)._blocks\n [[1, b'AD.z']]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_97extract = {"extract", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_97extract, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_96extract}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_97extract(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_pattern = 0; PyObject *__pyx_v_step = 0; PyObject *__pyx_v_bound = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extract (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_pattern,&__pyx_n_s_step,&__pyx_n_s_bound,0}; PyObject* values[5] = {0,0,0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_96extract(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern, PyObject *__pyx_v_step, PyObject *__pyx_v_bound) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extract", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.extract", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__132 = PyTuple_Pack(6, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_pattern, __pyx_n_s_step, __pyx_n_s_bound); if (unlikely(!__pyx_tuple__132)) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__132); __Pyx_GIVEREF(__pyx_tuple__132); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_97extract, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_extract, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__133)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_extract, __pyx_t_5) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__133 = (PyObject*)__Pyx_PyCode_New(6, 0, 6, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__132, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_extract, 7383, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__133)) __PYX_ERR(0, 7383, __pyx_L1_error)
7384: self: Memory,
+7385: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7385, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7385, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7385, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_1) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+7386: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7386, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7386, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7386, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_5) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7387: pattern: Optional[Union[AnyBytes, Value]] = None,
values[2] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Union); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Value); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_7); __pyx_t_1 = 0; __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7387, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_pattern, __pyx_t_6) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7388: step: Optional[Address] = None,
values[3] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7388, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7388, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7388, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_step, __pyx_t_5) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7389: bound: bool = True,
values[4] = ((PyObject *)Py_True); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pattern); if (value) { values[2] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 3: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_step); if (value) { values[3] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 4: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bound); if (value) { values[4] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "extract") < 0)) __PYX_ERR(0, 7383, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_pattern = values[2]; __pyx_v_step = values[3]; __pyx_v_bound = values[4]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("extract", 0, 0, 5, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7383, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.extract", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_96extract(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_pattern, __pyx_v_step, __pyx_v_bound); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_bound, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7383, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7383, __pyx_L1_error)
7390: ) -> Memory:
7391: r"""Selects items from a range.
7392:
7393: Arguments:
7394: start (int):
7395: Inclusive start of the extracted range.
7396: If ``None``, :attr:`start` is considered.
7397:
7398: endex (int):
7399: Exclusive end of the extracted range.
7400: If ``None``, :attr:`endex` is considered.
7401:
7402: pattern (items):
7403: Optional pattern of items to fill the emptiness.
7404:
7405: step (int):
7406: Optional address stepping between bytes extracted from the
7407: range. It has the same meaning of Python's :attr:`slice.step`,
7408: but negative steps are ignored.
7409: Please note that a `step` greater than 1 could take much more
7410: time to process than the default unitary step.
7411:
7412: bound (bool):
7413: The selected address range is applied to the resulting memory
7414: as its trimming range. This retains information about any
7415: initial and final emptiness of that range, which would be lost
7416: otherwise.
7417:
7418: Returns:
7419: :obj:`Memory`: A copy of the memory from the selected range.
7420:
7421: Examples:
7422: +---+---+---+---+---+---+---+---+---+---+---+---+
7423: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
7424: +===+===+===+===+===+===+===+===+===+===+===+===+
7425: | |[A | B | C | D]| |[$]| |[x | y | z]| |
7426: +---+---+---+---+---+---+---+---+---+---+---+---+
7427:
7428: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
7429: >>> memory.extract()._blocks
7430: [[1, b'ABCD'], [6, b'$'], [8, b'xyz']]
7431: >>> memory.extract(2, 9)._blocks
7432: [[2, b'BCD'], [6, b'$'], [8, b'x']]
7433: >>> memory.extract(start=2)._blocks
7434: [[2, b'BCD'], [6, b'$'], [8, b'xyz']]
7435: >>> memory.extract(endex=9)._blocks
7436: [[1, b'ABCD'], [6, b'$'], [8, b'x']]
7437: >>> memory.extract(5, 8).span
7438: (5, 8)
7439: >>> memory.extract(pattern=b'.')._blocks
7440: [[1, b'ABCD.$.xyz']]
7441: >>> memory.extract(pattern=b'.', step=3)._blocks
7442: [[1, b'AD.z']]
7443: """
7444:
+7445: return Memory_Extract(self._, start, endex, pattern, step, bound)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_bound); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7445, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Extract(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex, __pyx_v_pattern, __pyx_v_step, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7445, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (!(likely(((__pyx_t_2) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_2, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 7445, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_2); __pyx_t_2 = 0; goto __pyx_L0;
7446:
+7447: def fill(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_99fill(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_98fill[] = "Memory.fill(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None, pattern: Union[AnyBytes, Value] = 0) -> None\nOverwrites a range with a pattern.\n\n Arguments:\n start (int):\n Inclusive start address for filling.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for filling.\n If ``None``, :attr:`endex` is considered.\n\n pattern (items):\n Pattern of items to fill the range.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[1 | 2 | 3 | 1 | 2 | 3 | 1 | 2]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> memory.fill(pattern=b'123')\n >>> memory._blocks\n [[1, b'12312312']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[A | B | 1 | 2 | 3 | 1 | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> memory.fill(3, 7, b'123')\n >>> memory._blocks\n [[1, b'AB1231yz']]\n\n See Also:\n :meth:`fill_backup`\n :meth:`fill_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_99fill = {"fill", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_99fill, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_98fill}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_99fill(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_pattern = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fill (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_pattern,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_98fill(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fill", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.fill", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__134 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_pattern); if (unlikely(!__pyx_tuple__134)) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__134); __Pyx_GIVEREF(__pyx_tuple__134); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7447, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_99fill, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_fill, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__135)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_fill, __pyx_t_6) < 0) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__135 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__134, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_fill, 7447, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__135)) __PYX_ERR(0, 7447, __pyx_L1_error)
7448: self: Memory,
+7449: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7449, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7449, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7449, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_start, __pyx_t_6) < 0) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7450: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); values[2] = ((PyObject *)__pyx_int_0); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pattern); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "fill") < 0)) __PYX_ERR(0, 7447, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_pattern = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("fill", 0, 0, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7447, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.fill", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_98fill(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7450, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7450, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7450, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_endex, __pyx_t_2) < 0) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7451: pattern: Union[AnyBytes, Value] = 0,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Union); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7451, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7451, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7451, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7451, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_6); __pyx_t_7 = 0; __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7451, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_pattern, __pyx_t_6) < 0) __PYX_ERR(0, 7447, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7452: ) -> None:
if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7447, __pyx_L1_error)
7453: r"""Overwrites a range with a pattern.
7454:
7455: Arguments:
7456: start (int):
7457: Inclusive start address for filling.
7458: If ``None``, :attr:`start` is considered.
7459:
7460: endex (int):
7461: Exclusive end address for filling.
7462: If ``None``, :attr:`endex` is considered.
7463:
7464: pattern (items):
7465: Pattern of items to fill the range.
7466:
7467: Examples:
7468: +---+---+---+---+---+---+---+---+---+---+
7469: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
7470: +===+===+===+===+===+===+===+===+===+===+
7471: | |[A | B | C]| | |[x | y | z]| |
7472: +---+---+---+---+---+---+---+---+---+---+
7473: | |[1 | 2 | 3 | 1 | 2 | 3 | 1 | 2]| |
7474: +---+---+---+---+---+---+---+---+---+---+
7475:
7476: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
7477: >>> memory.fill(pattern=b'123')
7478: >>> memory._blocks
7479: [[1, b'12312312']]
7480:
7481: ~~~
7482:
7483: +---+---+---+---+---+---+---+---+---+---+
7484: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
7485: +===+===+===+===+===+===+===+===+===+===+
7486: | |[A | B | C]| | |[x | y | z]| |
7487: +---+---+---+---+---+---+---+---+---+---+
7488: | |[A | B | 1 | 2 | 3 | 1 | y | z]| |
7489: +---+---+---+---+---+---+---+---+---+---+
7490:
7491: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
7492: >>> memory.fill(3, 7, b'123')
7493: >>> memory._blocks
7494: [[1, b'AB1231yz']]
7495:
7496: See Also:
7497: :meth:`fill_backup`
7498: :meth:`fill_restore`
7499: """
7500:
+7501: Memory_Fill(self._, start, endex, pattern)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Fill(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7501, __pyx_L1_error)
7502:
+7503: def fill_backup(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_101fill_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_100fill_backup[] = "Memory.fill_backup(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> Memory\nBackups a `fill()` operation.\n\n Arguments:\n start (int):\n Inclusive start address for filling.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for filling.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n :obj:`Memory`: Backup memory region.\n\n See Also:\n :meth:`fill`\n :meth:`fill_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_101fill_backup = {"fill_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_101fill_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_100fill_backup}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_101fill_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fill_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_100fill_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { Memory_ const *__pyx_v_memory; addr_t __pyx_v_start_; addr_t __pyx_v_endex_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fill_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.fill_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__136 = PyTuple_Pack(6, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_memory, __pyx_n_s_start_2, __pyx_n_s_endex_2); if (unlikely(!__pyx_tuple__136)) __PYX_ERR(0, 7503, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__136); __Pyx_GIVEREF(__pyx_tuple__136); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7503, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7503, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_101fill_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_fill_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__137)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7503, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_fill_backup, __pyx_t_5) < 0) __PYX_ERR(0, 7503, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__137 = (PyObject*)__Pyx_PyCode_New(3, 0, 6, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__136, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_fill_backup, 7503, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__137)) __PYX_ERR(0, 7503, __pyx_L1_error)
7504: self: Memory,
+7505: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7505, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7505, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7505, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 7503, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7506: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "fill_backup") < 0)) __PYX_ERR(0, 7503, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("fill_backup", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7503, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.fill_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_100fill_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7506, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7506, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7506, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_endex, __pyx_t_5) < 0) __PYX_ERR(0, 7503, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7503, __pyx_L1_error)
7507: ) -> Memory:
7508: r"""Backups a `fill()` operation.
7509:
7510: Arguments:
7511: start (int):
7512: Inclusive start address for filling.
7513: If ``None``, :attr:`start` is considered.
7514:
7515: endex (int):
7516: Exclusive end address for filling.
7517: If ``None``, :attr:`endex` is considered.
7518:
7519: Returns:
7520: :obj:`Memory`: Backup memory region.
7521:
7522: See Also:
7523: :meth:`fill`
7524: :meth:`fill_restore`
7525: """
7526: cdef:
+7527: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+7528: addr_t start_ = Memory_Start(memory) if start is None else <addr_t>start
__pyx_t_3 = (__pyx_v_start == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7528, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_start_ = __pyx_t_2;
+7529: addr_t endex_ = Memory_Endex(memory) if endex is None else <addr_t>endex
__pyx_t_3 = (__pyx_v_endex == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 7529, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_endex_ = __pyx_t_2;
7530:
+7531: return Memory_Extract_(memory, start_, endex_, 0, NULL, 1, True)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_5 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_memory, __pyx_v_start_, __pyx_v_endex_, 0, NULL, 1, 1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7531, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (!(likely(((__pyx_t_5) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_5, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 7531, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L0;
7532:
+7533: def fill_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_103fill_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_102fill_restore[] = "Memory.fill_restore(self: Memory, Memory backup: Memory) -> None\nRestores a `fill()` operation.\n\n Arguments:\n backup (:obj:`Memory`):\n Backup memory region to restore.\n\n See Also:\n :meth:`fill`\n :meth:`fill_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_103fill_restore = {"fill_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_103fill_restore, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_102fill_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_103fill_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fill_restore (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 7535, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_102fill_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_backup)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_102fill_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fill_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.fill_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__138 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__138)) __PYX_ERR(0, 7533, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__138); __Pyx_GIVEREF(__pyx_tuple__138); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7533, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7533, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7533, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_103fill_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_fill_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__139)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7533, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_fill_restore, __pyx_t_6) < 0) __PYX_ERR(0, 7533, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__139 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__138, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_fill_restore, 7533, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__139)) __PYX_ERR(0, 7533, __pyx_L1_error)
7534: self: Memory,
7535: Memory backup not None: Memory,
+7536: ) -> None:
if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7533, __pyx_L1_error)
7537: r"""Restores a `fill()` operation.
7538:
7539: Arguments:
7540: backup (:obj:`Memory`):
7541: Backup memory region to restore.
7542:
7543: See Also:
7544: :meth:`fill`
7545: :meth:`fill_backup`
7546: """
7547:
+7548: Memory_WriteSame_(self._, 0, backup._, True)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_self->_, 0, __pyx_v_backup->_, 1); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7548, __pyx_L1_error)
7549:
+7550: def find(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_105find(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_104find[] = "Memory.find(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> Address\nIndex of an item.\n\n Arguments:\n item (items):\n Value to find. Can be either some byte string or an integer.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The index of the first item equal to `value`, or -1.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_105find = {"find", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_105find, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_104find}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_105find(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("find (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_104find(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("find", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.find", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__140 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__140)) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__140); __Pyx_GIVEREF(__pyx_tuple__140); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7550, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_105find, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_find, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__141)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_find, __pyx_t_2) < 0) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__141 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__140, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_find, 7550, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__141)) __PYX_ERR(0, 7550, __pyx_L1_error)
7551: self: Memory,
+7552: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Union); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7552, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7552, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7552, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7552, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_9); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_2); __pyx_t_9 = 0; __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7552, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_item, __pyx_t_2) < 0) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7553: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7553, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7553, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7553, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7554: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "find") < 0)) __PYX_ERR(0, 7550, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("find", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7550, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.find", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_104find(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7554, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7554, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7554, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_endex, __pyx_t_2) < 0) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7555: ) -> Address:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7555, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, __pyx_t_2) < 0) __PYX_ERR(0, 7550, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
7556: r"""Index of an item.
7557:
7558: Arguments:
7559: item (items):
7560: Value to find. Can be either some byte string or an integer.
7561:
7562: start (int):
7563: Inclusive start of the searched range.
7564: If ``None``, :attr:`endex` is considered.
7565:
7566: endex (int):
7567: Exclusive end of the searched range.
7568: If ``None``, :attr:`endex` is considered.
7569:
7570: Returns:
7571: int: The index of the first item equal to `value`, or -1.
7572: """
7573:
+7574: return Memory_Find(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Find(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7574, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
7575:
+7576: def flood(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_107flood(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_106flood[] = "Memory.flood(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None, pattern: Union[AnyBytes, Value] = 0) -> None\nFills emptiness between non-touching blocks.\n\n Arguments:\n start (int):\n Inclusive start address for flooding.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for flooding.\n If ``None``, :attr:`endex` is considered.\n\n pattern (items):\n Pattern of items to fill the range.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C | 1 | 2 | x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> memory.flood(pattern=b'123')\n >>> memory._blocks\n [[1, b'ABC12xyz']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C | 2 | 3 | x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> memory.flood(3, 7, b'123')\n >>> memory._blocks\n [[1, b'ABC23xyz']]\n\n See Also:\n :meth:`flood_backup`\n :meth:`flood_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_107flood = {"flood", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_107flood, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_106flood}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_107flood(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_pattern = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("flood (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_pattern,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_106flood(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("flood", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.flood", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__142 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_pattern); if (unlikely(!__pyx_tuple__142)) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__142); __Pyx_GIVEREF(__pyx_tuple__142); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7576, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_107flood, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_flood, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__143)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_flood, __pyx_t_5) < 0) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__143 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__142, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_flood, 7576, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__143)) __PYX_ERR(0, 7576, __pyx_L1_error)
7577: self: Memory,
+7578: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7578, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7578, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7578, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7579: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); values[2] = ((PyObject *)__pyx_int_0); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pattern); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "flood") < 0)) __PYX_ERR(0, 7576, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_pattern = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("flood", 0, 0, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7576, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.flood", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_106flood(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7579, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7579, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7579, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_6) < 0) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7580: pattern: Union[AnyBytes, Value] = 0,
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7580, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7580, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Value); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7580, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7580, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_5); __pyx_t_7 = 0; __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7580, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_pattern, __pyx_t_5) < 0) __PYX_ERR(0, 7576, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7581: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7576, __pyx_L1_error)
7582: r"""Fills emptiness between non-touching blocks.
7583:
7584: Arguments:
7585: start (int):
7586: Inclusive start address for flooding.
7587: If ``None``, :attr:`start` is considered.
7588:
7589: endex (int):
7590: Exclusive end address for flooding.
7591: If ``None``, :attr:`endex` is considered.
7592:
7593: pattern (items):
7594: Pattern of items to fill the range.
7595:
7596: Examples:
7597: +---+---+---+---+---+---+---+---+---+---+
7598: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
7599: +===+===+===+===+===+===+===+===+===+===+
7600: | |[A | B | C]| | |[x | y | z]| |
7601: +---+---+---+---+---+---+---+---+---+---+
7602: | |[A | B | C | 1 | 2 | x | y | z]| |
7603: +---+---+---+---+---+---+---+---+---+---+
7604:
7605: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
7606: >>> memory.flood(pattern=b'123')
7607: >>> memory._blocks
7608: [[1, b'ABC12xyz']]
7609:
7610: ~~~
7611:
7612: +---+---+---+---+---+---+---+---+---+---+
7613: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
7614: +===+===+===+===+===+===+===+===+===+===+
7615: | |[A | B | C]| | |[x | y | z]| |
7616: +---+---+---+---+---+---+---+---+---+---+
7617: | |[A | B | C | 2 | 3 | x | y | z]| |
7618: +---+---+---+---+---+---+---+---+---+---+
7619:
7620: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
7621: >>> memory.flood(3, 7, b'123')
7622: >>> memory._blocks
7623: [[1, b'ABC23xyz']]
7624:
7625: See Also:
7626: :meth:`flood_backup`
7627: :meth:`flood_restore`
7628: """
7629:
+7630: Memory_Flood(self._, start, endex, pattern)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Flood(__pyx_v_self->_, __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7630, __pyx_L1_error)
7631:
+7632: def flood_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_109flood_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_108flood_backup[] = "Memory.flood_backup(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> List[OpenInterval]\nBackups a `flood()` operation.\n\n Arguments:\n start (int):\n Inclusive start address for filling.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address for filling.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n list of open intervals: Backup memory gaps.\n\n See Also:\n :meth:`flood`\n :meth:`flood_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_109flood_backup = {"flood_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_109flood_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_108flood_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_109flood_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("flood_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_108flood_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("flood_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.flood_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__144 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__144)) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__144); __Pyx_GIVEREF(__pyx_tuple__144); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7632, __pyx_L1_error) /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_109flood_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_flood_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__145)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_flood_backup, __pyx_t_6) < 0) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__145 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__144, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_flood_backup, 7632, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__145)) __PYX_ERR(0, 7632, __pyx_L1_error)
7633: self: Memory,
+7634: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7634, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7634, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7634, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_start, __pyx_t_6) < 0) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7635: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "flood_backup") < 0)) __PYX_ERR(0, 7632, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("flood_backup", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7632, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.flood_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_108flood_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7635, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7635, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7635, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_endex, __pyx_t_2) < 0) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7636: ) -> List[OpenInterval]:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_List); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7636, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_OpenInterval); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7636, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7636, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_6) < 0) __PYX_ERR(0, 7632, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
7637: r"""Backups a `flood()` operation.
7638:
7639: Arguments:
7640: start (int):
7641: Inclusive start address for filling.
7642: If ``None``, :attr:`start` is considered.
7643:
7644: endex (int):
7645: Exclusive end address for filling.
7646: If ``None``, :attr:`endex` is considered.
7647:
7648: Returns:
7649: list of open intervals: Backup memory gaps.
7650:
7651: See Also:
7652: :meth:`flood`
7653: :meth:`flood_restore`
7654: """
7655:
+7656: return list(self.gaps(start, endex))
__Pyx_XDECREF(__pyx_r); __pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_gaps); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7656, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = NULL; __pyx_t_4 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_2, function); __pyx_t_4 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_2)) { PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_start, __pyx_v_endex}; __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_4, 2+__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7656, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_1); } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) { PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_start, __pyx_v_endex}; __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_4, 2+__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7656, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_1); } else #endif { __pyx_t_5 = PyTuple_New(2+__pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7656, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__pyx_t_3) { __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3); __pyx_t_3 = NULL; } __Pyx_INCREF(__pyx_v_start); __Pyx_GIVEREF(__pyx_v_start); PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_4, __pyx_v_start); __Pyx_INCREF(__pyx_v_endex); __Pyx_GIVEREF(__pyx_v_endex); PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_4, __pyx_v_endex); __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7656, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PySequence_List(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7656, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
7657:
+7658: def flood_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_111flood_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_gaps); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_110flood_restore[] = "Memory.flood_restore(self: Memory, gaps: List[OpenInterval]) -> None\nRestores a `flood()` operation.\n\n Arguments:\n gaps (list of open intervals):\n Backup memory gaps to restore.\n\n See Also:\n :meth:`flood`\n :meth:`flood_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_111flood_restore = {"flood_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_111flood_restore, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_110flood_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_111flood_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_gaps) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("flood_restore (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_110flood_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_gaps)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_110flood_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_gaps) { Memory_ *__pyx_v_memory; PyObject *__pyx_v_gap_start = NULL; PyObject *__pyx_v_gap_endex = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("flood_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("cbytesparse.c.Memory.flood_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_gap_start); __Pyx_XDECREF(__pyx_v_gap_endex); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__146 = PyTuple_Pack(5, __pyx_n_s_self, __pyx_n_s_gaps, __pyx_n_s_memory, __pyx_n_s_gap_start, __pyx_n_s_gap_endex); if (unlikely(!__pyx_tuple__146)) __PYX_ERR(0, 7658, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__146); __Pyx_GIVEREF(__pyx_tuple__146); /* … */ __pyx_t_6 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7658, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7658, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_111flood_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_flood_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__147)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7658, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_6); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_flood_restore, __pyx_t_2) < 0) __PYX_ERR(0, 7658, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__147 = (PyObject*)__Pyx_PyCode_New(2, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__146, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_flood_restore, 7658, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__147)) __PYX_ERR(0, 7658, __pyx_L1_error)
7659: self: Memory,
+7660: gaps: List[OpenInterval],
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_List); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7660, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_OpenInterval); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7660, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7660, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_gaps, __pyx_t_2) < 0) __PYX_ERR(0, 7658, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7661: ) -> None:
if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 7658, __pyx_L1_error)
7662: r"""Restores a `flood()` operation.
7663:
7664: Arguments:
7665: gaps (list of open intervals):
7666: Backup memory gaps to restore.
7667:
7668: See Also:
7669: :meth:`flood`
7670: :meth:`flood_backup`
7671: """
7672: cdef:
+7673: Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
7674:
+7675: for gap_start, gap_endex in gaps:
if (likely(PyList_CheckExact(__pyx_v_gaps)) || PyTuple_CheckExact(__pyx_v_gaps)) { __pyx_t_2 = __pyx_v_gaps; __Pyx_INCREF(__pyx_t_2); __pyx_t_3 = 0; __pyx_t_4 = NULL; } else { __pyx_t_3 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_v_gaps); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7675, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = Py_TYPE(__pyx_t_2)->tp_iternext; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 7675, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_4)) { if (likely(PyList_CheckExact(__pyx_t_2))) { if (__pyx_t_3 >= PyList_GET_SIZE(__pyx_t_2)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_3); __Pyx_INCREF(__pyx_t_5); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(0, 7675, __pyx_L1_error) #else __pyx_t_5 = PySequence_ITEM(__pyx_t_2, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7675, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); #endif } else { if (__pyx_t_3 >= PyTuple_GET_SIZE(__pyx_t_2)) break; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_3); __Pyx_INCREF(__pyx_t_5); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(0, 7675, __pyx_L1_error) #else __pyx_t_5 = PySequence_ITEM(__pyx_t_2, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7675, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); #endif } } else { __pyx_t_5 = __pyx_t_4(__pyx_t_2); if (unlikely(!__pyx_t_5)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); else __PYX_ERR(0, 7675, __pyx_L1_error) } break; } __Pyx_GOTREF(__pyx_t_5); } if ((likely(PyTuple_CheckExact(__pyx_t_5))) || (PyList_CheckExact(__pyx_t_5))) { PyObject* sequence = __pyx_t_5; Py_ssize_t size = __Pyx_PySequence_SIZE(sequence); if (unlikely(size != 2)) { if (size > 2) __Pyx_RaiseTooManyValuesError(2); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); __PYX_ERR(0, 7675, __pyx_L1_error) } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS if (likely(PyTuple_CheckExact(sequence))) { __pyx_t_6 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_7 = PyTuple_GET_ITEM(sequence, 1); } else { __pyx_t_6 = PyList_GET_ITEM(sequence, 0); __pyx_t_7 = PyList_GET_ITEM(sequence, 1); } __Pyx_INCREF(__pyx_t_6); __Pyx_INCREF(__pyx_t_7); #else __pyx_t_6 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7675, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7675, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); #endif __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; } else { Py_ssize_t index = -1; __pyx_t_8 = PyObject_GetIter(__pyx_t_5); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7675, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_9 = Py_TYPE(__pyx_t_8)->tp_iternext; index = 0; __pyx_t_6 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_6)) goto __pyx_L5_unpacking_failed; __Pyx_GOTREF(__pyx_t_6); index = 1; __pyx_t_7 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_7)) goto __pyx_L5_unpacking_failed; __Pyx_GOTREF(__pyx_t_7); if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 2) < 0) __PYX_ERR(0, 7675, __pyx_L1_error) __pyx_t_9 = NULL; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L6_unpacking_done; __pyx_L5_unpacking_failed:; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); __PYX_ERR(0, 7675, __pyx_L1_error) __pyx_L6_unpacking_done:; } __Pyx_XDECREF_SET(__pyx_v_gap_start, __pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF_SET(__pyx_v_gap_endex, __pyx_t_7); __pyx_t_7 = 0; /* … */ } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7676: Memory_Clear(memory, gap_start, gap_endex)
__pyx_t_10 = __pyx_f_11cbytesparse_1c_Memory_Clear(__pyx_v_memory, __pyx_v_gap_start, __pyx_v_gap_endex); if (unlikely(__pyx_t_10 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 7676, __pyx_L1_error)
7677:
+7678: @classmethod
__pyx_t_2 = __Pyx_Method_ClassMethod(__pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7678, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_from_blocks, __pyx_t_2) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory);
+7679: def from_blocks(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_113from_blocks(PyObject *__pyx_v_cls, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_112from_blocks[] = "Memory.from_blocks(type cls: Type[Memory], blocks: BlockList, offset: Address = 0, start: Optional[Address] = None, endex: Optional[Address] = None, copy: bool = True, validate: bool = True) -> Memory\nCreates a virtual memory from blocks.\n\n Arguments:\n blocks (list of blocks):\n A sequence of non-overlapping blocks, sorted by address.\n\n offset (int):\n Some address offset applied to all the blocks.\n\n start (int):\n Optional memory start address.\n Anything before will be trimmed away.\n\n endex (int):\n Optional memory exclusive end address.\n Anything at or after it will be trimmed away.\n\n copy (bool):\n Forces copy of provided input data.\n\n validate (bool):\n Validates the resulting :obj:`Memory` object.\n\n Raises:\n :obj:`ValueError`: Some requirements are not satisfied.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |\n +===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | | | | |\n +---+---+---+---+---+---+---+---+---+\n | | | | | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n\n >>> blocks = [[1, b'ABC'], [5, b'xyz']]\n >>> memory = Memory.from_blocks(blocks)\n >>> memory._blocks\n [[1, b'ABC'], [5, b'xyz']]\n >>> memory = Memory.from_blocks(blocks, offset=3)\n >>> memory._blocks\n [[4, b'ABC'], [8, b'xyz']]\n\n ~~~\n\n >>> # Loads data from an Intel HEX record file\n >>> # NOTE: Record files typically require collapsing!\n >>> import hexrec.records as hr\n >>> blocks = hr.load_blocks('records.hex')\n >>> memory = Memory.from_blocks(col""lapse_blocks(blocks))\n >>> memory\n ...\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_113from_blocks = {"from_blocks", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_113from_blocks, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_112from_blocks}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_113from_blocks(PyObject *__pyx_v_cls, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_blocks = 0; PyObject *__pyx_v_offset = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_copy = 0; PyObject *__pyx_v_validate = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("from_blocks (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_blocks,&__pyx_n_s_offset,&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_copy,&__pyx_n_s_validate,0}; PyObject* values[6] = {0,0,0,0,0,0}; values[1] = ((PyObject *)__pyx_int_0); /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_112from_blocks(CYTHON_UNUSED PyTypeObject *__pyx_v_cls, PyObject *__pyx_v_blocks, PyObject *__pyx_v_offset, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_copy, PyObject *__pyx_v_validate) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("from_blocks", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __PYX_XDEC_MEMVIEW(&__pyx_t_3, 1); __Pyx_AddTraceback("cbytesparse.c.Memory.from_blocks", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__148 = PyTuple_Pack(8, __pyx_n_s_cls, __pyx_n_s_blocks, __pyx_n_s_offset, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_copy, __pyx_n_s_validate, __pyx_n_s_memory); if (unlikely(!__pyx_tuple__148)) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__148); __Pyx_GIVEREF(__pyx_tuple__148); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_113from_blocks, __Pyx_CYFUNCTION_CLASSMETHOD | __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_from_blocks, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__149)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_from_blocks, __pyx_t_9) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); /* … */ __Pyx_GetNameInClass(__pyx_t_9, (PyObject *)__pyx_ptype_11cbytesparse_1c_Memory, __pyx_n_s_from_blocks); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_codeobj__149 = (PyObject*)__Pyx_PyCode_New(7, 0, 8, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__148, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_from_blocks, 7679, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__149)) __PYX_ERR(0, 7679, __pyx_L1_error)
+7680: cls: Type[Memory],
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Type); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7680, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_6, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7680, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_cls, __pyx_t_9) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7681: blocks: BlockList,
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_BlockList); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7681, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_blocks, __pyx_t_9) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7682: offset: Address = 0,
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7682, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_offset, __pyx_t_9) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7683: start: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7683, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7683, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7683, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7684: endex: Optional[Address] = None,
values[3] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7684, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7684, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7684, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7685: copy: bool = True,
values[4] = ((PyObject *)Py_True); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_copy, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7679, __pyx_L1_error)
+7686: validate: bool = True,
values[5] = ((PyObject *)Py_True); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5); CYTHON_FALLTHROUGH; case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_blocks)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[2] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 3: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[3] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 4: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_copy); if (value) { values[4] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 5: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_validate); if (value) { values[5] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "from_blocks") < 0)) __PYX_ERR(0, 7679, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5); CYTHON_FALLTHROUGH; case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_blocks = values[0]; __pyx_v_offset = values[1]; __pyx_v_start = values[2]; __pyx_v_endex = values[3]; __pyx_v_copy = values[4]; __pyx_v_validate = values[5]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("from_blocks", 0, 1, 6, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7679, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.from_blocks", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_112from_blocks(((PyTypeObject*)__pyx_v_cls), __pyx_v_blocks, __pyx_v_offset, __pyx_v_start, __pyx_v_endex, __pyx_v_copy, __pyx_v_validate); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_validate, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7679, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7679, __pyx_L1_error)
7687: ) -> Memory:
7688: r"""Creates a virtual memory from blocks.
7689:
7690: Arguments:
7691: blocks (list of blocks):
7692: A sequence of non-overlapping blocks, sorted by address.
7693:
7694: offset (int):
7695: Some address offset applied to all the blocks.
7696:
7697: start (int):
7698: Optional memory start address.
7699: Anything before will be trimmed away.
7700:
7701: endex (int):
7702: Optional memory exclusive end address.
7703: Anything at or after it will be trimmed away.
7704:
7705: copy (bool):
7706: Forces copy of provided input data.
7707:
7708: validate (bool):
7709: Validates the resulting :obj:`Memory` object.
7710:
7711: Raises:
7712: :obj:`ValueError`: Some requirements are not satisfied.
7713:
7714: Examples:
7715: +---+---+---+---+---+---+---+---+---+
7716: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
7717: +===+===+===+===+===+===+===+===+===+
7718: | |[A | B | C]| | | | | |
7719: +---+---+---+---+---+---+---+---+---+
7720: | | | | | |[x | y | z]| |
7721: +---+---+---+---+---+---+---+---+---+
7722:
7723: >>> blocks = [[1, b'ABC'], [5, b'xyz']]
7724: >>> memory = Memory.from_blocks(blocks)
7725: >>> memory._blocks
7726: [[1, b'ABC'], [5, b'xyz']]
7727: >>> memory = Memory.from_blocks(blocks, offset=3)
7728: >>> memory._blocks
7729: [[4, b'ABC'], [8, b'xyz']]
7730:
7731: ~~~
7732:
7733: >>> # Loads data from an Intel HEX record file
7734: >>> # NOTE: Record files typically require collapsing!
7735: >>> import hexrec.records as hr
7736: >>> blocks = hr.load_blocks('records.hex')
7737: >>> memory = Memory.from_blocks(collapse_blocks(blocks))
7738: >>> memory
7739: ...
7740: """
7741: cdef:
+7742: Memory memory = Memory()
__pyx_t_1 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7742, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_1); __pyx_t_1 = 0;
7743:
+7744: memory._ = Memory_Free(memory._)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory->_); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 7744, __pyx_L1_error) __pyx_v_memory->_ = __pyx_t_2;
+7745: memory._ = Memory_Create(NULL, None, offset, blocks, start, endex, copy, validate)
__pyx_t_3 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(Py_None, 0); if (unlikely(!__pyx_t_3.memview)) __PYX_ERR(0, 7745, __pyx_L1_error) __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_copy); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7745, __pyx_L1_error) __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_validate); if (unlikely((__pyx_t_5 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7745, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Create(NULL, __pyx_t_3, __pyx_v_offset, __pyx_v_blocks, __pyx_v_start, __pyx_v_endex, __pyx_t_4, __pyx_t_5); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL))) __PYX_ERR(0, 7745, __pyx_L1_error) __PYX_XDEC_MEMVIEW(&__pyx_t_3, 1); __pyx_t_3.memview = NULL; __pyx_t_3.data = NULL; __pyx_v_memory->_ = __pyx_t_2;
+7746: return memory
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = __pyx_v_memory; goto __pyx_L0;
7747:
+7748: @classmethod
__pyx_t_2 = __Pyx_Method_ClassMethod(__pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7748, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_from_bytes, __pyx_t_2) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory);
+7749: def from_bytes(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_115from_bytes(PyObject *__pyx_v_cls, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_114from_bytes[] = "Memory.from_bytes(type cls: Type[Memory], data: AnyBytes, offset: Address = 0, start: Optional[Address] = None, endex: Optional[Address] = None, copy: bool = True, validate: bool = True) -> Memory\nCreates a virtual memory from a byte-like chunk.\n\n Arguments:\n data (byte-like data):\n A byte-like chunk of data (e.g. :obj:`bytes`,\n :obj:`bytearray`, :obj:`memoryview`).\n\n offset (int):\n Start address of the block of data.\n\n start (int):\n Optional memory start address.\n Anything before will be trimmed away.\n\n endex (int):\n Optional memory exclusive end address.\n Anything at or after it will be trimmed away.\n\n copy (bool):\n Forces copy of provided input data into the underlying data\n structure.\n\n validate (bool):\n Validates the resulting :obj:`Memory` object.\n\n Raises:\n :obj:`ValueError`: Some requirements are not satisfied.\n\n Examples:\n >>> memory = Memory.from_bytes(b'')\n >>> memory._blocks\n []\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |\n +===+===+===+===+===+===+===+===+===+\n | | |[A | B | C | x | y | z]| |\n +---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_bytes(b'ABCxyz', 2)\n >>> memory._blocks\n [[2, b'ABCxyz']]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_115from_bytes = {"from_bytes", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_115from_bytes, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_114from_bytes}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_115from_bytes(PyObject *__pyx_v_cls, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_data = 0; PyObject *__pyx_v_offset = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_copy = 0; PyObject *__pyx_v_validate = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("from_bytes (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_data,&__pyx_n_s_offset,&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_copy,&__pyx_n_s_validate,0}; PyObject* values[6] = {0,0,0,0,0,0}; values[1] = ((PyObject *)__pyx_int_0); /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_114from_bytes(CYTHON_UNUSED PyTypeObject *__pyx_v_cls, PyObject *__pyx_v_data, PyObject *__pyx_v_offset, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_copy, PyObject *__pyx_v_validate) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("from_bytes", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __PYX_XDEC_MEMVIEW(&__pyx_t_3, 1); __Pyx_AddTraceback("cbytesparse.c.Memory.from_bytes", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__150 = PyTuple_Pack(8, __pyx_n_s_cls, __pyx_n_s_data, __pyx_n_s_offset, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_copy, __pyx_n_s_validate, __pyx_n_s_memory); if (unlikely(!__pyx_tuple__150)) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__150); __Pyx_GIVEREF(__pyx_tuple__150); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); /* … */ __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_115from_bytes, __Pyx_CYFUNCTION_CLASSMETHOD | __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_from_bytes, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__151)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_6, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_from_bytes, __pyx_t_6) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); /* … */ __Pyx_GetNameInClass(__pyx_t_6, (PyObject *)__pyx_ptype_11cbytesparse_1c_Memory, __pyx_n_s_from_bytes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_codeobj__151 = (PyObject*)__Pyx_PyCode_New(7, 0, 8, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__150, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_from_bytes, 7749, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__151)) __PYX_ERR(0, 7749, __pyx_L1_error)
+7750: cls: Type[Memory],
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Type); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_9, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_cls, __pyx_t_6) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7751: data: AnyBytes,
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7751, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_data, __pyx_t_6) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7752: offset: Address = 0,
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7752, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_offset, __pyx_t_6) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7753: start: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7753, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7753, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7753, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7754: endex: Optional[Address] = None,
values[3] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7754, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7754, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7754, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_6) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
+7755: copy: bool = True,
values[4] = ((PyObject *)Py_True); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_copy, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7749, __pyx_L1_error)
+7756: validate: bool = True,
values[5] = ((PyObject *)Py_True); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5); CYTHON_FALLTHROUGH; case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_data)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[2] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 3: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[3] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 4: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_copy); if (value) { values[4] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 5: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_validate); if (value) { values[5] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "from_bytes") < 0)) __PYX_ERR(0, 7749, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5); CYTHON_FALLTHROUGH; case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_data = values[0]; __pyx_v_offset = values[1]; __pyx_v_start = values[2]; __pyx_v_endex = values[3]; __pyx_v_copy = values[4]; __pyx_v_validate = values[5]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("from_bytes", 0, 1, 6, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7749, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.from_bytes", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_114from_bytes(((PyTypeObject*)__pyx_v_cls), __pyx_v_data, __pyx_v_offset, __pyx_v_start, __pyx_v_endex, __pyx_v_copy, __pyx_v_validate); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_validate, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7749, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7749, __pyx_L1_error)
7757: ) -> Memory:
7758: r"""Creates a virtual memory from a byte-like chunk.
7759:
7760: Arguments:
7761: data (byte-like data):
7762: A byte-like chunk of data (e.g. :obj:`bytes`,
7763: :obj:`bytearray`, :obj:`memoryview`).
7764:
7765: offset (int):
7766: Start address of the block of data.
7767:
7768: start (int):
7769: Optional memory start address.
7770: Anything before will be trimmed away.
7771:
7772: endex (int):
7773: Optional memory exclusive end address.
7774: Anything at or after it will be trimmed away.
7775:
7776: copy (bool):
7777: Forces copy of provided input data into the underlying data
7778: structure.
7779:
7780: validate (bool):
7781: Validates the resulting :obj:`Memory` object.
7782:
7783: Raises:
7784: :obj:`ValueError`: Some requirements are not satisfied.
7785:
7786: Examples:
7787: >>> memory = Memory.from_bytes(b'')
7788: >>> memory._blocks
7789: []
7790:
7791: ~~~
7792:
7793: +---+---+---+---+---+---+---+---+---+
7794: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
7795: +===+===+===+===+===+===+===+===+===+
7796: | | |[A | B | C | x | y | z]| |
7797: +---+---+---+---+---+---+---+---+---+
7798:
7799: >>> memory = Memory.from_bytes(b'ABCxyz', 2)
7800: >>> memory._blocks
7801: [[2, b'ABCxyz']]
7802: """
7803: cdef:
+7804: Memory memory = Memory()
__pyx_t_1 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7804, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_1); __pyx_t_1 = 0;
7805:
+7806: memory._ = Memory_Free(memory._)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory->_); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 7806, __pyx_L1_error) __pyx_v_memory->_ = __pyx_t_2;
+7807: memory._ = Memory_Create(NULL, data, offset, None, start, endex, copy, validate)
__pyx_t_3 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_v_data, 0); if (unlikely(!__pyx_t_3.memview)) __PYX_ERR(0, 7807, __pyx_L1_error) __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_copy); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7807, __pyx_L1_error) __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_validate); if (unlikely((__pyx_t_5 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7807, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Create(NULL, __pyx_t_3, __pyx_v_offset, Py_None, __pyx_v_start, __pyx_v_endex, __pyx_t_4, __pyx_t_5); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL))) __PYX_ERR(0, 7807, __pyx_L1_error) __PYX_XDEC_MEMVIEW(&__pyx_t_3, 1); __pyx_t_3.memview = NULL; __pyx_t_3.data = NULL; __pyx_v_memory->_ = __pyx_t_2;
+7808: return memory
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_memory)); __pyx_r = __pyx_v_memory; goto __pyx_L0;
7809:
+7810: @classmethod
__pyx_t_2 = __Pyx_Method_ClassMethod(__pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7810, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_from_memory, __pyx_t_2) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory);
+7811: def from_memory(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_117from_memory(PyObject *__pyx_v_cls, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_116from_memory[] = "Memory.from_memory(type cls: Type[Memory], Memory memory: Memory, offset: Address = 0, start: Optional[Address] = None, endex: Optional[Address] = None, copy: bool = True, validate: bool = True) -> Memory\nCreates a virtual memory from another one.\n\n Arguments:\n memory (Memory):\n A :obj:`Memory` to copy data from.\n\n offset (int):\n Some address offset applied to all the blocks.\n\n start (int):\n Optional memory start address.\n Anything before will be trimmed away.\n\n endex (int):\n Optional memory exclusive end address.\n Anything at or after it will be trimmed away.\n\n copy (bool):\n Forces copy of provided input data into the underlying data\n structure.\n\n validate (bool):\n Validates the resulting :obj:`Memory` object.\n\n Raises:\n :obj:`ValueError`: Some requirements are not satisfied.\n\n Examples:\n >>> memory1 = Memory.from_bytes(b'ABC', 5)\n >>> memory2 = Memory.from_memory(memory1)\n >>> memory2._blocks\n [[5, b'ABC']]\n >>> memory1 == memory2\n True\n >>> memory1 is memory2\n False\n >>> memory1._blocks is memory2._blocks\n False\n\n ~~~\n\n >>> memory1 = Memory.from_bytes(b'ABC', 10)\n >>> memory2 = Memory.from_memory(memory1, -3)\n >>> memory2._blocks\n [[7, b'ABC']]\n >>> memory1 == memory2\n False\n\n ~~~\n\n >>> memory1 = Memory.from_bytes(b'ABC', 10)\n >>> memory2 = Memory.from_memory(memory1, copy=False)\n >>> all((b1[1] is b2[1]) # compare block data\n ... for b1, b2 in zip(memory1._blocks, memory2._blocks))\n True\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_117from_memory = {"from_memory", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_117from_memory, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_116from_memory}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_117from_memory(PyObject *__pyx_v_cls, PyObject *__pyx_args, PyObject *__pyx_kwds) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory = 0; PyObject *__pyx_v_offset = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_copy = 0; PyObject *__pyx_v_validate = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("from_memory (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_memory,&__pyx_n_s_offset,&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_copy,&__pyx_n_s_validate,0}; PyObject* values[6] = {0,0,0,0,0,0}; values[1] = ((PyObject *)__pyx_int_0); /* … */ /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_116from_memory(CYTHON_UNUSED PyTypeObject *__pyx_v_cls, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory, PyObject *__pyx_v_offset, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_copy, PyObject *__pyx_v_validate) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_memory_ = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("from_memory", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __PYX_XDEC_MEMVIEW(&__pyx_t_3, 1); __Pyx_AddTraceback("cbytesparse.c.Memory.from_memory", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_memory_); __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_120generator2(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */ /* … */ __pyx_tuple__152 = PyTuple_Pack(8, __pyx_n_s_cls, __pyx_n_s_memory, __pyx_n_s_offset, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_copy, __pyx_n_s_validate, __pyx_n_s_memory_2); if (unlikely(!__pyx_tuple__152)) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__152); __Pyx_GIVEREF(__pyx_tuple__152); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(8); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_117from_memory, __Pyx_CYFUNCTION_CLASSMETHOD | __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_from_memory, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__153)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_from_memory, __pyx_t_9) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); /* … */ __Pyx_GetNameInClass(__pyx_t_9, (PyObject *)__pyx_ptype_11cbytesparse_1c_Memory, __pyx_n_s_from_memory); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_codeobj__153 = (PyObject*)__Pyx_PyCode_New(7, 0, 8, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__152, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_from_memory, 7811, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__153)) __PYX_ERR(0, 7811, __pyx_L1_error)
+7812: cls: Type[Memory],
__Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Type); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7812, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_6, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7812, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_cls, __pyx_t_9) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_memory, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7811, __pyx_L1_error)
7813: memory: Memory,
+7814: offset: Address = 0,
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7814, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_offset, __pyx_t_9) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7815: start: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7815, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7815, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7815, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7816: endex: Optional[Address] = None,
values[3] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7816, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7816, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7816, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7817: copy: bool = True,
values[4] = ((PyObject *)Py_True); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_copy, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7811, __pyx_L1_error)
+7818: validate: bool = True,
values[5] = ((PyObject *)Py_True); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5); CYTHON_FALLTHROUGH; case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_memory)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[2] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 3: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[3] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 4: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_copy); if (value) { values[4] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 5: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_validate); if (value) { values[5] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "from_memory") < 0)) __PYX_ERR(0, 7811, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5); CYTHON_FALLTHROUGH; case 5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4); CYTHON_FALLTHROUGH; case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); CYTHON_FALLTHROUGH; case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_memory = ((struct __pyx_obj_11cbytesparse_1c_Memory *)values[0]); __pyx_v_offset = values[1]; __pyx_v_start = values[2]; __pyx_v_endex = values[3]; __pyx_v_copy = values[4]; __pyx_v_validate = values[5]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("from_memory", 0, 1, 6, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7811, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.from_memory", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_memory), __pyx_ptype_11cbytesparse_1c_Memory, 1, "memory", 0))) __PYX_ERR(0, 7813, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_116from_memory(((PyTypeObject*)__pyx_v_cls), __pyx_v_memory, __pyx_v_offset, __pyx_v_start, __pyx_v_endex, __pyx_v_copy, __pyx_v_validate); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_validate, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7811, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7811, __pyx_L1_error)
7819: ) -> Memory:
7820: r"""Creates a virtual memory from another one.
7821:
7822: Arguments:
7823: memory (Memory):
7824: A :obj:`Memory` to copy data from.
7825:
7826: offset (int):
7827: Some address offset applied to all the blocks.
7828:
7829: start (int):
7830: Optional memory start address.
7831: Anything before will be trimmed away.
7832:
7833: endex (int):
7834: Optional memory exclusive end address.
7835: Anything at or after it will be trimmed away.
7836:
7837: copy (bool):
7838: Forces copy of provided input data into the underlying data
7839: structure.
7840:
7841: validate (bool):
7842: Validates the resulting :obj:`Memory` object.
7843:
7844: Raises:
7845: :obj:`ValueError`: Some requirements are not satisfied.
7846:
7847: Examples:
7848: >>> memory1 = Memory.from_bytes(b'ABC', 5)
7849: >>> memory2 = Memory.from_memory(memory1)
7850: >>> memory2._blocks
7851: [[5, b'ABC']]
7852: >>> memory1 == memory2
7853: True
7854: >>> memory1 is memory2
7855: False
7856: >>> memory1._blocks is memory2._blocks
7857: False
7858:
7859: ~~~
7860:
7861: >>> memory1 = Memory.from_bytes(b'ABC', 10)
7862: >>> memory2 = Memory.from_memory(memory1, -3)
7863: >>> memory2._blocks
7864: [[7, b'ABC']]
7865: >>> memory1 == memory2
7866: False
7867:
7868: ~~~
7869:
7870: >>> memory1 = Memory.from_bytes(b'ABC', 10)
7871: >>> memory2 = Memory.from_memory(memory1, copy=False)
7872: >>> all((b1[1] is b2[1]) # compare block data
7873: ... for b1, b2 in zip(memory1._blocks, memory2._blocks))
7874: True
7875: """
7876: cdef:
+7877: Memory memory_ = Memory()
__pyx_t_1 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7877, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_memory_ = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_1); __pyx_t_1 = 0;
7878:
+7879: memory_._ = Memory_Free(memory_._)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Free(__pyx_v_memory_->_); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 7879, __pyx_L1_error) __pyx_v_memory_->_ = __pyx_t_2;
+7880: memory_._ = Memory_Create(memory._, None, offset, None, start, endex, copy, validate)
__pyx_t_3 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(Py_None, 0); if (unlikely(!__pyx_t_3.memview)) __PYX_ERR(0, 7880, __pyx_L1_error) __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_copy); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7880, __pyx_L1_error) __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_validate); if (unlikely((__pyx_t_5 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 7880, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Create(__pyx_v_memory->_, __pyx_t_3, __pyx_v_offset, Py_None, __pyx_v_start, __pyx_v_endex, __pyx_t_4, __pyx_t_5); if (unlikely(__pyx_t_2 == ((Memory_ *)NULL))) __PYX_ERR(0, 7880, __pyx_L1_error) __PYX_XDEC_MEMVIEW(&__pyx_t_3, 1); __pyx_t_3.memview = NULL; __pyx_t_3.data = NULL; __pyx_v_memory_->_ = __pyx_t_2;
+7881: return memory_
__Pyx_XDECREF(((PyObject *)__pyx_r)); __Pyx_INCREF(((PyObject *)__pyx_v_memory_)); __pyx_r = __pyx_v_memory_; goto __pyx_L0;
7882:
+7883: def gaps(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_119gaps(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_118gaps[] = "Memory.gaps(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None, bound: bool = False) -> Iterator[OpenInterval]\nIterates over block gaps.\n\n Iterates over gaps emptiness bounds within an address range.\n If a yielded bound is ``None``, that direction is infinitely empty\n (valid before or after global data bounds).\n\n Arguments:\n start (int):\n Inclusive start address.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address.\n If ``None``, :attr:`endex` is considered.\n\n Yields:\n couple of addresses: Block data interval boundaries.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|\n +===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B]| | |[x]| |[1 | 2 | 3]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'AB'], [5, b'x'], [7, b'123']])\n >>> list(memory.gaps())\n [(None, 1), (3, 5), (6, 7), (10, None)]\n >>> list(memory.gaps(0, 11))\n [(0, 1), (3, 5), (6, 7), (10, 11)]\n >>> list(memory.gaps(*memory.span))\n [(3, 5), (6, 7)]\n >>> list(memory.gaps(2, 6))\n [(3, 5)]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_119gaps = {"gaps", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_119gaps, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_118gaps}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_119gaps(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_bound = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("gaps (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_bound,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_118gaps(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_bound) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_2_gaps *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("gaps", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_2_gaps *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_2_gaps(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_2_gaps, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_2_gaps *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 7883, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __pyx_cur_scope->__pyx_v_start = __pyx_v_start; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_endex = __pyx_v_endex; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); __pyx_cur_scope->__pyx_v_bound = __pyx_v_bound; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_bound); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_bound); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_120generator2, __pyx_codeobj__30, (PyObject *) __pyx_cur_scope, __pyx_n_s_gaps, __pyx_n_s_Memory_gaps, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.gaps", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_120generator2(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("gaps", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 7883, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_13); __Pyx_AddTraceback("gaps", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__154 = PyTuple_Pack(17, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_bound, __pyx_n_s_start_2, __pyx_n_s_endex_2, __pyx_n_s_bound_2, __pyx_n_s_blocks, __pyx_n_s_block_count, __pyx_n_s_block_index, __pyx_n_s_block_index_start_2, __pyx_n_s_block_index_endex_2, __pyx_n_s_block, __pyx_n_s_block_start, __pyx_n_s_block_endex, __pyx_n_s_start_3, __pyx_n_s_endex_3); if (unlikely(!__pyx_tuple__154)) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__154); __Pyx_GIVEREF(__pyx_tuple__154); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7883, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_119gaps, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_gaps, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__30)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_gaps, __pyx_t_5) < 0) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__30 = (PyObject*)__Pyx_PyCode_New(4, 0, 17, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__154, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_gaps, 7883, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__30)) __PYX_ERR(0, 7883, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_2_gaps { PyObject_HEAD Block_ const *__pyx_v_block; size_t __pyx_v_block_count; addr_t __pyx_v_block_endex; size_t __pyx_v_block_index; size_t __pyx_v_block_index_endex; size_t __pyx_v_block_index_start; addr_t __pyx_v_block_start; Rack_ const *__pyx_v_blocks; PyObject *__pyx_v_bound; int __pyx_v_bound_; PyObject *__pyx_v_endex; addr_t __pyx_v_endex_; PyObject *__pyx_v_endex__; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; PyObject *__pyx_v_start; addr_t __pyx_v_start_; PyObject *__pyx_v_start__; size_t __pyx_t_0; size_t __pyx_t_1; size_t __pyx_t_2; };
7884: self: Memory,
+7885: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7885, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7885, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7885, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+7886: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7886, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7887: bound: bool = False,
values[2] = ((PyObject *)Py_False); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bound); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "gaps") < 0)) __PYX_ERR(0, 7883, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_bound = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("gaps", 0, 0, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7883, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.gaps", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_118gaps(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_bound); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_bound, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 7883, __pyx_L1_error)
+7888: ) -> Iterator[OpenInterval]:
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_OpenInterval); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7888, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_5) < 0) __PYX_ERR(0, 7883, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
7889: r"""Iterates over block gaps.
7890:
7891: Iterates over gaps emptiness bounds within an address range.
7892: If a yielded bound is ``None``, that direction is infinitely empty
7893: (valid before or after global data bounds).
7894:
7895: Arguments:
7896: start (int):
7897: Inclusive start address.
7898: If ``None``, :attr:`start` is considered.
7899:
7900: endex (int):
7901: Exclusive end address.
7902: If ``None``, :attr:`endex` is considered.
7903:
7904: Yields:
7905: couple of addresses: Block data interval boundaries.
7906:
7907: Example:
7908: +---+---+---+---+---+---+---+---+---+---+---+
7909: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|
7910: +===+===+===+===+===+===+===+===+===+===+===+
7911: | |[A | B]| | |[x]| |[1 | 2 | 3]| |
7912: +---+---+---+---+---+---+---+---+---+---+---+
7913:
7914: >>> memory = Memory.from_blocks([[1, b'AB'], [5, b'x'], [7, b'123']])
7915: >>> list(memory.gaps())
7916: [(None, 1), (3, 5), (6, 7), (10, None)]
7917: >>> list(memory.gaps(0, 11))
7918: [(0, 1), (3, 5), (6, 7), (10, 11)]
7919: >>> list(memory.gaps(*memory.span))
7920: [(3, 5), (6, 7)]
7921: >>> list(memory.gaps(2, 6))
7922: [(3, 5)]
7923: """
7924: cdef:
7925: addr_t start_
7926: addr_t endex_
+7927: bint bound_ = <bint>bound
__pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_cur_scope->__pyx_v_bound); if (unlikely(__pyx_t_1 < 0)) __PYX_ERR(0, 7927, __pyx_L1_error) __pyx_cur_scope->__pyx_v_bound_ = __pyx_t_1;
+7928: const Rack_* blocks = self._.blocks
__pyx_t_2 = __pyx_cur_scope->__pyx_v_self->_->blocks; __pyx_cur_scope->__pyx_v_blocks = __pyx_t_2;
+7929: size_t block_count = Rack_Length(blocks)
__pyx_cur_scope->__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_cur_scope->__pyx_v_blocks);
7930: size_t block_index
7931: size_t block_index_start
7932: size_t block_index_endex
7933: const Block_* block
7934: addr_t block_start
7935: addr_t block_endex
7936:
+7937: if block_count:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_block_count != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+7938: start__ = start
__Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_start__ = __pyx_cur_scope->__pyx_v_start;
+7939: endex__ = endex
__Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); __pyx_cur_scope->__pyx_v_endex__ = __pyx_cur_scope->__pyx_v_endex;
+7940: start_, endex_ = Memory_Bound(self._, start, endex)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_cur_scope->__pyx_v_self->_, __pyx_cur_scope->__pyx_v_start, __pyx_cur_scope->__pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 7940, __pyx_L1_error)
__pyx_t_4 = __pyx_t_3.f0;
__pyx_t_5 = __pyx_t_3.f1;
__pyx_cur_scope->__pyx_v_start_ = __pyx_t_4;
__pyx_cur_scope->__pyx_v_endex_ = __pyx_t_5;
7941:
+7942: if start__ is None:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_start__ == Py_None); __pyx_t_6 = (__pyx_t_1 != 0); if (__pyx_t_6) { /* … */ goto __pyx_L5; }
+7943: if not bound_:
__pyx_t_6 = ((!(__pyx_cur_scope->__pyx_v_bound_ != 0)) != 0); if (__pyx_t_6) { /* … */ }
+7944: block = Rack_First__(blocks)
__pyx_cur_scope->__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_First__(__pyx_cur_scope->__pyx_v_blocks);
+7945: start_ = Block_Start(block) # override trim start
__pyx_cur_scope->__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_cur_scope->__pyx_v_block);
+7946: yield None, start_
__pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_start_); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7946, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7946, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_8, 0, Py_None); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_7); __pyx_t_7 = 0; __pyx_r = __pyx_t_8; __pyx_t_8 = 0; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L7_resume_from_yield:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 7946, __pyx_L1_error)
+7947: block_index_start = 0
__pyx_cur_scope->__pyx_v_block_index_start = 0;
7948: else:
+7949: block_index_start = Rack_IndexStart(blocks, start_)
/*else*/ {
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_cur_scope->__pyx_v_blocks, __pyx_cur_scope->__pyx_v_start_); if (unlikely(__pyx_t_9 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 7949, __pyx_L1_error)
__pyx_cur_scope->__pyx_v_block_index_start = __pyx_t_9;
}
__pyx_L5:;
7950:
+7951: if endex__ is None:
__pyx_t_6 = (__pyx_cur_scope->__pyx_v_endex__ == Py_None); __pyx_t_1 = (__pyx_t_6 != 0); if (__pyx_t_1) { /* … */ goto __pyx_L8; }
+7952: block_index_endex = block_count
__pyx_cur_scope->__pyx_v_block_index_endex = __pyx_cur_scope->__pyx_v_block_count;
7953: else:
+7954: block_index_endex = Rack_IndexEndex(blocks, endex_)
/*else*/ {
__pyx_t_9 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_cur_scope->__pyx_v_blocks, __pyx_cur_scope->__pyx_v_endex_); if (unlikely(__pyx_t_9 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 7954, __pyx_L1_error)
__pyx_cur_scope->__pyx_v_block_index_endex = __pyx_t_9;
}
__pyx_L8:;
7955:
+7956: for block_index in range(block_index_start, block_index_endex):
__pyx_t_10 = __pyx_cur_scope->__pyx_v_block_index_endex; __pyx_t_11 = __pyx_t_10; for (__pyx_t_12 = __pyx_cur_scope->__pyx_v_block_index_start; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) { __pyx_cur_scope->__pyx_v_block_index = __pyx_t_12;
+7957: block = Rack_Get__(blocks, block_index)
__pyx_cur_scope->__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_cur_scope->__pyx_v_blocks, __pyx_cur_scope->__pyx_v_block_index);
+7958: block_start = Block_Start(block)
__pyx_cur_scope->__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_cur_scope->__pyx_v_block);
+7959: if start_ < block_start:
__pyx_t_1 = ((__pyx_cur_scope->__pyx_v_start_ < __pyx_cur_scope->__pyx_v_block_start) != 0); if (__pyx_t_1) { /* … */ }
+7960: yield start_, block_start
__pyx_t_8 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_start_); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7960, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_block_start); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7960, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_13 = PyTuple_New(2); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 7960, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_13); __Pyx_GIVEREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_13, 0, __pyx_t_8); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_13, 1, __pyx_t_7); __pyx_t_8 = 0; __pyx_t_7 = 0; __pyx_r = __pyx_t_13; __pyx_t_13 = 0; __pyx_cur_scope->__pyx_t_0 = __pyx_t_10; __pyx_cur_scope->__pyx_t_1 = __pyx_t_11; __pyx_cur_scope->__pyx_t_2 = __pyx_t_12; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 2; return __pyx_r; __pyx_L12_resume_from_yield:; __pyx_t_10 = __pyx_cur_scope->__pyx_t_0; __pyx_t_11 = __pyx_cur_scope->__pyx_t_1; __pyx_t_12 = __pyx_cur_scope->__pyx_t_2; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 7960, __pyx_L1_error)
+7961: start_ = Block_Endex(block)
__pyx_cur_scope->__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_cur_scope->__pyx_v_block); }
7962:
+7963: if endex__ is None and not bound_:
__pyx_t_6 = (__pyx_cur_scope->__pyx_v_endex__ == Py_None); __pyx_t_14 = (__pyx_t_6 != 0); if (__pyx_t_14) { } else { __pyx_t_1 = __pyx_t_14; goto __pyx_L14_bool_binop_done; } __pyx_t_14 = ((!(__pyx_cur_scope->__pyx_v_bound_ != 0)) != 0); __pyx_t_1 = __pyx_t_14; __pyx_L14_bool_binop_done:; if (__pyx_t_1) { /* … */ goto __pyx_L13; }
+7964: yield start_, None
__pyx_t_13 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_start_); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 7964, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7964, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_13); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_13); __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_7, 1, Py_None); __pyx_t_13 = 0; __pyx_r = __pyx_t_7; __pyx_t_7 = 0; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 3; return __pyx_r; __pyx_L16_resume_from_yield:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 7964, __pyx_L1_error)
+7965: elif start_ < endex_:
__pyx_t_1 = ((__pyx_cur_scope->__pyx_v_start_ < __pyx_cur_scope->__pyx_v_endex_) != 0); if (__pyx_t_1) { /* … */ } __pyx_L13:;
+7966: yield start_, endex_
__pyx_t_7 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_start_); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7966, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_13 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_endex_); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 7966, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 7966, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_13); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_13); __pyx_t_7 = 0; __pyx_t_13 = 0; __pyx_r = __pyx_t_8; __pyx_t_8 = 0; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 4; return __pyx_r; __pyx_L17_resume_from_yield:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 7966, __pyx_L1_error)
7967:
+7968: elif not bound_:
__pyx_t_1 = ((!(__pyx_cur_scope->__pyx_v_bound_ != 0)) != 0); if (__pyx_t_1) { /* … */ } __pyx_L4:; CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
+7969: yield None, None
__Pyx_INCREF(__pyx_tuple__31); __pyx_r = __pyx_tuple__31; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 5; return __pyx_r; __pyx_L18_resume_from_yield:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 7969, __pyx_L1_error) /* … */ __pyx_tuple__31 = PyTuple_Pack(2, Py_None, Py_None); if (unlikely(!__pyx_tuple__31)) __PYX_ERR(0, 7969, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__31); __Pyx_GIVEREF(__pyx_tuple__31);
7970:
+7971: def index(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_122index(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_121index[] = "Memory.index(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> Address\nIndex of an item.\n\n Arguments:\n item (items):\n Value to find. Can be either some byte string or an integer.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The index of the first item equal to `value`.\n\n Raises:\n :obj:`ValueError`: Item not found.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_122index = {"index", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_122index, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_121index}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_122index(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("index (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_121index(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("index", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.index", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__155 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__155)) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__155); __Pyx_GIVEREF(__pyx_tuple__155); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 7971, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_122index, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_index, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__156)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_index, __pyx_t_9) < 0) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__156 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__155, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_index, 7971, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__156)) __PYX_ERR(0, 7971, __pyx_L1_error)
7972: self: Memory,
+7973: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Union); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7973, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 7973, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7973, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7973, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_9); __pyx_t_6 = 0; __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7973, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_item, __pyx_t_9) < 0) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7974: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7974, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7974, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7974, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+7975: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "index") < 0)) __PYX_ERR(0, 7971, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("index", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 7971, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.index", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_121index(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 7975, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 7975, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7975, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+7976: ) -> Address:
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 7976, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_9) < 0) __PYX_ERR(0, 7971, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
7977: r"""Index of an item.
7978:
7979: Arguments:
7980: item (items):
7981: Value to find. Can be either some byte string or an integer.
7982:
7983: start (int):
7984: Inclusive start of the searched range.
7985: If ``None``, :attr:`start` is considered.
7986:
7987: endex (int):
7988: Exclusive end of the searched range.
7989: If ``None``, :attr:`endex` is considered.
7990:
7991: Returns:
7992: int: The index of the first item equal to `value`.
7993:
7994: Raises:
7995: :obj:`ValueError`: Item not found.
7996: """
7997:
+7998: return Memory_Index(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Index(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 7998, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
7999:
+8000: def insert(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_124insert(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_123insert[] = "Memory.insert(self: Memory, address: Address, data: Union[AnyBytes, Value, Memory]) -> None\nInserts data.\n\n Inserts data, moving existing items after the insertion address by the\n size of the inserted data.\n\n Arguments::\n address (int):\n Address of the insertion point.\n\n data (bytes):\n Data to insert.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| | | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C]| | |[x | y | z]| |[$]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C]| | |[x | y | 1 | z]| |[$]|\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> memory.insert(10, b'$')\n >>> memory._blocks\n [[1, b'ABC'], [6, b'xyz'], [10, b'$']]\n >>> memory.insert(8, b'1')\n >>> memory._blocks\n [[1, b'ABC'], [6, b'xy1z'], [11, b'$']]\n\n See Also:\n :meth:`insert_backup`\n :meth:`insert_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_124insert = {"insert", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_124insert, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_123insert}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_124insert(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_data = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("insert (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_data,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_data)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("insert", 1, 2, 2, 1); __PYX_ERR(0, 8000, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "insert") < 0)) __PYX_ERR(0, 8000, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_data = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("insert", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8000, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.insert", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_123insert(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_data); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_123insert(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_data) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("insert", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.insert", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__157 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_data); if (unlikely(!__pyx_tuple__157)) __PYX_ERR(0, 8000, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__157); __Pyx_GIVEREF(__pyx_tuple__157); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8000, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8000, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_124insert, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_insert, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__158)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8000, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_insert, __pyx_t_2) < 0) __PYX_ERR(0, 8000, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__158 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__157, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_insert, 8000, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__158)) __PYX_ERR(0, 8000, __pyx_L1_error)
8001: self: Memory,
+8002: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8002, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_address, __pyx_t_5) < 0) __PYX_ERR(0, 8000, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8003: data: Union[AnyBytes, Value, Memory],
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Union); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8003, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8003, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Value); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8003, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_6 = PyTuple_New(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8003, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_2); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_6, 2, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_7 = 0; __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8003, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_data, __pyx_t_2) < 0) __PYX_ERR(0, 8000, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+8004: ) -> None:
if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8000, __pyx_L1_error)
8005: r"""Inserts data.
8006:
8007: Inserts data, moving existing items after the insertion address by the
8008: size of the inserted data.
8009:
8010: Arguments::
8011: address (int):
8012: Address of the insertion point.
8013:
8014: data (bytes):
8015: Data to insert.
8016:
8017: Example:
8018: +---+---+---+---+---+---+---+---+---+---+---+---+
8019: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
8020: +===+===+===+===+===+===+===+===+===+===+===+===+
8021: | |[A | B | C]| | |[x | y | z]| | | |
8022: +---+---+---+---+---+---+---+---+---+---+---+---+
8023: | |[A | B | C]| | |[x | y | z]| |[$]| |
8024: +---+---+---+---+---+---+---+---+---+---+---+---+
8025: | |[A | B | C]| | |[x | y | 1 | z]| |[$]|
8026: +---+---+---+---+---+---+---+---+---+---+---+---+
8027:
8028: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
8029: >>> memory.insert(10, b'$')
8030: >>> memory._blocks
8031: [[1, b'ABC'], [6, b'xyz'], [10, b'$']]
8032: >>> memory.insert(8, b'1')
8033: >>> memory._blocks
8034: [[1, b'ABC'], [6, b'xy1z'], [11, b'$']]
8035:
8036: See Also:
8037: :meth:`insert_backup`
8038: :meth:`insert_restore`
8039: """
8040:
+8041: Memory_Insert(self._, address, data)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Insert(__pyx_v_self->_, __pyx_v_address, __pyx_v_data); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8041, __pyx_L1_error)
8042:
+8043: def insert_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_126insert_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_125insert_backup[] = "Memory.insert_backup(self: Memory, address: Address, data: Union[AnyBytes, Value, Memory]) -> Tuple[Address, Memory]\nBackups an `insert()` operation.\n\n Arguments:\n address (int):\n Address of the insertion point.\n\n data (bytes):\n Data to insert.\n\n Returns:\n (int, :obj:`Memory`): Insertion address, backup memory region.\n\n See Also:\n :meth:`insert`\n :meth:`insert_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_126insert_backup = {"insert_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_126insert_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_125insert_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_126insert_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_data = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("insert_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_data,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_data)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("insert_backup", 1, 2, 2, 1); __PYX_ERR(0, 8043, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "insert_backup") < 0)) __PYX_ERR(0, 8043, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_data = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("insert_backup", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8043, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.insert_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_125insert_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_data); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_125insert_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_data) { Py_ssize_t __pyx_v_size; PyObject *__pyx_v_backup = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("insert_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_9); __Pyx_AddTraceback("cbytesparse.c.Memory.insert_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_backup); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__159 = PyTuple_Pack(5, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_data, __pyx_n_s_size, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__159)) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__159); __Pyx_GIVEREF(__pyx_tuple__159); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8043, __pyx_L1_error) /* … */ __pyx_t_7 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_126insert_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_insert_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__160)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_7, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_insert_backup, __pyx_t_7) < 0) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__160 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__159, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_insert_backup, 8043, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__160)) __PYX_ERR(0, 8043, __pyx_L1_error)
8044: self: Memory,
+8045: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8045, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_address, __pyx_t_9) < 0) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+8046: data: Union[AnyBytes, Value, Memory],
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Union); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Value); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_7 = PyTuple_New(3); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_5); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_7, 2, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_6 = 0; __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_7); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_data, __pyx_t_5) < 0) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8047: ) -> Tuple[Address, Memory]:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_7); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_9, 1, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_7) < 0) __PYX_ERR(0, 8043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
8048: r"""Backups an `insert()` operation.
8049:
8050: Arguments:
8051: address (int):
8052: Address of the insertion point.
8053:
8054: data (bytes):
8055: Data to insert.
8056:
8057: Returns:
8058: (int, :obj:`Memory`): Insertion address, backup memory region.
8059:
8060: See Also:
8061: :meth:`insert`
8062: :meth:`insert_restore`
8063: """
8064:
+8065: size = 1 if isinstance(data, int) else len(data)
__pyx_t_2 = PyInt_Check(__pyx_v_data); if ((__pyx_t_2 != 0)) { __pyx_t_1 = 1; } else { __pyx_t_3 = PyObject_Length(__pyx_v_data); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-1))) __PYX_ERR(0, 8065, __pyx_L1_error) __pyx_t_1 = __pyx_t_3; } __pyx_v_size = __pyx_t_1;
+8066: backup = self._pretrim_endex_backup(address, size)
__pyx_t_5 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_pretrim_endex_backup); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8066, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = PyInt_FromSsize_t(__pyx_v_size); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8066, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = NULL; __pyx_t_8 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_5))) { __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_5); if (likely(__pyx_t_7)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5); __Pyx_INCREF(__pyx_t_7); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_5, function); __pyx_t_8 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_5)) { PyObject *__pyx_temp[3] = {__pyx_t_7, __pyx_v_address, __pyx_t_6}; __pyx_t_4 = __Pyx_PyFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_8, 2+__pyx_t_8); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8066, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_5)) { PyObject *__pyx_temp[3] = {__pyx_t_7, __pyx_v_address, __pyx_t_6}; __pyx_t_4 = __Pyx_PyCFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_8, 2+__pyx_t_8); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8066, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; } else #endif { __pyx_t_9 = PyTuple_New(2+__pyx_t_8); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8066, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (__pyx_t_7) { __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_7); __pyx_t_7 = NULL; } __Pyx_INCREF(__pyx_v_address); __Pyx_GIVEREF(__pyx_v_address); PyTuple_SET_ITEM(__pyx_t_9, 0+__pyx_t_8, __pyx_v_address); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_9, 1+__pyx_t_8, __pyx_t_6); __pyx_t_6 = 0; __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_9, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8066, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; } __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_v_backup = __pyx_t_4; __pyx_t_4 = 0;
+8067: return address, backup
__Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8067, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_INCREF(__pyx_v_address); __Pyx_GIVEREF(__pyx_v_address); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v_address); __Pyx_INCREF(__pyx_v_backup); __Pyx_GIVEREF(__pyx_v_backup); PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_v_backup); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0;
8068:
+8069: def insert_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_128insert_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_127insert_restore[] = "Memory.insert_restore(self: Memory, addr_t address: Address, Memory backup: Memory) -> None\nRestores an `insert()` operation.\n\n Arguments:\n address (int):\n Address of the insertion point.\n\n backup (:obj:`Memory`):\n Backup memory region to restore.\n\n See Also:\n :meth:`insert`\n :meth:`insert_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_128insert_restore = {"insert_restore", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_128insert_restore, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_127insert_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_128insert_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { addr_t __pyx_v_address; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("insert_restore (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_backup,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_backup)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("insert_restore", 1, 2, 2, 1); __PYX_ERR(0, 8069, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "insert_restore") < 0)) __PYX_ERR(0, 8069, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = __Pyx_PyInt_As_uint_fast64_t(values[0]); if (unlikely((__pyx_v_address == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8071, __pyx_L3_error) __pyx_v_backup = ((struct __pyx_obj_11cbytesparse_1c_Memory *)values[1]); } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("insert_restore", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8069, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.insert_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 8072, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_127insert_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_backup); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_127insert_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, addr_t __pyx_v_address, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { Memory_ *__pyx_v_memory; addr_t __pyx_v_size; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("insert_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.insert_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_131generator3(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */ /* … */ __pyx_tuple__161 = PyTuple_Pack(5, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_backup, __pyx_n_s_memory, __pyx_n_s_size); if (unlikely(!__pyx_tuple__161)) __PYX_ERR(0, 8069, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__161); __Pyx_GIVEREF(__pyx_tuple__161); /* … */ __pyx_t_7 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8069, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8069, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_128insert_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_insert_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__162)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8069, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_7); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_insert_restore, __pyx_t_2) < 0) __PYX_ERR(0, 8069, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__162 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__161, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_insert_restore, 8069, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__162)) __PYX_ERR(0, 8069, __pyx_L1_error)
8070: self: Memory,
+8071: addr_t address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8071, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_address, __pyx_t_2) < 0) __PYX_ERR(0, 8069, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8069, __pyx_L1_error)
8072: Memory backup not None: Memory,
+8073: ) -> None:
if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8069, __pyx_L1_error)
8074: r"""Restores an `insert()` operation.
8075:
8076: Arguments:
8077: address (int):
8078: Address of the insertion point.
8079:
8080: backup (:obj:`Memory`):
8081: Backup memory region to restore.
8082:
8083: See Also:
8084: :meth:`insert`
8085: :meth:`insert_backup`
8086: """
8087: cdef:
+8088: Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+8089: addr_t size = Memory_Length(backup._)
__pyx_v_size = __pyx_f_11cbytesparse_1c_Memory_Length(__pyx_v_backup->_);
8090:
+8091: CheckAddAddrU(address, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8091, __pyx_L1_error)
+8092: Memory_Delete_(memory, address, address + size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Delete_(__pyx_v_memory, __pyx_v_address, (__pyx_v_address + __pyx_v_size)); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8092, __pyx_L1_error)
+8093: Memory_WriteSame_(memory, 0, backup._, True)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_memory, 0, __pyx_v_backup->_, 1); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8093, __pyx_L1_error)
8094:
+8095: def intervals(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_130intervals(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_129intervals[] = "Memory.intervals(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> Iterator[ClosedInterval]\nIterates over block intervals.\n\n Iterates over data boundaries within an address range.\n\n Arguments:\n start (int):\n Inclusive start address.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address.\n If ``None``, :attr:`endex` is considered.\n\n Yields:\n couple of addresses: Block data interval boundaries.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|\n +===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B]| | |[x]| |[1 | 2 | 3]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'AB'], [5, b'x'], [7, b'123']])\n >>> list(memory.intervals())\n [(1, 3), (5, 6), (7, 10)]\n >>> list(memory.intervals(2, 9))\n [(2, 3), (5, 6), (7, 9)]\n >>> list(memory.intervals(3, 5))\n []\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_130intervals = {"intervals", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_130intervals, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_129intervals}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_130intervals(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("intervals (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_129intervals(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_3_intervals *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("intervals", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_3_intervals *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_3_intervals(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_3_intervals, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_3_intervals *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 8095, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __pyx_cur_scope->__pyx_v_start = __pyx_v_start; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_endex = __pyx_v_endex; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_131generator3, __pyx_codeobj__32, (PyObject *) __pyx_cur_scope, __pyx_n_s_intervals, __pyx_n_s_Memory_intervals, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.intervals", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_131generator3(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("intervals", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8095, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("intervals", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_134generator4(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */ /* … */ __pyx_tuple__163 = PyTuple_Pack(15, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_start_2, __pyx_n_s_endex_2, __pyx_n_s_blocks, __pyx_n_s_block_count, __pyx_n_s_block_index, __pyx_n_s_block_index_start_2, __pyx_n_s_block_index_endex_2, __pyx_n_s_block, __pyx_n_s_block_start, __pyx_n_s_block_endex, __pyx_n_s_slice_start, __pyx_n_s_slice_endex); if (unlikely(!__pyx_tuple__163)) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__163); __Pyx_GIVEREF(__pyx_tuple__163); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8095, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_130intervals, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_intervals, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__32)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_intervals, __pyx_t_5) < 0) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__32 = (PyObject*)__Pyx_PyCode_New(3, 0, 15, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__163, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_intervals, 8095, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__32)) __PYX_ERR(0, 8095, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_3_intervals { PyObject_HEAD Block_ const *__pyx_v_block; size_t __pyx_v_block_count; addr_t __pyx_v_block_endex; size_t __pyx_v_block_index; size_t __pyx_v_block_index_endex; size_t __pyx_v_block_index_start; addr_t __pyx_v_block_start; Rack_ const *__pyx_v_blocks; PyObject *__pyx_v_endex; addr_t __pyx_v_endex_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; size_t __pyx_v_slice_endex; size_t __pyx_v_slice_start; PyObject *__pyx_v_start; addr_t __pyx_v_start_; size_t __pyx_t_0; size_t __pyx_t_1; size_t __pyx_t_2; };
8096: self: Memory,
+8097: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8097, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8097, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8097, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8098: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "intervals") < 0)) __PYX_ERR(0, 8095, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("intervals", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8095, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.intervals", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_129intervals(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8098, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8098, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8098, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_7) < 0) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8099: ) -> Iterator[ClosedInterval]:
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8099, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_ClosedInterval); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8099, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8099, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_5) < 0) __PYX_ERR(0, 8095, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
8100: r"""Iterates over block intervals.
8101:
8102: Iterates over data boundaries within an address range.
8103:
8104: Arguments:
8105: start (int):
8106: Inclusive start address.
8107: If ``None``, :attr:`start` is considered.
8108:
8109: endex (int):
8110: Exclusive end address.
8111: If ``None``, :attr:`endex` is considered.
8112:
8113: Yields:
8114: couple of addresses: Block data interval boundaries.
8115:
8116: Example:
8117: +---+---+---+---+---+---+---+---+---+---+---+
8118: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10|
8119: +===+===+===+===+===+===+===+===+===+===+===+
8120: | |[A | B]| | |[x]| |[1 | 2 | 3]| |
8121: +---+---+---+---+---+---+---+---+---+---+---+
8122:
8123: >>> memory = Memory.from_blocks([[1, b'AB'], [5, b'x'], [7, b'123']])
8124: >>> list(memory.intervals())
8125: [(1, 3), (5, 6), (7, 10)]
8126: >>> list(memory.intervals(2, 9))
8127: [(2, 3), (5, 6), (7, 9)]
8128: >>> list(memory.intervals(3, 5))
8129: []
8130: """
8131: cdef:
8132: addr_t start_
8133: addr_t endex_
+8134: const Rack_* blocks = self._.blocks
__pyx_t_1 = __pyx_cur_scope->__pyx_v_self->_->blocks; __pyx_cur_scope->__pyx_v_blocks = __pyx_t_1;
+8135: size_t block_count = Rack_Length(blocks)
__pyx_cur_scope->__pyx_v_block_count = __pyx_f_11cbytesparse_1c_Rack_Length(__pyx_cur_scope->__pyx_v_blocks);
8136: size_t block_index
8137: size_t block_index_start
8138: size_t block_index_endex
8139: const Block_* block
8140: addr_t block_start
8141: addr_t block_endex
8142: size_t slice_start
8143: size_t slice_endex
8144:
+8145: if block_count:
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_block_count != 0); if (__pyx_t_2) { /* … */ } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
+8146: block_index_start = 0 if start is None else Rack_IndexStart(blocks, <addr_t>start)
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_start == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_3 = 0; } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_start); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8146, __pyx_L1_error) __pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_IndexStart(__pyx_cur_scope->__pyx_v_blocks, ((addr_t)__pyx_t_4)); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 8146, __pyx_L1_error) __pyx_t_3 = __pyx_t_5; } __pyx_cur_scope->__pyx_v_block_index_start = __pyx_t_3;
+8147: block_index_endex = block_count if endex is None else Rack_IndexEndex(blocks, <addr_t>endex)
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_endex == Py_None); if ((__pyx_t_2 != 0)) { __pyx_t_3 = __pyx_cur_scope->__pyx_v_block_count; } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_endex); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8147, __pyx_L1_error) __pyx_t_5 = __pyx_f_11cbytesparse_1c_Rack_IndexEndex(__pyx_cur_scope->__pyx_v_blocks, ((addr_t)__pyx_t_4)); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-2L))) __PYX_ERR(0, 8147, __pyx_L1_error) __pyx_t_3 = __pyx_t_5; } __pyx_cur_scope->__pyx_v_block_index_endex = __pyx_t_3;
+8148: start_, endex_ = Memory_Bound(self._, start, endex)
__pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Bound(__pyx_cur_scope->__pyx_v_self->_, __pyx_cur_scope->__pyx_v_start, __pyx_cur_scope->__pyx_v_endex); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 8148, __pyx_L1_error)
__pyx_t_4 = __pyx_t_6.f0;
__pyx_t_7 = __pyx_t_6.f1;
__pyx_cur_scope->__pyx_v_start_ = __pyx_t_4;
__pyx_cur_scope->__pyx_v_endex_ = __pyx_t_7;
8149:
+8150: for block_index in range(block_index_start, block_index_endex):
__pyx_t_3 = __pyx_cur_scope->__pyx_v_block_index_endex; __pyx_t_8 = __pyx_t_3; for (__pyx_t_9 = __pyx_cur_scope->__pyx_v_block_index_start; __pyx_t_9 < __pyx_t_8; __pyx_t_9+=1) { __pyx_cur_scope->__pyx_v_block_index = __pyx_t_9;
+8151: block = Rack_Get__(blocks, block_index)
__pyx_cur_scope->__pyx_v_block = __pyx_f_11cbytesparse_1c_Rack_Get__(__pyx_cur_scope->__pyx_v_blocks, __pyx_cur_scope->__pyx_v_block_index);
+8152: block_start = Block_Start(block)
__pyx_cur_scope->__pyx_v_block_start = __pyx_f_11cbytesparse_1c_Block_Start(__pyx_cur_scope->__pyx_v_block);
+8153: block_endex = Block_Endex(block)
__pyx_cur_scope->__pyx_v_block_endex = __pyx_f_11cbytesparse_1c_Block_Endex(__pyx_cur_scope->__pyx_v_block);
+8154: slice_start = block_start if start_ < block_start else start_
if (((__pyx_cur_scope->__pyx_v_start_ < __pyx_cur_scope->__pyx_v_block_start) != 0)) { __pyx_t_7 = __pyx_cur_scope->__pyx_v_block_start; } else { __pyx_t_7 = __pyx_cur_scope->__pyx_v_start_; } __pyx_cur_scope->__pyx_v_slice_start = __pyx_t_7;
+8155: slice_endex = endex_ if endex_ < block_endex else block_endex
if (((__pyx_cur_scope->__pyx_v_endex_ < __pyx_cur_scope->__pyx_v_block_endex) != 0)) { __pyx_t_7 = __pyx_cur_scope->__pyx_v_endex_; } else { __pyx_t_7 = __pyx_cur_scope->__pyx_v_block_endex; } __pyx_cur_scope->__pyx_v_slice_endex = __pyx_t_7;
+8156: if slice_start < slice_endex:
__pyx_t_2 = ((__pyx_cur_scope->__pyx_v_slice_start < __pyx_cur_scope->__pyx_v_slice_endex) != 0); if (__pyx_t_2) { /* … */ } }
+8157: yield slice_start, slice_endex
__pyx_t_10 = __Pyx_PyInt_FromSize_t(__pyx_cur_scope->__pyx_v_slice_start); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 8157, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_10); __pyx_t_11 = __Pyx_PyInt_FromSize_t(__pyx_cur_scope->__pyx_v_slice_endex); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 8157, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_11); __pyx_t_12 = PyTuple_New(2); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 8157, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_GIVEREF(__pyx_t_10); PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_10); __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_11); __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_r = __pyx_t_12; __pyx_t_12 = 0; __pyx_cur_scope->__pyx_t_0 = __pyx_t_3; __pyx_cur_scope->__pyx_t_1 = __pyx_t_8; __pyx_cur_scope->__pyx_t_2 = __pyx_t_9; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L8_resume_from_yield:; __pyx_t_3 = __pyx_cur_scope->__pyx_t_0; __pyx_t_8 = __pyx_cur_scope->__pyx_t_1; __pyx_t_9 = __pyx_cur_scope->__pyx_t_2; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8157, __pyx_L1_error)
8158:
+8159: def items(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_133items(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_132items[] = "Memory.items(self: Memory, start: Optional[Address] = None, endex: Optional[Union[Address, EllipsisType]] = None, pattern: Optional[Union[AnyBytes, Value]] = None) -> Iterator[Tuple[Address, Value]]\nIterates over address and value couples.\n\n Iterates over address and value couples, from `start` to `endex`.\n Implemets the interface of :obj:`dict`.\n\n Arguments:\n start (int):\n Inclusive start address.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address.\n If ``None``, :attr:`endex` is considered.\n If ``Ellipsis``, the iterator is infinite.\n\n pattern (items):\n Pattern of values to fill emptiness.\n\n Yields:\n int: Range address and value couples.\n\n Examples:\n >>> from itertools import islice\n >>> memory = Memory()\n >>> list(memory.items(endex=8))\n [(0, None), (1, None), (2, None), (3, None), (4, None), (5, None), (6, None), (7, None)]\n >>> list(memory.items(3, 8))\n [(3, None), (4, None), (5, None), (6, None), (7, None)]\n >>> list(islice(memory.items(3, ...), 7))\n [(3, None), (4, None), (5, None), (6, None), (7, None), (8, None), (9, None)]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | | 65| 66| 67| | |120|121|122| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> list(memory.items())\n [(1, 65), (2, 66), (3, 67), (4, None), (5, None), (6, 120), (7, 121), (8, 122)]\n >>> list(m""emory.items(3, 8))\n [(3, 67), (4, None), (5, None), (6, 120), (7, 121)]\n >>> list(islice(memory.items(3, ...), 7))\n [(3, 67), (4, None), (5, None), (6, 120), (7, 121), (8, 122), (9, None)]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_133items = {"items", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_133items, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_132items}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_133items(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_pattern = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("items (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_pattern,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_132items(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_4_items *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("items", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_4_items *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_4_items(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_4_items, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_4_items *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 8159, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __pyx_cur_scope->__pyx_v_start = __pyx_v_start; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_endex = __pyx_v_endex; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); __pyx_cur_scope->__pyx_v_pattern = __pyx_v_pattern; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_pattern); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_pattern); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_134generator4, __pyx_codeobj__33, (PyObject *) __pyx_cur_scope, __pyx_n_s_items, __pyx_n_s_Memory_items, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.items", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_134generator4(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("items", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8159, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("items", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_137generator5(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */ /* … */ __pyx_tuple__164 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_pattern); if (unlikely(!__pyx_tuple__164)) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__164); __Pyx_GIVEREF(__pyx_tuple__164); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8159, __pyx_L1_error) /* … */ __pyx_t_7 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_133items, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_items, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__33)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_7, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_items, __pyx_t_7) < 0) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__33 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__164, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_items, 8159, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__33)) __PYX_ERR(0, 8159, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_4_items { PyObject_HEAD PyObject *__pyx_v_endex; PyObject *__pyx_v_pattern; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; PyObject *__pyx_v_start; };
8160: self: Memory,
+8161: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8161, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8161, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8161, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_start, __pyx_t_7) < 0) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8162: endex: Optional[Union[Address, EllipsisType]] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Union); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_EllipsisType); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_6); __pyx_t_2 = 0; __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8162, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_endex, __pyx_t_1) < 0) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8163: pattern: Optional[Union[AnyBytes, Value]] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pattern); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "items") < 0)) __PYX_ERR(0, 8159, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_pattern = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("items", 0, 0, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8159, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.items", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_132items(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_9); __pyx_t_7 = 0; __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8163, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_pattern, __pyx_t_2) < 0) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+8164: ) -> Iterator[Tuple[Address, Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_6); __pyx_t_1 = 0; __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8164, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_7) < 0) __PYX_ERR(0, 8159, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
8165: r"""Iterates over address and value couples.
8166:
8167: Iterates over address and value couples, from `start` to `endex`.
8168: Implemets the interface of :obj:`dict`.
8169:
8170: Arguments:
8171: start (int):
8172: Inclusive start address.
8173: If ``None``, :attr:`start` is considered.
8174:
8175: endex (int):
8176: Exclusive end address.
8177: If ``None``, :attr:`endex` is considered.
8178: If ``Ellipsis``, the iterator is infinite.
8179:
8180: pattern (items):
8181: Pattern of values to fill emptiness.
8182:
8183: Yields:
8184: int: Range address and value couples.
8185:
8186: Examples:
8187: >>> from itertools import islice
8188: >>> memory = Memory()
8189: >>> list(memory.items(endex=8))
8190: [(0, None), (1, None), (2, None), (3, None), (4, None), (5, None), (6, None), (7, None)]
8191: >>> list(memory.items(3, 8))
8192: [(3, None), (4, None), (5, None), (6, None), (7, None)]
8193: >>> list(islice(memory.items(3, ...), 7))
8194: [(3, None), (4, None), (5, None), (6, None), (7, None), (8, None), (9, None)]
8195:
8196: ~~~
8197:
8198: +---+---+---+---+---+---+---+---+---+---+
8199: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
8200: +===+===+===+===+===+===+===+===+===+===+
8201: | |[A | B | C]| | |[x | y | z]| |
8202: +---+---+---+---+---+---+---+---+---+---+
8203: | | 65| 66| 67| | |120|121|122| |
8204: +---+---+---+---+---+---+---+---+---+---+
8205:
8206: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
8207: >>> list(memory.items())
8208: [(1, 65), (2, 66), (3, 67), (4, None), (5, None), (6, 120), (7, 121), (8, 122)]
8209: >>> list(memory.items(3, 8))
8210: [(3, 67), (4, None), (5, None), (6, 120), (7, 121)]
8211: >>> list(islice(memory.items(3, ...), 7))
8212: [(3, 67), (4, None), (5, None), (6, 120), (7, 121), (8, 122), (9, None)]
8213: """
8214:
+8215: yield from zip(self.keys(start, endex), self.values(start, endex, pattern)) # TODO: cythonize
__pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_cur_scope->__pyx_v_self), __pyx_n_s_keys); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = NULL; __pyx_t_4 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_2, function); __pyx_t_4 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_2)) { PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_cur_scope->__pyx_v_start, __pyx_cur_scope->__pyx_v_endex}; __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_4, 2+__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_1); } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) { PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_cur_scope->__pyx_v_start, __pyx_cur_scope->__pyx_v_endex}; __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_4, 2+__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_1); } else #endif { __pyx_t_5 = PyTuple_New(2+__pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__pyx_t_3) { __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3); __pyx_t_3 = NULL; } __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_4, __pyx_cur_scope->__pyx_v_start); __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_4, __pyx_cur_scope->__pyx_v_endex); __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_5 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_cur_scope->__pyx_v_self), __pyx_n_s_values); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = NULL; __pyx_t_4 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_5))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_5); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_5, function); __pyx_t_4 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_5)) { PyObject *__pyx_temp[4] = {__pyx_t_3, __pyx_cur_scope->__pyx_v_start, __pyx_cur_scope->__pyx_v_endex, __pyx_cur_scope->__pyx_v_pattern}; __pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_4, 3+__pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_2); } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_5)) { PyObject *__pyx_temp[4] = {__pyx_t_3, __pyx_cur_scope->__pyx_v_start, __pyx_cur_scope->__pyx_v_endex, __pyx_cur_scope->__pyx_v_pattern}; __pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_4, 3+__pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_2); } else #endif { __pyx_t_6 = PyTuple_New(3+__pyx_t_4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (__pyx_t_3) { __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_3); __pyx_t_3 = NULL; } __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); PyTuple_SET_ITEM(__pyx_t_6, 0+__pyx_t_4, __pyx_cur_scope->__pyx_v_start); __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); PyTuple_SET_ITEM(__pyx_t_6, 1+__pyx_t_4, __pyx_cur_scope->__pyx_v_endex); __Pyx_INCREF(__pyx_cur_scope->__pyx_v_pattern); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_pattern); PyTuple_SET_ITEM(__pyx_t_6, 2+__pyx_t_4, __pyx_cur_scope->__pyx_v_pattern); __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; } __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_2); __pyx_t_1 = 0; __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_zip, __pyx_t_5, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8215, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_r = __Pyx_Generator_Yield_From(__pyx_generator, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XGOTREF(__pyx_r); if (likely(__pyx_r)) { __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L4_resume_from_yield_from:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8215, __pyx_L1_error) } else { PyObject* exc_type = __Pyx_PyErr_Occurred(); if (exc_type) { if (likely(exc_type == PyExc_StopIteration || (exc_type != PyExc_GeneratorExit && __Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration)))) PyErr_Clear(); else __PYX_ERR(0, 8215, __pyx_L1_error) } } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
8216:
+8217: def keys(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_136keys(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_135keys[] = "Memory.keys(self: Memory, start: Optional[Address] = None, endex: Optional[Union[Address, EllipsisType]] = None) -> Iterator[Address]\nIterates over addresses.\n\n Iterates over addresses, from `start` to `endex`.\n Implemets the interface of :obj:`dict`.\n\n Arguments:\n start (int):\n Inclusive start address.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address.\n If ``None``, :attr:`endex` is considered.\n If ``Ellipsis``, the iterator is infinite.\n\n Yields:\n int: Range address.\n\n Examples:\n >>> from itertools import islice\n >>> memory = Memory()\n >>> list(memory.keys())\n []\n >>> list(memory.keys(endex=8))\n [0, 1, 2, 3, 4, 5, 6, 7]\n >>> list(memory.keys(3, 8))\n [3, 4, 5, 6, 7]\n >>> list(islice(memory.keys(3, ...), 7))\n [3, 4, 5, 6, 7, 8, 9]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> list(memory.keys())\n [1, 2, 3, 4, 5, 6, 7, 8]\n >>> list(memory.keys(endex=8))\n [1, 2, 3, 4, 5, 6, 7]\n >>> list(memory.keys(3, 8))\n [3, 4, 5, 6, 7]\n >>> list(islice(memory.keys(3, ...), 7))\n [3, 4, 5, 6, 7, 8, 9]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_136keys = {"keys", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_136keys, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_135keys}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_136keys(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("keys (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_135keys(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_5_keys *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("keys", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_5_keys *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_5_keys(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_5_keys, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_5_keys *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 8217, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __pyx_cur_scope->__pyx_v_start = __pyx_v_start; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_endex = __pyx_v_endex; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_137generator5, __pyx_codeobj__34, (PyObject *) __pyx_cur_scope, __pyx_n_s_keys, __pyx_n_s_Memory_keys, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.keys", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_137generator5(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("keys", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8217, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("keys", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__165 = PyTuple_Pack(5, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_start_2, __pyx_n_s_endex_2); if (unlikely(!__pyx_tuple__165)) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__165); __Pyx_GIVEREF(__pyx_tuple__165); /* … */ __pyx_t_7 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8217, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_136keys, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_keys, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__34)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_7); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_keys, __pyx_t_2) < 0) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__34 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__165, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_keys, 8217, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__34)) __PYX_ERR(0, 8217, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_5_keys { PyObject_HEAD PyObject *__pyx_v_endex; addr_t __pyx_v_endex_; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; PyObject *__pyx_v_start; addr_t __pyx_v_start_; };
8218: self: Memory,
+8219: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8219, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8219, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8219, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_start, __pyx_t_2) < 0) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+8220: endex: Optional[Union[Address, EllipsisType]] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "keys") < 0)) __PYX_ERR(0, 8217, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("keys", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8217, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.keys", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_135keys(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_EllipsisType); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_5); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_9); __pyx_t_5 = 0; __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_1); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8220, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_endex, __pyx_t_1) < 0) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8221: ) -> Iterator[Address]:
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8221, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8221, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8221, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_return, __pyx_t_2) < 0) __PYX_ERR(0, 8217, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
8222: r"""Iterates over addresses.
8223:
8224: Iterates over addresses, from `start` to `endex`.
8225: Implemets the interface of :obj:`dict`.
8226:
8227: Arguments:
8228: start (int):
8229: Inclusive start address.
8230: If ``None``, :attr:`start` is considered.
8231:
8232: endex (int):
8233: Exclusive end address.
8234: If ``None``, :attr:`endex` is considered.
8235: If ``Ellipsis``, the iterator is infinite.
8236:
8237: Yields:
8238: int: Range address.
8239:
8240: Examples:
8241: >>> from itertools import islice
8242: >>> memory = Memory()
8243: >>> list(memory.keys())
8244: []
8245: >>> list(memory.keys(endex=8))
8246: [0, 1, 2, 3, 4, 5, 6, 7]
8247: >>> list(memory.keys(3, 8))
8248: [3, 4, 5, 6, 7]
8249: >>> list(islice(memory.keys(3, ...), 7))
8250: [3, 4, 5, 6, 7, 8, 9]
8251:
8252: ~~~
8253:
8254: +---+---+---+---+---+---+---+---+---+---+
8255: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
8256: +===+===+===+===+===+===+===+===+===+===+
8257: | |[A | B | C]| | |[x | y | z]| |
8258: +---+---+---+---+---+---+---+---+---+---+
8259:
8260: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
8261: >>> list(memory.keys())
8262: [1, 2, 3, 4, 5, 6, 7, 8]
8263: >>> list(memory.keys(endex=8))
8264: [1, 2, 3, 4, 5, 6, 7]
8265: >>> list(memory.keys(3, 8))
8266: [3, 4, 5, 6, 7]
8267: >>> list(islice(memory.keys(3, ...), 7))
8268: [3, 4, 5, 6, 7, 8, 9]
8269: """
8270: cdef:
8271: addr_t start_
8272: addr_t endex_
8273:
+8274: if start is None:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_start == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+8275: start_ = Memory_Start(self._)
__pyx_cur_scope->__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_cur_scope->__pyx_v_self->_);
8276: else:
+8277: start_ = <addr_t>start
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8277, __pyx_L1_error) __pyx_cur_scope->__pyx_v_start_ = ((addr_t)__pyx_t_3); } __pyx_L4:;
8278:
+8279: if endex is None:
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_endex == Py_None); __pyx_t_1 = (__pyx_t_2 != 0); if (__pyx_t_1) { /* … */ goto __pyx_L5; }
+8280: endex_ = Memory_Endex(self._)
__pyx_cur_scope->__pyx_v_endex_ = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_cur_scope->__pyx_v_self->_);
+8281: elif endex is Ellipsis:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_endex == __pyx_builtin_Ellipsis); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L5; }
+8282: endex_ = ADDR_MAX
__pyx_cur_scope->__pyx_v_endex_ = ADDR_MAX;
8283: else:
+8284: endex_ = <addr_t>endex
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8284, __pyx_L1_error) __pyx_cur_scope->__pyx_v_endex_ = ((addr_t)__pyx_t_3); } __pyx_L5:;
8285:
+8286: while start_ < endex_:
while (1) { __pyx_t_2 = ((__pyx_cur_scope->__pyx_v_start_ < __pyx_cur_scope->__pyx_v_endex_) != 0); if (!__pyx_t_2) break;
+8287: yield start_
__pyx_t_4 = __Pyx_PyInt_From_uint_fast64_t(__pyx_cur_scope->__pyx_v_start_); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8287, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L8_resume_from_yield:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8287, __pyx_L1_error)
+8288: start_ += 1
__pyx_cur_scope->__pyx_v_start_ = (__pyx_cur_scope->__pyx_v_start_ + 1); } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
8289:
+8290: def ofind(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_139ofind(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_138ofind[] = "Memory.ofind(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> Optional[Address]\nIndex of an item.\n\n Arguments:\n item (items):\n Value to find. Can be either some byte string or an integer.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The index of the first item equal to `value`, or ``None``.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_139ofind = {"ofind", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_139ofind, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_138ofind}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_139ofind(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("ofind (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_138ofind(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("ofind", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.ofind", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__166 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__166)) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__166); __Pyx_GIVEREF(__pyx_tuple__166); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8290, __pyx_L1_error) /* … */ __pyx_t_7 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_139ofind, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_ofind, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__167)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_7, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_ofind, __pyx_t_7) < 0) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__167 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__166, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_ofind, 8290, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__167)) __PYX_ERR(0, 8290, __pyx_L1_error)
8291: self: Memory,
+8292: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Union); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8292, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8292, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8292, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8292, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_9); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_1); __pyx_t_9 = 0; __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8292, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_item, __pyx_t_1) < 0) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8293: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8293, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8293, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8293, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_7) < 0) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8294: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "ofind") < 0)) __PYX_ERR(0, 8290, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("ofind", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8290, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.ofind", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_138ofind(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8294, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8294, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8294, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_1) < 0) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8295: ) -> Optional[Address]:
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8295, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8295, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8295, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_7) < 0) __PYX_ERR(0, 8290, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
8296: r"""Index of an item.
8297:
8298: Arguments:
8299: item (items):
8300: Value to find. Can be either some byte string or an integer.
8301:
8302: start (int):
8303: Inclusive start of the searched range.
8304: If ``None``, :attr:`start` is considered.
8305:
8306: endex (int):
8307: Exclusive end of the searched range.
8308: If ``None``, :attr:`endex` is considered.
8309:
8310: Returns:
8311: int: The index of the first item equal to `value`, or ``None``.
8312: """
8313:
+8314: return Memory_ObjFind(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_ObjFind(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8314, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8315:
+8316: def peek(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_141peek(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_140peek[] = "Memory.peek(self: Memory, address: Address) -> Optional[Value]\nGets the item at an address.\n\n Returns:\n int: The item at `address`, ``None`` if empty.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> memory.peek(3) # -> ord('C') = 67\n 67\n >>> memory.peek(6) # -> ord('$') = 36\n 36\n >>> memory.peek(10) # -> ord('z') = 122\n 122\n >>> memory.peek(0)\n None\n >>> memory.peek(7)\n None\n >>> memory.peek(11)\n None\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_141peek = {"peek", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_141peek, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_140peek}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_141peek(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("peek (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_140peek(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_140peek(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("peek", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.peek", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__168 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_address); if (unlikely(!__pyx_tuple__168)) __PYX_ERR(0, 8316, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__168); __Pyx_GIVEREF(__pyx_tuple__168); /* … */ __pyx_t_7 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8316, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8316, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_141peek, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_peek, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__169)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8316, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_7); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_peek, __pyx_t_1) < 0) __PYX_ERR(0, 8316, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__169 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__168, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_peek, 8316, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__169)) __PYX_ERR(0, 8316, __pyx_L1_error)
8317: self: Memory,
+8318: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8318, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_address, __pyx_t_2) < 0) __PYX_ERR(0, 8316, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+8319: ) -> Optional[Value]:
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8319, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8319, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8319, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_return, __pyx_t_1) < 0) __PYX_ERR(0, 8316, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
8320: r"""Gets the item at an address.
8321:
8322: Returns:
8323: int: The item at `address`, ``None`` if empty.
8324:
8325: Examples:
8326: +---+---+---+---+---+---+---+---+---+---+---+---+
8327: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
8328: +===+===+===+===+===+===+===+===+===+===+===+===+
8329: | |[A | B | C | D]| |[$]| |[x | y | z]| |
8330: +---+---+---+---+---+---+---+---+---+---+---+---+
8331:
8332: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
8333: >>> memory.peek(3) # -> ord('C') = 67
8334: 67
8335: >>> memory.peek(6) # -> ord('$') = 36
8336: 36
8337: >>> memory.peek(10) # -> ord('z') = 122
8338: 122
8339: >>> memory.peek(0)
8340: None
8341: >>> memory.peek(7)
8342: None
8343: >>> memory.peek(11)
8344: None
8345: """
8346:
+8347: return Memory_Peek(self._, address)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Peek(__pyx_v_self->_, __pyx_v_address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8347, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8348:
+8349: def poke(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_143poke(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_142poke[] = "Memory.poke(self: Memory, address: Address, item: Optional[Union[AnyBytes, Value]]) -> None\nSets the item at an address.\n\n Arguments:\n address (int):\n Address of the target item.\n\n item (int or byte):\n Item to set, ``None`` to clear the cell.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> memory.poke(3, b'@')\n >>> memory.peek(3) # -> ord('@') = 64\n 64\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> memory.poke(5, b'@')\n >>> memory.peek(5) # -> ord('@') = 64\n 64\n\n See Also:\n :meth:`poke_backup`\n :meth:`poke_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_143poke = {"poke", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_143poke, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_142poke}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_143poke(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_item = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("poke (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_item,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("poke", 1, 2, 2, 1); __PYX_ERR(0, 8349, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "poke") < 0)) __PYX_ERR(0, 8349, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_item = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("poke", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8349, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.poke", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_142poke(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_item); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_142poke(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_item) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("poke", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.poke", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__170 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_item); if (unlikely(!__pyx_tuple__170)) __PYX_ERR(0, 8349, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__170); __Pyx_GIVEREF(__pyx_tuple__170); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8349, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8349, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_143poke, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_poke, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__171)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8349, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_poke, __pyx_t_5) < 0) __PYX_ERR(0, 8349, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__171 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__170, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_poke, 8349, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__171)) __PYX_ERR(0, 8349, __pyx_L1_error)
8350: self: Memory,
+8351: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8351, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_address, __pyx_t_7) < 0) __PYX_ERR(0, 8349, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8352: item: Optional[Union[AnyBytes, Value]],
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_9); __pyx_t_2 = 0; __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_5); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_item, __pyx_t_5) < 0) __PYX_ERR(0, 8349, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8353: ) -> None:
if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8349, __pyx_L1_error)
8354: r"""Sets the item at an address.
8355:
8356: Arguments:
8357: address (int):
8358: Address of the target item.
8359:
8360: item (int or byte):
8361: Item to set, ``None`` to clear the cell.
8362:
8363: Examples:
8364: +---+---+---+---+---+---+---+---+---+---+---+---+
8365: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
8366: +===+===+===+===+===+===+===+===+===+===+===+===+
8367: | |[A | B | C | D]| |[$]| |[x | y | z]| |
8368: +---+---+---+---+---+---+---+---+---+---+---+---+
8369:
8370: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
8371: >>> memory.poke(3, b'@')
8372: >>> memory.peek(3) # -> ord('@') = 64
8373: 64
8374: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
8375: >>> memory.poke(5, b'@')
8376: >>> memory.peek(5) # -> ord('@') = 64
8377: 64
8378:
8379: See Also:
8380: :meth:`poke_backup`
8381: :meth:`poke_restore`
8382: """
8383:
+8384: Memory_Poke(self._, address, item)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Poke(__pyx_v_self->_, __pyx_v_address, __pyx_v_item); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8384, __pyx_L1_error)
8385:
+8386: def poke_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_145poke_backup(PyObject *__pyx_v_self, PyObject *__pyx_v_address); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_144poke_backup[] = "Memory.poke_backup(self: Memory, address: Address) -> Tuple[Address, Optional[Value]]\nBackups a `poke()` operation.\n\n Arguments:\n address (int):\n Address of the target item.\n\n Returns:\n (int, int): `address`, item at `address` (``None`` if empty).\n\n See Also:\n :meth:`poke`\n :meth:`poke_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_145poke_backup = {"poke_backup", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_145poke_backup, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_144poke_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_145poke_backup(PyObject *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("poke_backup (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_144poke_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_address)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_144poke_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("poke_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.poke_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__172 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_address); if (unlikely(!__pyx_tuple__172)) __PYX_ERR(0, 8386, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__172); __Pyx_GIVEREF(__pyx_tuple__172); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8386, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8386, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_145poke_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_poke_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__173)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8386, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_poke_backup, __pyx_t_2) < 0) __PYX_ERR(0, 8386, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__173 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__172, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_poke_backup, 8386, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__173)) __PYX_ERR(0, 8386, __pyx_L1_error)
8387: self: Memory,
+8388: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8388, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_address, __pyx_t_1) < 0) __PYX_ERR(0, 8386, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8389: ) -> Tuple[Address, Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_9); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_2); __pyx_t_9 = 0; __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8389, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_2) < 0) __PYX_ERR(0, 8386, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
8390: r"""Backups a `poke()` operation.
8391:
8392: Arguments:
8393: address (int):
8394: Address of the target item.
8395:
8396: Returns:
8397: (int, int): `address`, item at `address` (``None`` if empty).
8398:
8399: See Also:
8400: :meth:`poke`
8401: :meth:`poke_restore`
8402: """
8403:
+8404: return address, Memory_Peek(self._, address)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Peek(__pyx_v_self->_, __pyx_v_address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8404, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8404, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_v_address); __Pyx_GIVEREF(__pyx_v_address); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v_address); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0;
8405:
+8406: def poke_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_147poke_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_146poke_restore[] = "Memory.poke_restore(self: Memory, address: Address, item: Optional[Value]) -> None\nRestores a `poke()` operation.\n\n Arguments:\n address (int):\n Address of the target item.\n\n item (int or byte):\n Item to restore.\n\n See Also:\n :meth:`poke`\n :meth:`poke_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_147poke_restore = {"poke_restore", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_147poke_restore, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_146poke_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_147poke_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_item = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("poke_restore (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_item,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("poke_restore", 1, 2, 2, 1); __PYX_ERR(0, 8406, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "poke_restore") < 0)) __PYX_ERR(0, 8406, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_item = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("poke_restore", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8406, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.poke_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_146poke_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_item); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_146poke_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_item) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("poke_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.poke_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__174 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_item); if (unlikely(!__pyx_tuple__174)) __PYX_ERR(0, 8406, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__174); __Pyx_GIVEREF(__pyx_tuple__174); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8406, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8406, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_147poke_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_poke_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__175)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8406, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_poke_restore, __pyx_t_1) < 0) __PYX_ERR(0, 8406, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__175 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__174, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_poke_restore, 8406, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__175)) __PYX_ERR(0, 8406, __pyx_L1_error)
8407: self: Memory,
+8408: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8408, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_address, __pyx_t_5) < 0) __PYX_ERR(0, 8406, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8409: item: Optional[Value],
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8409, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8409, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8409, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_item, __pyx_t_1) < 0) __PYX_ERR(0, 8406, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8410: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8406, __pyx_L1_error)
8411: r"""Restores a `poke()` operation.
8412:
8413: Arguments:
8414: address (int):
8415: Address of the target item.
8416:
8417: item (int or byte):
8418: Item to restore.
8419:
8420: See Also:
8421: :meth:`poke`
8422: :meth:`poke_backup`
8423: """
8424:
+8425: if item is None:
__pyx_t_1 = (__pyx_v_item == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+8426: Memory_PokeNone_(self._, <addr_t>address)
__pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8426, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_PokeNone_(__pyx_v_self->_, ((addr_t)__pyx_t_3)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8426, __pyx_L1_error)
8427: else:
+8428: Memory_Poke_(self._, <addr_t>address, <byte_t>item)
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8428, __pyx_L1_error) __pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8428, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Poke_(__pyx_v_self->_, ((addr_t)__pyx_t_3), ((byte_t)__pyx_t_5)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8428, __pyx_L1_error) } __pyx_L3:;
8429:
+8430: def pop(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_149pop(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_148pop[] = "Memory.pop(self: Memory, address: Optional[Address] = None) -> Optional[Value]\nTakes a value away.\n\n Arguments:\n address (int):\n Address of the byte to pop.\n If ``None``, the very last byte is popped.\n\n Return:\n int: Value at `address`; ``None`` within emptiness.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C | D]| |[$]| |[x | y]| | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | D]| |[$]| |[x | y]| | | |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> memory.pop() # -> ord('z') = 122\n 122\n >>> memory.pop(3) # -> ord('C') = 67\n 67\n\n See Also:\n :meth:`pop_backup`\n :meth:`pop_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_149pop = {"pop", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_149pop, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_148pop}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_149pop(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,0}; PyObject* values[1] = {0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_148pop(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__176 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_address); if (unlikely(!__pyx_tuple__176)) __PYX_ERR(0, 8430, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__176); __Pyx_GIVEREF(__pyx_tuple__176); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8430, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8430, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_149pop, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_pop, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__177)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8430, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pop, __pyx_t_2) < 0) __PYX_ERR(0, 8430, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__177 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__176, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pop, 8430, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__177)) __PYX_ERR(0, 8430, __pyx_L1_error)
8431: self: Memory,
+8432: address: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address); if (value) { values[0] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "pop") < 0)) __PYX_ERR(0, 8430, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_address = values[0]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("pop", 0, 0, 1, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8430, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_148pop(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8432, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8432, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8432, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_address, __pyx_t_5) < 0) __PYX_ERR(0, 8430, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8433: ) -> Optional[Value]:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8433, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8433, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8433, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_t_2) < 0) __PYX_ERR(0, 8430, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
8434: r"""Takes a value away.
8435:
8436: Arguments:
8437: address (int):
8438: Address of the byte to pop.
8439: If ``None``, the very last byte is popped.
8440:
8441: Return:
8442: int: Value at `address`; ``None`` within emptiness.
8443:
8444: Example:
8445: +---+---+---+---+---+---+---+---+---+---+---+---+
8446: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
8447: +===+===+===+===+===+===+===+===+===+===+===+===+
8448: | |[A | B | C | D]| |[$]| |[x | y | z]| |
8449: +---+---+---+---+---+---+---+---+---+---+---+---+
8450: | |[A | B | C | D]| |[$]| |[x | y]| | |
8451: +---+---+---+---+---+---+---+---+---+---+---+---+
8452: | |[A | B | D]| |[$]| |[x | y]| | | |
8453: +---+---+---+---+---+---+---+---+---+---+---+---+
8454:
8455: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
8456: >>> memory.pop() # -> ord('z') = 122
8457: 122
8458: >>> memory.pop(3) # -> ord('C') = 67
8459: 67
8460:
8461: See Also:
8462: :meth:`pop_backup`
8463: :meth:`pop_restore`
8464: """
8465:
+8466: return Memory_Pop(self._, address)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Pop(__pyx_v_self->_, __pyx_v_address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8466, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8467:
+8468: def pop_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_151pop_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_150pop_backup[] = "Memory.pop_backup(self: Memory, address: Optional[Address] = None) -> Tuple[Address, Optional[Value]]\nBackups a `pop()` operation.\n\n Arguments:\n address (int):\n Address of the byte to pop.\n If ``None``, the very last byte is popped.\n\n Returns:\n (int, int): `address`, item at `address` (``None`` if empty).\n\n See Also:\n :meth:`pop`\n :meth:`pop_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_151pop_backup = {"pop_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_151pop_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_150pop_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_151pop_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,0}; PyObject* values[1] = {0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_150pop_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop_backup", 0); __Pyx_INCREF(__pyx_v_address); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("cbytesparse.c.Memory.pop_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_address); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__178 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_address); if (unlikely(!__pyx_tuple__178)) __PYX_ERR(0, 8468, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__178); __Pyx_GIVEREF(__pyx_tuple__178); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8468, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8468, __pyx_L1_error) /* … */ __pyx_t_7 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_151pop_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_pop_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__179)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8468, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_7, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pop_backup, __pyx_t_7) < 0) __PYX_ERR(0, 8468, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__179 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__178, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pop_backup, 8468, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__179)) __PYX_ERR(0, 8468, __pyx_L1_error)
8469: self: Memory,
+8470: address: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address); if (value) { values[0] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "pop_backup") < 0)) __PYX_ERR(0, 8468, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_address = values[0]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("pop_backup", 0, 0, 1, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8468, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.pop_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_150pop_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8470, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8470, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8470, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_address, __pyx_t_5) < 0) __PYX_ERR(0, 8468, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8471: ) -> Tuple[Address, Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_9); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_7); __pyx_t_6 = 0; __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_9); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_7) < 0) __PYX_ERR(0, 8468, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
8472: r"""Backups a `pop()` operation.
8473:
8474: Arguments:
8475: address (int):
8476: Address of the byte to pop.
8477: If ``None``, the very last byte is popped.
8478:
8479: Returns:
8480: (int, int): `address`, item at `address` (``None`` if empty).
8481:
8482: See Also:
8483: :meth:`pop`
8484: :meth:`pop_restore`
8485: """
8486:
+8487: if address is None:
__pyx_t_1 = (__pyx_v_address == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ }
+8488: address = self.endex - 1
__pyx_t_3 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_endex); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8488, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyInt_SubtractObjC(__pyx_t_3, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8488, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF_SET(__pyx_v_address, __pyx_t_4); __pyx_t_4 = 0;
+8489: return address, Memory_Peek(self._, address)
__Pyx_XDECREF(__pyx_r); __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Peek(__pyx_v_self->_, __pyx_v_address); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8489, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8489, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_INCREF(__pyx_v_address); __Pyx_GIVEREF(__pyx_v_address); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_address); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_4); __pyx_t_4 = 0; __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0;
8490:
+8491: def pop_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_153pop_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_152pop_restore[] = "Memory.pop_restore(self: Memory, address: Address, item: Optional[Value]) -> None\nRestores a `pop()` operation.\n\n Arguments:\n address (int):\n Address of the target item.\n\n item (int or byte):\n Item to restore, ``None`` if empty.\n\n See Also:\n :meth:`pop`\n :meth:`pop_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_153pop_restore = {"pop_restore", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_153pop_restore, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_152pop_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_153pop_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_item = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop_restore (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_item,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("pop_restore", 1, 2, 2, 1); __PYX_ERR(0, 8491, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "pop_restore") < 0)) __PYX_ERR(0, 8491, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_item = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("pop_restore", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8491, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.pop_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_152pop_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_item); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_152pop_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_item) { byte_t __pyx_v_value; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.pop_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__180 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_item, __pyx_n_s_value); if (unlikely(!__pyx_tuple__180)) __PYX_ERR(0, 8491, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__180); __Pyx_GIVEREF(__pyx_tuple__180); /* … */ __pyx_t_7 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8491, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8491, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_153pop_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_pop_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__181)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8491, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_7); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_pop_restore, __pyx_t_5) < 0) __PYX_ERR(0, 8491, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__181 = (PyObject*)__Pyx_PyCode_New(3, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__180, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_pop_restore, 8491, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__181)) __PYX_ERR(0, 8491, __pyx_L1_error)
8492: self: Memory,
+8493: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8493, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_address, __pyx_t_2) < 0) __PYX_ERR(0, 8491, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+8494: item: Optional[Value],
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8494, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8494, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8494, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_item, __pyx_t_5) < 0) __PYX_ERR(0, 8491, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8495: ) -> None:
if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8491, __pyx_L1_error)
8496: r"""Restores a `pop()` operation.
8497:
8498: Arguments:
8499: address (int):
8500: Address of the target item.
8501:
8502: item (int or byte):
8503: Item to restore, ``None`` if empty.
8504:
8505: See Also:
8506: :meth:`pop`
8507: :meth:`pop_backup`
8508: """
8509: cdef:
8510: byte_t value
8511:
+8512: if item is None:
__pyx_t_1 = (__pyx_v_item == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+8513: Memory_Reserve_(self._, <addr_t>address, 1)
__pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8513, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_Reserve_(__pyx_v_self->_, ((addr_t)__pyx_t_3), 1); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8513, __pyx_L1_error)
8514: else:
+8515: value = <byte_t>item
/*else*/ { __pyx_t_5 = __Pyx_PyInt_As_byte_t(__pyx_v_item); if (unlikely((__pyx_t_5 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8515, __pyx_L1_error) __pyx_v_value = ((byte_t)__pyx_t_5);
+8516: Memory_InsertRaw_(self._, address, 1, &value)
__pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8516, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_Memory_InsertRaw_(__pyx_v_self->_, __pyx_t_3, 1, (&__pyx_v_value)); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8516, __pyx_L1_error) } __pyx_L3:;
8517:
+8518: def reserve(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_155reserve(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_154reserve[] = "Memory.reserve(self: Memory, address: Address, size: Address) -> None\nInserts emptiness.\n\n Reserves emptiness at the provided address.\n\n Arguments:\n address (int):\n Start address of the emptiness to insert.\n\n size (int):\n Size of the emptiness to insert.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+\n | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| |[x | y | z]| | | |\n +---+---+---+---+---+---+---+---+---+---+---+\n | |[A]| | | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[3, b'ABC'], [7, b'xyz']])\n >>> memory.reserve(4, 2)\n >>> memory._blocks\n [[3, b'A'], [6, b'BC'], [9, b'xyz']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+---+\n | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+===+===+\n | | | |[A | B | C]| |[x | y | z]|)))|\n +---+---+---+---+---+---+---+---+---+---+---+\n | | | | | | | | |[A | B]|)))|\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']], endex=12)\n >>> memory.reserve(5, 5)\n >>> memory._blocks\n [[10, b'AB']]\n\n See Also:\n :meth:`reserve_backup`\n :meth:`reserve_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_155reserve = {"reserve", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_155reserve, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_154reserve}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_155reserve(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_size = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("reserve (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_size,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("reserve", 1, 2, 2, 1); __PYX_ERR(0, 8518, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "reserve") < 0)) __PYX_ERR(0, 8518, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_size = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("reserve", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8518, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.reserve", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_154reserve(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_size); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_154reserve(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_size) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("reserve", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.reserve", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__182 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_size); if (unlikely(!__pyx_tuple__182)) __PYX_ERR(0, 8518, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__182); __Pyx_GIVEREF(__pyx_tuple__182); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8518, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8518, __pyx_L1_error) /* … */ __pyx_t_7 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_155reserve, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_reserve, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__183)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8518, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_7, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_reserve, __pyx_t_7) < 0) __PYX_ERR(0, 8518, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__183 = (PyObject*)__Pyx_PyCode_New(3, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__182, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_reserve, 8518, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__183)) __PYX_ERR(0, 8518, __pyx_L1_error)
8519: self: Memory,
+8520: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8520, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_address, __pyx_t_7) < 0) __PYX_ERR(0, 8518, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8521: size: Address,
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8521, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_size, __pyx_t_7) < 0) __PYX_ERR(0, 8518, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8522: ) -> None:
if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8518, __pyx_L1_error)
8523: r"""Inserts emptiness.
8524:
8525: Reserves emptiness at the provided address.
8526:
8527: Arguments:
8528: address (int):
8529: Start address of the emptiness to insert.
8530:
8531: size (int):
8532: Size of the emptiness to insert.
8533:
8534: Examples:
8535: +---+---+---+---+---+---+---+---+---+---+---+
8536: | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
8537: +===+===+===+===+===+===+===+===+===+===+===+
8538: | |[A | B | C]| |[x | y | z]| | | |
8539: +---+---+---+---+---+---+---+---+---+---+---+
8540: | |[A]| | | B | C]| |[x | y | z]| |
8541: +---+---+---+---+---+---+---+---+---+---+---+
8542:
8543: >>> memory = Memory.from_blocks([[3, b'ABC'], [7, b'xyz']])
8544: >>> memory.reserve(4, 2)
8545: >>> memory._blocks
8546: [[3, b'A'], [6, b'BC'], [9, b'xyz']]
8547:
8548: ~~~
8549:
8550: +---+---+---+---+---+---+---+---+---+---+---+
8551: | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
8552: +===+===+===+===+===+===+===+===+===+===+===+
8553: | | | |[A | B | C]| |[x | y | z]|)))|
8554: +---+---+---+---+---+---+---+---+---+---+---+
8555: | | | | | | | | |[A | B]|)))|
8556: +---+---+---+---+---+---+---+---+---+---+---+
8557:
8558: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']], endex=12)
8559: >>> memory.reserve(5, 5)
8560: >>> memory._blocks
8561: [[10, b'AB']]
8562:
8563: See Also:
8564: :meth:`reserve_backup`
8565: :meth:`reserve_restore`
8566: """
8567:
+8568: Memory_Reserve(self._, address, size)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Reserve(__pyx_v_self->_, __pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8568, __pyx_L1_error)
8569:
+8570: def reserve_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_157reserve_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_156reserve_backup[] = "Memory.reserve_backup(self: Memory, address: Address, size: Address) -> Tuple[Address, Memory]\nBackups a `reserve()` operation.\n\n Arguments:\n address (int):\n Start address of the emptiness to insert.\n\n size (int):\n Size of the emptiness to insert.\n\n Returns:\n (int, :obj:`Memory`): Reservation address, backup memory region.\n\n See Also:\n :meth:`reserve`\n :meth:`reserve_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_157reserve_backup = {"reserve_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_157reserve_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_156reserve_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_157reserve_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_size = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("reserve_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_size,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("reserve_backup", 1, 2, 2, 1); __PYX_ERR(0, 8570, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "reserve_backup") < 0)) __PYX_ERR(0, 8570, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_size = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("reserve_backup", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8570, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.reserve_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_156reserve_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_size); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_156reserve_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_size) { PyObject *__pyx_v_backup = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("reserve_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.reserve_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_backup); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__184 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_size, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__184)) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__184); __Pyx_GIVEREF(__pyx_tuple__184); /* … */ __pyx_t_7 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8570, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_157reserve_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_reserve_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__185)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_7); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_reserve_backup, __pyx_t_9) < 0) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__185 = (PyObject*)__Pyx_PyCode_New(3, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__184, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_reserve_backup, 8570, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__185)) __PYX_ERR(0, 8570, __pyx_L1_error)
8571: self: Memory,
+8572: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8572, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_address, __pyx_t_5) < 0) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8573: size: Address,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8573, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_size, __pyx_t_5) < 0) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8574: ) -> Tuple[Address, Memory]:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8574, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8574, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8574, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_9); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8574, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_return, __pyx_t_9) < 0) __PYX_ERR(0, 8570, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
8575: r"""Backups a `reserve()` operation.
8576:
8577: Arguments:
8578: address (int):
8579: Start address of the emptiness to insert.
8580:
8581: size (int):
8582: Size of the emptiness to insert.
8583:
8584: Returns:
8585: (int, :obj:`Memory`): Reservation address, backup memory region.
8586:
8587: See Also:
8588: :meth:`reserve`
8589: :meth:`reserve_restore`
8590: """
8591:
+8592: backup = self._pretrim_endex_backup(address, size)
__pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_pretrim_endex_backup); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8592, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = NULL; __pyx_t_4 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2); if (likely(__pyx_t_3)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_2, function); __pyx_t_4 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_2)) { PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_address, __pyx_v_size}; __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_4, 2+__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8592, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_1); } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) { PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_address, __pyx_v_size}; __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_4, 2+__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8592, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_GOTREF(__pyx_t_1); } else #endif { __pyx_t_5 = PyTuple_New(2+__pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8592, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__pyx_t_3) { __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3); __pyx_t_3 = NULL; } __Pyx_INCREF(__pyx_v_address); __Pyx_GIVEREF(__pyx_v_address); PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_4, __pyx_v_address); __Pyx_INCREF(__pyx_v_size); __Pyx_GIVEREF(__pyx_v_size); PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_4, __pyx_v_size); __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8592, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_backup = __pyx_t_1; __pyx_t_1 = 0;
+8593: return address, backup
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8593, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_v_address); __Pyx_GIVEREF(__pyx_v_address); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_address); __Pyx_INCREF(__pyx_v_backup); __Pyx_GIVEREF(__pyx_v_backup); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_backup); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8594:
+8595: def reserve_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_159reserve_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_158reserve_restore[] = "Memory.reserve_restore(self: Memory, addr_t address: Address, Memory backup: Memory) -> None\nRestores a `reserve()` operation.\n\n Arguments:\n address (int):\n Address of the reservation point.\n\n backup (:obj:`Memory`):\n Backup memory region to restore.\n\n See Also:\n :meth:`reserve`\n :meth:`reserve_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_159reserve_restore = {"reserve_restore", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_159reserve_restore, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_158reserve_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_159reserve_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { addr_t __pyx_v_address; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("reserve_restore (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_backup,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_backup)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("reserve_restore", 1, 2, 2, 1); __PYX_ERR(0, 8595, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "reserve_restore") < 0)) __PYX_ERR(0, 8595, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = __Pyx_PyInt_As_uint_fast64_t(values[0]); if (unlikely((__pyx_v_address == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8597, __pyx_L3_error) __pyx_v_backup = ((struct __pyx_obj_11cbytesparse_1c_Memory *)values[1]); } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("reserve_restore", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8595, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.reserve_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 8598, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_158reserve_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_backup); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_158reserve_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, addr_t __pyx_v_address, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { addr_t __pyx_v_size; Memory_ *__pyx_v_memory; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("reserve_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.reserve_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__186 = PyTuple_Pack(5, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_backup, __pyx_n_s_size, __pyx_n_s_memory); if (unlikely(!__pyx_tuple__186)) __PYX_ERR(0, 8595, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__186); __Pyx_GIVEREF(__pyx_tuple__186); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8595, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8595, __pyx_L1_error) /* … */ __pyx_t_7 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_159reserve_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_reserve_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__187)); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8595, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_7, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_reserve_restore, __pyx_t_7) < 0) __PYX_ERR(0, 8595, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__187 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__186, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_reserve_restore, 8595, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__187)) __PYX_ERR(0, 8595, __pyx_L1_error)
8596: self: Memory,
+8597: addr_t address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8597, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_address, __pyx_t_7) < 0) __PYX_ERR(0, 8595, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8595, __pyx_L1_error)
8598: Memory backup not None: Memory,
+8599: ) -> None:
if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8595, __pyx_L1_error)
8600: r"""Restores a `reserve()` operation.
8601:
8602: Arguments:
8603: address (int):
8604: Address of the reservation point.
8605:
8606: backup (:obj:`Memory`):
8607: Backup memory region to restore.
8608:
8609: See Also:
8610: :meth:`reserve`
8611: :meth:`reserve_backup`
8612: """
8613: cdef:
+8614: addr_t size = Memory_Length(backup._)
__pyx_v_size = __pyx_f_11cbytesparse_1c_Memory_Length(__pyx_v_backup->_);
+8615: Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
8616:
+8617: CheckAddAddrU(address, size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_v_address, __pyx_v_size); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8617, __pyx_L1_error)
+8618: Memory_Delete_(memory, address, address + size)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Delete_(__pyx_v_memory, __pyx_v_address, (__pyx_v_address + __pyx_v_size)); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8618, __pyx_L1_error)
+8619: Memory_WriteSame_(memory, 0, backup._, True)
__pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_WriteSame_(__pyx_v_memory, 0, __pyx_v_backup->_, 1); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8619, __pyx_L1_error)
8620:
+8621: def rfind(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_161rfind(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_160rfind[] = "Memory.rfind(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> Address\nIndex of an item, reversed search.\n\n Arguments:\n item (items):\n Value to find. Can be either some byte string or an integer.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The index of the last item equal to `value`, or -1.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_161rfind = {"rfind", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_161rfind, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_160rfind}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_161rfind(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rfind (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_160rfind(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rfind", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.rfind", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__188 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__188)) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__188); __Pyx_GIVEREF(__pyx_tuple__188); /* … */ __pyx_t_7 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8621, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_161rfind, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_rfind, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__189)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_7); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_rfind, __pyx_t_5) < 0) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__189 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__188, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_rfind, 8621, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__189)) __PYX_ERR(0, 8621, __pyx_L1_error)
8622: self: Memory,
+8623: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Union); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8623, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8623, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Value); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8623, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8623, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_5); __pyx_t_2 = 0; __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8623, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_item, __pyx_t_5) < 0) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8624: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8624, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8624, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8624, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_start, __pyx_t_9) < 0) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+8625: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rfind") < 0)) __PYX_ERR(0, 8621, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("rfind", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8621, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.rfind", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_160rfind(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8625, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8625, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8625, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_endex, __pyx_t_5) < 0) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8626: ) -> Address:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8626, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_return, __pyx_t_5) < 0) __PYX_ERR(0, 8621, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
8627: r"""Index of an item, reversed search.
8628:
8629: Arguments:
8630: item (items):
8631: Value to find. Can be either some byte string or an integer.
8632:
8633: start (int):
8634: Inclusive start of the searched range.
8635: If ``None``, :attr:`start` is considered.
8636:
8637: endex (int):
8638: Exclusive end of the searched range.
8639: If ``None``, :attr:`endex` is considered.
8640:
8641: Returns:
8642: int: The index of the last item equal to `value`, or -1.
8643: """
8644:
+8645: return Memory_RevFind(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_RevFind(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8645, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8646:
+8647: def rindex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_163rindex(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_162rindex[] = "Memory.rindex(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> Address\nIndex of an item, reversed search.\n\n Arguments:\n item (items):\n Value to find. Can be either some byte string or an integer.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The index of the last item equal to `value`.\n\n Raises:\n :obj:`ValueError`: Item not found.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_163rindex = {"rindex", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_163rindex, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_162rindex}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_163rindex(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rindex (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_162rindex(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rindex", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.rindex", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__190 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__190)) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__190); __Pyx_GIVEREF(__pyx_tuple__190); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8647, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_163rindex, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_rindex, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__191)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_rindex, __pyx_t_9) < 0) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__191 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__190, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_rindex, 8647, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__191)) __PYX_ERR(0, 8647, __pyx_L1_error)
8648: self: Memory,
+8649: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Union); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8649, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8649, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8649, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8649, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_9); __pyx_t_6 = 0; __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8649, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_item, __pyx_t_9) < 0) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+8650: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8650, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8650, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8650, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_start, __pyx_t_7) < 0) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8651: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rindex") < 0)) __PYX_ERR(0, 8647, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("rindex", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8647, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.rindex", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_162rindex(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8651, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8651, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8651, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+8652: ) -> Address:
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8652, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_9) < 0) __PYX_ERR(0, 8647, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
8653: r"""Index of an item, reversed search.
8654:
8655: Arguments:
8656: item (items):
8657: Value to find. Can be either some byte string or an integer.
8658:
8659: start (int):
8660: Inclusive start of the searched range.
8661: If ``None``, :attr:`start` is considered.
8662:
8663: endex (int):
8664: Exclusive end of the searched range.
8665: If ``None``, :attr:`endex` is considered.
8666:
8667: Returns:
8668: int: The index of the last item equal to `value`.
8669:
8670: Raises:
8671: :obj:`ValueError`: Item not found.
8672: """
8673:
+8674: return Memory_RevIndex(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_RevIndex(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8674, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8675:
+8676: def rofind(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_165rofind(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_164rofind[] = "Memory.rofind(self: Memory, item: Union[AnyBytes, Value], start: Optional[Address] = None, endex: Optional[Address] = None) -> Optional[Address]\nIndex of an item, reversed search.\n\n Arguments:\n item (items):\n Value to find. Can be either some byte string or an integer.\n\n start (int):\n Inclusive start of the searched range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the searched range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n int: The index of the last item equal to `value`, or ``None``.\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_165rofind = {"rofind", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_165rofind, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_164rofind}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_165rofind(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_item = 0; PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rofind (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_item,&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_164rofind(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_item, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rofind", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.rofind", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_168generator6(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */ /* … */ __pyx_tuple__192 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_item, __pyx_n_s_start, __pyx_n_s_endex); if (unlikely(!__pyx_tuple__192)) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__192); __Pyx_GIVEREF(__pyx_tuple__192); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8676, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_165rofind, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_rofind, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__193)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_rofind, __pyx_t_5) < 0) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__193 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__192, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_rofind, 8676, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__193)) __PYX_ERR(0, 8676, __pyx_L1_error)
8677: self: Memory,
+8678: item: Union[AnyBytes, Value],
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Union); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8678, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8678, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Value); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8678, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8678, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_7); __pyx_t_2 = 0; __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8678, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_item, __pyx_t_7) < 0) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8679: start: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8679, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8679, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8679, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8680: endex: Optional[Address] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_item)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rofind") < 0)) __PYX_ERR(0, 8676, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_item = values[0]; __pyx_v_start = values[1]; __pyx_v_endex = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("rofind", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8676, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.rofind", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_164rofind(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_item, __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8680, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8680, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8680, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_endex, __pyx_t_7) < 0) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8681: ) -> Optional[Address]:
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8681, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8681, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8681, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, __pyx_t_5) < 0) __PYX_ERR(0, 8676, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
8682: r"""Index of an item, reversed search.
8683:
8684: Arguments:
8685: item (items):
8686: Value to find. Can be either some byte string or an integer.
8687:
8688: start (int):
8689: Inclusive start of the searched range.
8690: If ``None``, :attr:`start` is considered.
8691:
8692: endex (int):
8693: Exclusive end of the searched range.
8694: If ``None``, :attr:`endex` is considered.
8695:
8696: Returns:
8697: int: The index of the last item equal to `value`, or ``None``.
8698: """
8699:
+8700: return Memory_RevObjFind(self._, item, start, endex)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_RevObjFind(__pyx_v_self->_, __pyx_v_item, __pyx_v_start, __pyx_v_endex); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8700, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8701:
+8702: def rvalues(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_167rvalues(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_166rvalues[] = "Memory.rvalues(self: Memory, start: Optional[Union[Address, EllipsisType]] = None, endex: Optional[Address] = None, pattern: Optional[Union[AnyBytes, Value]] = None) -> Iterator[Optional[Value]]\nIterates over values, reversed order.\n\n Iterates over values, from `endex` to `start`.\n\n Arguments:\n start (int):\n Inclusive start address.\n If ``None``, :attr:`start` is considered.\n If ``Ellipsis``, the iterator is infinite.\n\n endex (int):\n Exclusive end address.\n If ``None``, :attr:`endex` is considered.\n\n pattern (items):\n Pattern of values to fill emptiness.\n\n Yields:\n int: Range values.\n\n Examples:\n >>> from itertools import islice\n >>> memory = Memory()\n >>> list(memory.values(endex=8))\n [None, None, None, None, None, None, None, None]\n >>> list(memory.values(3, 8))\n [None, None, None, None, None]\n >>> list(islice(memory.values(3, ...), 7))\n [None, None, None, None, None, None, None]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | | 65| 66| 67| | |120|121|122| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> list(memory.values())\n [65, 66, 67, None, None, 120, 121, 122]\n >>> list(memory.values(3, 8))\n [67, None, None, 120, 121]\n >>> list(islice(memory.values(3, ...), 7))\n [67, None, None, 120, 121, 122, None]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_167rvalues = {"rvalues", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_167rvalues, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_166rvalues}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_167rvalues(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_pattern = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rvalues (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_pattern,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_166rvalues(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_6_rvalues *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rvalues", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_6_rvalues *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_6_rvalues(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_6_rvalues, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_6_rvalues *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 8702, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __pyx_cur_scope->__pyx_v_start = __pyx_v_start; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_endex = __pyx_v_endex; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); __pyx_cur_scope->__pyx_v_pattern = __pyx_v_pattern; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_pattern); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_pattern); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_168generator6, __pyx_codeobj__35, (PyObject *) __pyx_cur_scope, __pyx_n_s_rvalues, __pyx_n_s_Memory_rvalues, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.rvalues", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_168generator6(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("rvalues", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8702, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_XDECREF(__pyx_t_13); __Pyx_AddTraceback("rvalues", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__194 = PyTuple_Pack(11, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_pattern, __pyx_n_s_start_2, __pyx_n_s_endex_2, __pyx_n_s_rover, __pyx_n_s_pattern_value, __pyx_n_s_pattern_view, __pyx_n_s_pattern_size, __pyx_n_s_pattern_data); if (unlikely(!__pyx_tuple__194)) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__194); __Pyx_GIVEREF(__pyx_tuple__194); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8702, __pyx_L1_error) /* … */ __pyx_t_9 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_167rvalues, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_rvalues, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__35)); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_9, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_rvalues, __pyx_t_9) < 0) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__35 = (PyObject*)__Pyx_PyCode_New(4, 0, 11, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__194, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_rvalues, 8702, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__35)) __PYX_ERR(0, 8702, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_6_rvalues { PyObject_HEAD PyObject *__pyx_v_endex; addr_t __pyx_v_endex_; PyObject *__pyx_v_pattern; byte_t const *__pyx_v_pattern_data; size_t __pyx_v_pattern_size; byte_t __pyx_v_pattern_value; __Pyx_memviewslice __pyx_v_pattern_view; Rover_ *__pyx_v_rover; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; PyObject *__pyx_v_start; addr_t __pyx_v_start_; PyObject *__pyx_t_0; PyObject *__pyx_t_1; PyObject *__pyx_t_2; };
8703: self: Memory,
+8704: start: Optional[Union[Address, EllipsisType]] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_EllipsisType); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_2); __pyx_t_7 = 0; __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8704, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_start, __pyx_t_1) < 0) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+8705: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8705, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8705, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8705, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_endex, __pyx_t_9) < 0) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+8706: pattern: Optional[Union[AnyBytes, Value]] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pattern); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rvalues") < 0)) __PYX_ERR(0, 8702, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_pattern = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("rvalues", 0, 0, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8702, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.rvalues", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_166rvalues(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Union); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Value); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_6); __pyx_t_1 = 0; __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_7); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_pattern, __pyx_t_7) < 0) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
+8707: ) -> Iterator[Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8707, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Optional); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 8707, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Value); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8707, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8707, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8707, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_9) < 0) __PYX_ERR(0, 8702, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
8708: r"""Iterates over values, reversed order.
8709:
8710: Iterates over values, from `endex` to `start`.
8711:
8712: Arguments:
8713: start (int):
8714: Inclusive start address.
8715: If ``None``, :attr:`start` is considered.
8716: If ``Ellipsis``, the iterator is infinite.
8717:
8718: endex (int):
8719: Exclusive end address.
8720: If ``None``, :attr:`endex` is considered.
8721:
8722: pattern (items):
8723: Pattern of values to fill emptiness.
8724:
8725: Yields:
8726: int: Range values.
8727:
8728: Examples:
8729: >>> from itertools import islice
8730: >>> memory = Memory()
8731: >>> list(memory.values(endex=8))
8732: [None, None, None, None, None, None, None, None]
8733: >>> list(memory.values(3, 8))
8734: [None, None, None, None, None]
8735: >>> list(islice(memory.values(3, ...), 7))
8736: [None, None, None, None, None, None, None]
8737:
8738: ~~~
8739:
8740: +---+---+---+---+---+---+---+---+---+---+
8741: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
8742: +===+===+===+===+===+===+===+===+===+===+
8743: | |[A | B | C]| | |[x | y | z]| |
8744: +---+---+---+---+---+---+---+---+---+---+
8745: | | 65| 66| 67| | |120|121|122| |
8746: +---+---+---+---+---+---+---+---+---+---+
8747:
8748: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
8749: >>> list(memory.values())
8750: [65, 66, 67, None, None, 120, 121, 122]
8751: >>> list(memory.values(3, 8))
8752: [67, None, None, 120, 121]
8753: >>> list(islice(memory.values(3, ...), 7))
8754: [67, None, None, 120, 121, 122, None]
8755: """
8756: cdef:
8757: addr_t start_
8758: addr_t endex_
+8759: Rover_* rover = NULL
__pyx_cur_scope->__pyx_v_rover = NULL;
8760: byte_t pattern_value
8761: const byte_t[:] pattern_view
+8762: size_t pattern_size = 0
__pyx_cur_scope->__pyx_v_pattern_size = 0;
+8763: const byte_t* pattern_data = NULL
__pyx_cur_scope->__pyx_v_pattern_data = NULL;
8764:
+8765: if start is None:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_start == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+8766: start_ = Memory_Start(self._)
__pyx_cur_scope->__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_cur_scope->__pyx_v_self->_);
+8767: elif start is Ellipsis:
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_start == __pyx_builtin_Ellipsis); __pyx_t_1 = (__pyx_t_2 != 0); if (__pyx_t_1) { /* … */ goto __pyx_L4; }
+8768: start_ = ADDR_MIN
__pyx_cur_scope->__pyx_v_start_ = ADDR_MIN;
8769: else:
+8770: start_ = <addr_t>start
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8770, __pyx_L1_error) __pyx_cur_scope->__pyx_v_start_ = ((addr_t)__pyx_t_3); } __pyx_L4:;
8771:
+8772: if endex is None:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_endex == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L5; }
+8773: endex_ = Memory_Endex(self._)
__pyx_cur_scope->__pyx_v_endex_ = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_cur_scope->__pyx_v_self->_);
8774: else:
+8775: endex_ = <addr_t>endex
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8775, __pyx_L1_error) __pyx_cur_scope->__pyx_v_endex_ = ((addr_t)__pyx_t_3); } __pyx_L5:;
8776:
+8777: if pattern is not None:
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_pattern != Py_None); __pyx_t_1 = (__pyx_t_2 != 0); if (__pyx_t_1) { /* … */ }
+8778: if isinstance(pattern, int):
__pyx_t_1 = PyInt_Check(__pyx_cur_scope->__pyx_v_pattern);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L7;
}
+8779: pattern_value = <byte_t>pattern
__pyx_t_4 = __Pyx_PyInt_As_byte_t(__pyx_cur_scope->__pyx_v_pattern); if (unlikely((__pyx_t_4 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 8779, __pyx_L1_error) __pyx_cur_scope->__pyx_v_pattern_value = ((byte_t)__pyx_t_4);
+8780: pattern_size = 1
__pyx_cur_scope->__pyx_v_pattern_size = 1;
+8781: pattern_data = &pattern_value
__pyx_cur_scope->__pyx_v_pattern_data = (&__pyx_cur_scope->__pyx_v_pattern_value);
8782: else:
+8783: try:
/*else*/ { { /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L13_try_end; __pyx_L8_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); /* … */ __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ExceptionReset(__pyx_t_5, __pyx_t_6, __pyx_t_7); goto __pyx_L1_error; __pyx_L9_exception_handled:; __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ExceptionReset(__pyx_t_5, __pyx_t_6, __pyx_t_7); __pyx_L13_try_end:; }
+8784: pattern_view = pattern
__pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_cur_scope->__pyx_v_pattern, 0); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(0, 8784, __pyx_L8_error) __pyx_cur_scope->__pyx_v_pattern_view = __pyx_t_8; __pyx_t_8.memview = NULL; __pyx_t_8.data = NULL;
+8785: except TypeError:
__pyx_t_9 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError); if (__pyx_t_9) { __Pyx_AddTraceback("cbytesparse.c.Memory.rvalues", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12) < 0) __PYX_ERR(0, 8785, __pyx_L10_except_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11); __Pyx_GOTREF(__pyx_t_12);
+8786: pattern_view = bytes(pattern)
__pyx_t_13 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_cur_scope->__pyx_v_pattern); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 8786, __pyx_L10_except_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_t_13, 0); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(0, 8786, __pyx_L10_except_error) __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; __PYX_XDEC_MEMVIEW(&__pyx_cur_scope->__pyx_v_pattern_view, 1); __pyx_cur_scope->__pyx_v_pattern_view = __pyx_t_8; __pyx_t_8.memview = NULL; __pyx_t_8.data = NULL; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; goto __pyx_L9_exception_handled; } goto __pyx_L10_except_error; __pyx_L10_except_error:;
8787: with cython.boundscheck(False):
+8788: pattern_size = len(pattern_view)
__pyx_t_14 = __Pyx_MemoryView_Len(__pyx_cur_scope->__pyx_v_pattern_view);
__pyx_cur_scope->__pyx_v_pattern_size = __pyx_t_14;
+8789: pattern_data = &pattern_view[0]
__pyx_t_15 = 0; if (__pyx_t_15 < 0) __pyx_t_15 += __pyx_cur_scope->__pyx_v_pattern_view.shape[0]; __pyx_cur_scope->__pyx_v_pattern_data = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_cur_scope->__pyx_v_pattern_view.data + __pyx_t_15 * __pyx_cur_scope->__pyx_v_pattern_view.strides[0]) )))); } __pyx_L7:;
8790:
+8791: rover = Rover_Create(self._, start_, endex_, pattern_size, pattern_data, False, start is Ellipsis)
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_start == __pyx_builtin_Ellipsis);
__pyx_t_16 = __pyx_f_11cbytesparse_1c_Rover_Create(__pyx_cur_scope->__pyx_v_self->_, __pyx_cur_scope->__pyx_v_start_, __pyx_cur_scope->__pyx_v_endex_, __pyx_cur_scope->__pyx_v_pattern_size, __pyx_cur_scope->__pyx_v_pattern_data, 0, __pyx_t_2); if (unlikely(__pyx_t_16 == ((Rover_ *)NULL))) __PYX_ERR(0, 8791, __pyx_L1_error)
__pyx_cur_scope->__pyx_v_rover = __pyx_t_16;
+8792: try:
/*try:*/ { { /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L24_try_end; __pyx_L19_error:; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); /* … */ __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_6, __pyx_t_5); goto __pyx_L17_error; __pyx_L20_exception_handled:; __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ExceptionReset(__pyx_t_7, __pyx_t_6, __pyx_t_5); __pyx_L24_try_end:; } }
+8793: while True:
while (1) {
+8794: yield Rover_Next(rover)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Rover_Next(__pyx_cur_scope->__pyx_v_rover); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 8794, __pyx_L19_error) __Pyx_GOTREF(__pyx_t_12); __pyx_r = __pyx_t_12; __pyx_t_12 = 0; __Pyx_XGIVEREF(__pyx_t_5); __pyx_cur_scope->__pyx_t_0 = __pyx_t_5; __Pyx_XGIVEREF(__pyx_t_6); __pyx_cur_scope->__pyx_t_1 = __pyx_t_6; __Pyx_XGIVEREF(__pyx_t_7); __pyx_cur_scope->__pyx_t_2 = __pyx_t_7; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L27_resume_from_yield:; __pyx_t_5 = __pyx_cur_scope->__pyx_t_0; __pyx_cur_scope->__pyx_t_0 = 0; __Pyx_XGOTREF(__pyx_t_5); __pyx_t_6 = __pyx_cur_scope->__pyx_t_1; __pyx_cur_scope->__pyx_t_1 = 0; __Pyx_XGOTREF(__pyx_t_6); __pyx_t_7 = __pyx_cur_scope->__pyx_t_2; __pyx_cur_scope->__pyx_t_2 = 0; __Pyx_XGOTREF(__pyx_t_7); if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 8794, __pyx_L19_error) }
+8795: except StopIteration:
__pyx_t_9 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_StopIteration); if (__pyx_t_9) { __Pyx_ErrRestore(0,0,0); goto __pyx_L20_exception_handled; } goto __pyx_L21_except_error; __pyx_L21_except_error:;
8796: pass
8797: finally:
+8798: Rover_Free(rover)
/*finally:*/ { /*normal exit:*/{ __pyx_t_16 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_cur_scope->__pyx_v_rover); if (unlikely(__pyx_t_16 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 8798, __pyx_L1_error) goto __pyx_L18; } __pyx_L17_error:; /*exception exit:*/{ __Pyx_PyThreadState_assign __pyx_t_5 = 0; __pyx_t_6 = 0; __pyx_t_7 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_19, &__pyx_t_20, &__pyx_t_21); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_5, &__pyx_t_6, &__pyx_t_7) < 0)) __Pyx_ErrFetch(&__pyx_t_5, &__pyx_t_6, &__pyx_t_7); __Pyx_XGOTREF(__pyx_t_5); __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_7); __Pyx_XGOTREF(__pyx_t_19); __Pyx_XGOTREF(__pyx_t_20); __Pyx_XGOTREF(__pyx_t_21); __pyx_t_9 = __pyx_lineno; __pyx_t_17 = __pyx_clineno; __pyx_t_18 = __pyx_filename; { __pyx_t_16 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_cur_scope->__pyx_v_rover); if (unlikely(__pyx_t_16 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 8798, __pyx_L29_error) } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_19); __Pyx_XGIVEREF(__pyx_t_20); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ExceptionReset(__pyx_t_19, __pyx_t_20, __pyx_t_21); } __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ErrRestore(__pyx_t_5, __pyx_t_6, __pyx_t_7); __pyx_t_5 = 0; __pyx_t_6 = 0; __pyx_t_7 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __pyx_lineno = __pyx_t_9; __pyx_clineno = __pyx_t_17; __pyx_filename = __pyx_t_18; goto __pyx_L1_error; __pyx_L29_error:; if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_19); __Pyx_XGIVEREF(__pyx_t_20); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ExceptionReset(__pyx_t_19, __pyx_t_20, __pyx_t_21); } __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; goto __pyx_L1_error; } __pyx_L18:; } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
8799:
+8800: def shift(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_170shift(PyObject *__pyx_v_self, PyObject *__pyx_v_offset); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_169shift[] = "Memory.shift(self: Memory, offset: Address) -> None\nShifts the items.\n\n Arguments:\n offset (int):\n Signed amount of address shifting.\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+\n | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+===+===+\n | | | |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C]| |[x | y | z]| | | |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])\n >>> memory.shift(-2)\n >>> memory._blocks\n [[3, b'ABC'], [7, b'xyz']]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+---+\n | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|\n +===+===+===+===+===+===+===+===+===+===+===+\n | |[[[| |[A | B | C]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+\n | |[y | z]| | | | | | | | |\n +---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']], start=3)\n >>> memory.shift(-8)\n >>> memory._blocks\n [[2, b'yz']]\n\n See Also:\n :meth:`shift_backup`\n :meth:`shift_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_170shift = {"shift", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_170shift, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_169shift}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_170shift(PyObject *__pyx_v_self, PyObject *__pyx_v_offset) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("shift (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_169shift(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_offset)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_169shift(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_offset) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("shift", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.shift", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__195 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_offset); if (unlikely(!__pyx_tuple__195)) __PYX_ERR(0, 8800, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__195); __Pyx_GIVEREF(__pyx_tuple__195); /* … */ __pyx_t_9 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8800, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8800, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_170shift, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_shift, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__196)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8800, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_9); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_shift, __pyx_t_5) < 0) __PYX_ERR(0, 8800, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__196 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__195, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_shift, 8800, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__196)) __PYX_ERR(0, 8800, __pyx_L1_error)
8801: self: Memory,
+8802: offset: Address,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8802, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_offset, __pyx_t_5) < 0) __PYX_ERR(0, 8800, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+8803: ) -> None:
if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8800, __pyx_L1_error)
8804: r"""Shifts the items.
8805:
8806: Arguments:
8807: offset (int):
8808: Signed amount of address shifting.
8809:
8810: Examples:
8811: +---+---+---+---+---+---+---+---+---+---+---+
8812: | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
8813: +===+===+===+===+===+===+===+===+===+===+===+
8814: | | | |[A | B | C]| |[x | y | z]| |
8815: +---+---+---+---+---+---+---+---+---+---+---+
8816: | |[A | B | C]| |[x | y | z]| | | |
8817: +---+---+---+---+---+---+---+---+---+---+---+
8818:
8819: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']])
8820: >>> memory.shift(-2)
8821: >>> memory._blocks
8822: [[3, b'ABC'], [7, b'xyz']]
8823:
8824: ~~~
8825:
8826: +---+---+---+---+---+---+---+---+---+---+---+
8827: | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11| 12|
8828: +===+===+===+===+===+===+===+===+===+===+===+
8829: | |[[[| |[A | B | C]| |[x | y | z]| |
8830: +---+---+---+---+---+---+---+---+---+---+---+
8831: | |[y | z]| | | | | | | | |
8832: +---+---+---+---+---+---+---+---+---+---+---+
8833:
8834: >>> memory = Memory.from_blocks([[5, b'ABC'], [9, b'xyz']], start=3)
8835: >>> memory.shift(-8)
8836: >>> memory._blocks
8837: [[2, b'yz']]
8838:
8839: See Also:
8840: :meth:`shift_backup`
8841: :meth:`shift_restore`
8842: """
8843:
+8844: Memory_Shift(self._, offset)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Shift(__pyx_v_self->_, __pyx_v_offset); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8844, __pyx_L1_error)
8845:
+8846: def shift_backup(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_172shift_backup(PyObject *__pyx_v_self, PyObject *__pyx_v_offset); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_171shift_backup[] = "Memory.shift_backup(self: Memory, offset: Address) -> Tuple[Address, Memory]\nBackups a `shift()` operation.\n\n Arguments:\n offset (int):\n Signed amount of address shifting.\n\n Returns:\n (int, :obj:`Memory`): Shifting, backup memory region.\n\n See Also:\n :meth:`shift`\n :meth:`shift_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_172shift_backup = {"shift_backup", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_172shift_backup, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_171shift_backup}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_172shift_backup(PyObject *__pyx_v_self, PyObject *__pyx_v_offset) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("shift_backup (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_171shift_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_offset)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_171shift_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_offset) { struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("shift_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("cbytesparse.c.Memory.shift_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_backup); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__197 = PyTuple_Pack(3, __pyx_n_s_self, __pyx_n_s_offset, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__197)) __PYX_ERR(0, 8846, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__197); __Pyx_GIVEREF(__pyx_tuple__197); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8846, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8846, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_172shift_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_shift_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__198)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8846, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_shift_backup, __pyx_t_2) < 0) __PYX_ERR(0, 8846, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__198 = (PyObject*)__Pyx_PyCode_New(2, 0, 3, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__197, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_shift_backup, 8846, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__198)) __PYX_ERR(0, 8846, __pyx_L1_error)
8847: self: Memory,
+8848: offset: Address,
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Address); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8848, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_offset, __pyx_t_9) < 0) __PYX_ERR(0, 8846, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+8849: ) -> Tuple[Address, Memory]:
__Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Tuple); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 8849, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8849, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8849, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_2); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_7, 1, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8849, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_t_2) < 0) __PYX_ERR(0, 8846, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
8850: r"""Backups a `shift()` operation.
8851:
8852: Arguments:
8853: offset (int):
8854: Signed amount of address shifting.
8855:
8856: Returns:
8857: (int, :obj:`Memory`): Shifting, backup memory region.
8858:
8859: See Also:
8860: :meth:`shift`
8861: :meth:`shift_restore`
8862: """
8863: cdef:
8864: Memory backup
8865:
+8866: if offset < 0:
__pyx_t_1 = PyObject_RichCompare(__pyx_v_offset, __pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8866, __pyx_L1_error) __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 8866, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_2) { /* … */ goto __pyx_L3; }
+8867: backup = self._pretrim_start_backup(None, -offset)
__pyx_t_3 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_pretrim_start_backup); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8867, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = PyNumber_Negative(__pyx_v_offset); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 8867, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_5 = NULL; __pyx_t_6 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3); if (likely(__pyx_t_5)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_5); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_3, function); __pyx_t_6 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_3)) { PyObject *__pyx_temp[3] = {__pyx_t_5, Py_None, __pyx_t_4}; __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8867, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) { PyObject *__pyx_temp[3] = {__pyx_t_5, Py_None, __pyx_t_4}; __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8867, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; } else #endif { __pyx_t_7 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8867, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); if (__pyx_t_5) { __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_5); __pyx_t_5 = NULL; } __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_6, Py_None); __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_6, __pyx_t_4); __pyx_t_4 = 0; __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_7, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8867, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; } __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 8867, __pyx_L1_error) __pyx_v_backup = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_1); __pyx_t_1 = 0;
8868: else:
+8869: backup = self._pretrim_endex_backup(None, +offset)
/*else*/ { __pyx_t_3 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_n_s_pretrim_endex_backup); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 8869, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_7 = PyNumber_Positive(__pyx_v_offset); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 8869, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_4 = NULL; __pyx_t_6 = 0; if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3); if (likely(__pyx_t_4)) { PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_4); __Pyx_INCREF(function); __Pyx_DECREF_SET(__pyx_t_3, function); __pyx_t_6 = 1; } } #if CYTHON_FAST_PYCALL if (PyFunction_Check(__pyx_t_3)) { PyObject *__pyx_temp[3] = {__pyx_t_4, Py_None, __pyx_t_7}; __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8869, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; } else #endif #if CYTHON_FAST_PYCCALL if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) { PyObject *__pyx_temp[3] = {__pyx_t_4, Py_None, __pyx_t_7}; __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8869, __pyx_L1_error) __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; } else #endif { __pyx_t_5 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8869, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__pyx_t_4) { __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_4); __pyx_t_4 = NULL; } __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_6, Py_None); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_6, __pyx_t_7); __pyx_t_7 = 0; __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8869, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; } __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 8869, __pyx_L1_error) __pyx_v_backup = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_1); __pyx_t_1 = 0; } __pyx_L3:;
+8870: return offset, backup
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8870, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(__pyx_v_offset); __Pyx_GIVEREF(__pyx_v_offset); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_offset); __Pyx_INCREF(((PyObject *)__pyx_v_backup)); __Pyx_GIVEREF(((PyObject *)__pyx_v_backup)); PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_v_backup)); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8871:
+8872: def shift_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_174shift_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_173shift_restore[] = "Memory.shift_restore(self: Memory, offset: Address, Memory backup: Memory) -> None\nRestores an `shift()` operation.\n\n Arguments:\n offset (int):\n Signed amount of address shifting.\n\n backup (:obj:`Memory`):\n Backup memory region to restore.\n\n See Also:\n :meth:`shift`\n :meth:`shift_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_174shift_restore = {"shift_restore", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_174shift_restore, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_173shift_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_174shift_restore(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_offset = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("shift_restore (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_offset,&__pyx_n_s_backup,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_backup)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("shift_restore", 1, 2, 2, 1); __PYX_ERR(0, 8872, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "shift_restore") < 0)) __PYX_ERR(0, 8872, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_offset = values[0]; __pyx_v_backup = ((struct __pyx_obj_11cbytesparse_1c_Memory *)values[1]); } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("shift_restore", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 8872, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.shift_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 8875, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_173shift_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_offset, __pyx_v_backup); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_173shift_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_offset, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { Memory_ *__pyx_v_memory; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("shift_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("cbytesparse.c.Memory.shift_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__199 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_offset, __pyx_n_s_backup, __pyx_n_s_memory); if (unlikely(!__pyx_tuple__199)) __PYX_ERR(0, 8872, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__199); __Pyx_GIVEREF(__pyx_tuple__199); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8872, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8872, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_174shift_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_shift_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__200)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8872, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_shift_restore, __pyx_t_5) < 0) __PYX_ERR(0, 8872, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__200 = (PyObject*)__Pyx_PyCode_New(3, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__199, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_shift_restore, 8872, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__200)) __PYX_ERR(0, 8872, __pyx_L1_error)
8873: self: Memory,
+8874: offset: Address,
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 8874, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_offset, __pyx_t_5) < 0) __PYX_ERR(0, 8872, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 8872, __pyx_L1_error)
8875: Memory backup not None: Memory
+8876: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 8872, __pyx_L1_error)
8877: r"""Restores an `shift()` operation.
8878:
8879: Arguments:
8880: offset (int):
8881: Signed amount of address shifting.
8882:
8883: backup (:obj:`Memory`):
8884: Backup memory region to restore.
8885:
8886: See Also:
8887: :meth:`shift`
8888: :meth:`shift_backup`
8889: """
8890: cdef:
+8891: Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
8892:
+8893: Memory_Shift(memory, -offset)
__pyx_t_2 = PyNumber_Negative(__pyx_v_offset); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 8893, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Shift(__pyx_v_memory, __pyx_t_2); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8893, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+8894: Memory_Write(memory, 0, backup, True)
__pyx_t_3 = __pyx_f_11cbytesparse_1c_Memory_Write(__pyx_v_memory, __pyx_int_0, ((PyObject *)__pyx_v_backup), 1); if (unlikely(__pyx_t_3 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8894, __pyx_L1_error)
8895:
8896: @property
+8897: def span(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_4span_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_4span_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_4span___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_4span___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.span.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
8898: self: Memory,
8899: ) -> ClosedInterval:
8900: r"""tuple of int: Memory address span.
8901:
8902: A :obj:`tuple` holding both :attr:`start` and :attr:`endex`.
8903:
8904: Examples:
8905: >>> Memory().span
8906: (0, 0)
8907: >>> Memory(start=1, endex=8).span
8908: (1, 8)
8909:
8910: ~~~
8911:
8912: +---+---+---+---+---+---+---+---+---+
8913: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
8914: +===+===+===+===+===+===+===+===+===+
8915: | |[A | B | C]| |[x | y | z]| |
8916: +---+---+---+---+---+---+---+---+---+
8917:
8918: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
8919: >>> memory.span
8920: (1, 8)
8921: """
8922:
+8923: return Memory_Span(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_convert__to_py___pyx_ctuple_addr_t__and_addr_t(__pyx_f_11cbytesparse_1c_Memory_Span(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8923, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8924:
8925: @property
+8926: def start(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5start_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_5start_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_5start___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_5start___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.start.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
8927: self: Memory,
8928: ) -> Address:
8929: r"""int: Inclusive start address.
8930:
8931: This property holds the inclusive start address of the virtual space.
8932: By default, it is the current minimum inclusive start address of
8933: the first stored block.
8934:
8935: If :attr:`trim_start` not ``None``, that is returned.
8936:
8937: If the memory has no data and no trimming, 0 is returned.
8938:
8939: Examples:
8940: >>> Memory().start
8941: 0
8942:
8943: ~~~
8944:
8945: +---+---+---+---+---+---+---+---+---+
8946: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
8947: +===+===+===+===+===+===+===+===+===+
8948: | |[A | B | C]| |[x | y | z]| |
8949: +---+---+---+---+---+---+---+---+---+
8950:
8951: >>> memory = Memory.from_blocks([[1, b'ABC'], [5, b'xyz']])
8952: >>> memory.start
8953: 1
8954:
8955: ~~~
8956:
8957: +---+---+---+---+---+---+---+---+---+
8958: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
8959: +===+===+===+===+===+===+===+===+===+
8960: | |[[[| | | |[x | y | z]| |
8961: +---+---+---+---+---+---+---+---+---+
8962:
8963: >>> memory = Memory.from_blocks([[5, b'xyz']], start=1)
8964: >>> memory.start
8965: 1
8966: """
8967:
+8968: return Memory_Start(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyInt_From_uint_fast64_t(__pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_self->_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8968, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8969:
8970: @property
+8971: def trim_endex(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_10trim_endex_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_10trim_endex_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_10trim_endex___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_10trim_endex___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.trim_endex.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
8972: self: Memory,
8973: ) -> Optional[Address]:
8974: r"""int: Trimming exclusive end address.
8975:
8976: Any data at or after this address is automatically discarded.
8977: Disabled if ``None``.
8978: """
8979:
+8980: return Memory_GetTrimEndex(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_GetTrimEndex(__pyx_v_self->_); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8980, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
8981:
8982: @trim_endex.setter
+8983: def trim_endex(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_10trim_endex_3__set__(PyObject *__pyx_v_self, PyObject *__pyx_v_trim_endex); /*proto*/ static int __pyx_pw_11cbytesparse_1c_6Memory_10trim_endex_3__set__(PyObject *__pyx_v_self, PyObject *__pyx_v_trim_endex) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__set__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_10trim_endex_2__set__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_trim_endex)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_10trim_endex_2__set__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_trim_endex) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__set__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.trim_endex.__set__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
8984: self: Memory,
8985: trim_endex: Address,
8986: ) -> None:
8987:
+8988: Memory_SetTrimEndex(self._, trim_endex)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_SetTrimEndex(__pyx_v_self->_, __pyx_v_trim_endex); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 8988, __pyx_L1_error)
8989:
8990: @property
+8991: def trim_span(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_9trim_span_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_9trim_span_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_9trim_span___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_9trim_span___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.trim_span.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
8992: self: Memory,
8993: ) -> OpenInterval:
8994: r"""tuple of int: Trimming span addresses.
8995:
8996: A :obj:`tuple` holding :attr:`trim_start` and :attr:`trim_endex`.
8997: """
8998:
+8999: return Memory_GetTrimSpan(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_GetTrimSpan(__pyx_v_self->_); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 8999, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
9000:
9001: @trim_span.setter
+9002: def trim_span(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_9trim_span_3__set__(PyObject *__pyx_v_self, PyObject *__pyx_v_trim_span); /*proto*/ static int __pyx_pw_11cbytesparse_1c_6Memory_9trim_span_3__set__(PyObject *__pyx_v_self, PyObject *__pyx_v_trim_span) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__set__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_9trim_span_2__set__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_trim_span)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_9trim_span_2__set__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_trim_span) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__set__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.trim_span.__set__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
9003: self: Memory,
9004: trim_span: OpenInterval,
9005: ) -> None:
9006:
+9007: Memory_SetTrimSpan(self._, trim_span)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_SetTrimSpan(__pyx_v_self->_, __pyx_v_trim_span); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 9007, __pyx_L1_error)
9008:
9009: @property
+9010: def trim_start(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_10trim_start_1__get__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_10trim_start_1__get__(PyObject *__pyx_v_self) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_10trim_start___get__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_10trim_start___get__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__get__", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("cbytesparse.c.Memory.trim_start.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; }
9011: self: Memory,
9012: ) -> Optional[Address]:
9013: r"""int: Trimming start address.
9014:
9015: Any data before this address is automatically discarded.
9016: Disabled if ``None``.
9017: """
9018:
+9019: return Memory_GetTrimStart(self._)
__Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_GetTrimStart(__pyx_v_self->_); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9019, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0;
9020:
9021: @trim_start.setter
+9022: def trim_start(
/* Python wrapper */ static int __pyx_pw_11cbytesparse_1c_6Memory_10trim_start_3__set__(PyObject *__pyx_v_self, PyObject *__pyx_v_trim_start); /*proto*/ static int __pyx_pw_11cbytesparse_1c_6Memory_10trim_start_3__set__(PyObject *__pyx_v_self, PyObject *__pyx_v_trim_start) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__set__ (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_10trim_start_2__set__(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((PyObject *)__pyx_v_trim_start)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_11cbytesparse_1c_6Memory_10trim_start_2__set__(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_trim_start) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__set__", 0); /* … */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.trim_start.__set__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; }
9023: self: Memory,
9024: trim_start: Address,
9025: ) -> None:
9026:
+9027: Memory_SetTrimStart(self._, trim_start)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_SetTrimStart(__pyx_v_self->_, __pyx_v_trim_start); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 9027, __pyx_L1_error)
9028:
+9029: def validate(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_176validate(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_175validate[] = "Memory.validate(self: Memory) -> None\nValidates internal structure.\n\n It makes sure that all the allocated blocks are sorted by block start\n address, and that all the blocks are non-overlapping.\n\n Raises:\n :obj:`ValueError`: Invalid data detected (see exception message).\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_176validate = {"validate", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_176validate, METH_NOARGS, __pyx_doc_11cbytesparse_1c_6Memory_175validate}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_176validate(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("validate (wrapper)", 0); __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_175validate(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_175validate(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("validate", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.validate", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_179generator7(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */ /* … */ __pyx_tuple__201 = PyTuple_Pack(1, __pyx_n_s_self); if (unlikely(!__pyx_tuple__201)) __PYX_ERR(0, 9029, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__201); __Pyx_GIVEREF(__pyx_tuple__201); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9029, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9029, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_176validate, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_validate, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__202)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9029, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_validate, __pyx_t_2) < 0) __PYX_ERR(0, 9029, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__202 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__201, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_validate, 9029, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__202)) __PYX_ERR(0, 9029, __pyx_L1_error)
9030: self: Memory,
+9031: ) -> None:
if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 9029, __pyx_L1_error)
9032: r"""Validates internal structure.
9033:
9034: It makes sure that all the allocated blocks are sorted by block start
9035: address, and that all the blocks are non-overlapping.
9036:
9037: Raises:
9038: :obj:`ValueError`: Invalid data detected (see exception message).
9039: """
9040:
+9041: Memory_Validate(self._)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Validate(__pyx_v_self->_); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 9041, __pyx_L1_error)
9042:
+9043: def values(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_178values(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_177values[] = "Memory.values(self: Memory, start: Optional[Address] = None, endex: Optional[Union[Address, EllipsisType]] = None, pattern: Optional[Union[AnyBytes, Value]] = None) -> Iterator[Optional[Value]]\nIterates over values.\n\n Iterates over values, from `start` to `endex`.\n Implemets the interface of :obj:`dict`.\n\n Arguments:\n start (int):\n Inclusive start address.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end address.\n If ``None``, :attr:`endex` is considered.\n If ``Ellipsis``, the iterator is infinite.\n\n pattern (items):\n Pattern of values to fill emptiness.\n\n Yields:\n int: Range values.\n\n Examples:\n >>> from itertools import islice\n >>> memory = Memory()\n >>> list(memory.values(endex=8))\n [None, None, None, None, None, None, None, None]\n >>> list(memory.values(3, 8))\n [None, None, None, None, None]\n >>> list(islice(memory.values(3, ...), 7))\n [None, None, None, None, None, None, None]\n\n ~~~\n\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | | 65| 66| 67| | |120|121|122| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> list(memory.values())\n [65, 66, 67, None, None, 120, 121, 122]\n >>> list(memory.values(3, 8))\n [67, None, None, 120, 121]\n >>> list(islice(memory.values(3, ...), 7))\n [67, None, None, 120, 121, 122, None]\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_178values = {"values", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_178values, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_177values}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_178values(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; PyObject *__pyx_v_pattern = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("values (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,&__pyx_n_s_pattern,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_177values(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex, PyObject *__pyx_v_pattern) { struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_7_values *__pyx_cur_scope; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("values", 0); __pyx_cur_scope = (struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_7_values *)__pyx_tp_new_11cbytesparse_1c___pyx_scope_struct_7_values(__pyx_ptype_11cbytesparse_1c___pyx_scope_struct_7_values, __pyx_empty_tuple, NULL); if (unlikely(!__pyx_cur_scope)) { __pyx_cur_scope = ((struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_7_values *)Py_None); __Pyx_INCREF(Py_None); __PYX_ERR(0, 9043, __pyx_L1_error) } else { __Pyx_GOTREF(__pyx_cur_scope); } __pyx_cur_scope->__pyx_v_self = __pyx_v_self; __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_v_self); __pyx_cur_scope->__pyx_v_start = __pyx_v_start; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_start); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_start); __pyx_cur_scope->__pyx_v_endex = __pyx_v_endex; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_endex); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_endex); __pyx_cur_scope->__pyx_v_pattern = __pyx_v_pattern; __Pyx_INCREF(__pyx_cur_scope->__pyx_v_pattern); __Pyx_GIVEREF(__pyx_cur_scope->__pyx_v_pattern); { __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_11cbytesparse_1c_6Memory_179generator7, __pyx_codeobj__36, (PyObject *) __pyx_cur_scope, __pyx_n_s_values, __pyx_n_s_Memory_values, __pyx_n_s_cbytesparse_c); if (unlikely(!gen)) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_DECREF(__pyx_cur_scope); __Pyx_RefNannyFinishContext(); return (PyObject *) gen; } /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.values", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_DECREF(((PyObject *)__pyx_cur_scope)); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_gb_11cbytesparse_1c_6Memory_179generator7(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */ { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("values", 0); __pyx_L3_first_run:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 9043, __pyx_L1_error) /* … */ /* function exit code */ PyErr_SetNone(PyExc_StopIteration); goto __pyx_L0; __pyx_L1_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); __Pyx_XDECREF(__pyx_t_10); __Pyx_XDECREF(__pyx_t_11); __Pyx_XDECREF(__pyx_t_12); __Pyx_XDECREF(__pyx_t_13); __Pyx_AddTraceback("values", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_L0:; __Pyx_XDECREF(__pyx_r); __pyx_r = 0; #if !CYTHON_USE_EXC_INFO_STACK __Pyx_Coroutine_ResetAndClearException(__pyx_generator); #endif __pyx_generator->resume_label = -1; __Pyx_Coroutine_clear((PyObject*)__pyx_generator); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__203 = PyTuple_Pack(11, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_pattern, __pyx_n_s_start_2, __pyx_n_s_endex_2, __pyx_n_s_rover, __pyx_n_s_pattern_value, __pyx_n_s_pattern_view, __pyx_n_s_pattern_size, __pyx_n_s_pattern_data); if (unlikely(!__pyx_tuple__203)) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__203); __Pyx_GIVEREF(__pyx_tuple__203); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9043, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_178values, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_values, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__36)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_values, __pyx_t_1) < 0) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__36 = (PyObject*)__Pyx_PyCode_New(4, 0, 11, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__203, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_values, 9043, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__36)) __PYX_ERR(0, 9043, __pyx_L1_error) /* … */ struct __pyx_obj_11cbytesparse_1c___pyx_scope_struct_7_values { PyObject_HEAD PyObject *__pyx_v_endex; addr_t __pyx_v_endex_; PyObject *__pyx_v_pattern; byte_t const *__pyx_v_pattern_data; size_t __pyx_v_pattern_size; byte_t __pyx_v_pattern_value; __Pyx_memviewslice __pyx_v_pattern_view; Rover_ *__pyx_v_rover; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self; PyObject *__pyx_v_start; addr_t __pyx_v_start_; };
9044: self: Memory,
+9045: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9045, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Address); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9045, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_7); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 9045, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_start, __pyx_t_9) < 0) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+9046: endex: Optional[Union[Address, EllipsisType]] = None,
values[1] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_Optional); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Union); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Address); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_EllipsisType); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_5); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_6); __pyx_t_5 = 0; __pyx_t_6 = 0; __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9046, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_endex, __pyx_t_1) < 0) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+9047: pattern: Optional[Union[AnyBytes, Value]] = None,
values[2] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pattern); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "values") < 0)) __PYX_ERR(0, 9043, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; __pyx_v_pattern = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("values", 0, 0, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 9043, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.values", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_177values(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex, __pyx_v_pattern); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Optional); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Union); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Value); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_9); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_7); __pyx_t_9 = 0; __pyx_t_7 = 0; __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_t_5); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_7); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9047, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_pattern, __pyx_t_5) < 0) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+9048: ) -> Iterator[Optional[Value]]:
__Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Iterator); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9048, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_Optional); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9048, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9048, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_6 = __Pyx_PyObject_GetItem(__pyx_t_7, __pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9048, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9048, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, __pyx_t_1) < 0) __PYX_ERR(0, 9043, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
9049: r"""Iterates over values.
9050:
9051: Iterates over values, from `start` to `endex`.
9052: Implemets the interface of :obj:`dict`.
9053:
9054: Arguments:
9055: start (int):
9056: Inclusive start address.
9057: If ``None``, :attr:`start` is considered.
9058:
9059: endex (int):
9060: Exclusive end address.
9061: If ``None``, :attr:`endex` is considered.
9062: If ``Ellipsis``, the iterator is infinite.
9063:
9064: pattern (items):
9065: Pattern of values to fill emptiness.
9066:
9067: Yields:
9068: int: Range values.
9069:
9070: Examples:
9071: >>> from itertools import islice
9072: >>> memory = Memory()
9073: >>> list(memory.values(endex=8))
9074: [None, None, None, None, None, None, None, None]
9075: >>> list(memory.values(3, 8))
9076: [None, None, None, None, None]
9077: >>> list(islice(memory.values(3, ...), 7))
9078: [None, None, None, None, None, None, None]
9079:
9080: ~~~
9081:
9082: +---+---+---+---+---+---+---+---+---+---+
9083: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
9084: +===+===+===+===+===+===+===+===+===+===+
9085: | |[A | B | C]| | |[x | y | z]| |
9086: +---+---+---+---+---+---+---+---+---+---+
9087: | | 65| 66| 67| | |120|121|122| |
9088: +---+---+---+---+---+---+---+---+---+---+
9089:
9090: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
9091: >>> list(memory.values())
9092: [65, 66, 67, None, None, 120, 121, 122]
9093: >>> list(memory.values(3, 8))
9094: [67, None, None, 120, 121]
9095: >>> list(islice(memory.values(3, ...), 7))
9096: [67, None, None, 120, 121, 122, None]
9097: """
9098: cdef:
9099: addr_t start_
9100: addr_t endex_
+9101: Rover_* rover = NULL
__pyx_cur_scope->__pyx_v_rover = NULL;
9102: byte_t pattern_value
9103: const byte_t[:] pattern_view
+9104: size_t pattern_size = 0
__pyx_cur_scope->__pyx_v_pattern_size = 0;
+9105: const byte_t* pattern_data = NULL
__pyx_cur_scope->__pyx_v_pattern_data = NULL;
9106:
+9107: if start is None:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_start == Py_None); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L4; }
+9108: start_ = Memory_Start(self._)
__pyx_cur_scope->__pyx_v_start_ = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_cur_scope->__pyx_v_self->_);
9109: else:
+9110: start_ = <addr_t>start
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_start); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9110, __pyx_L1_error) __pyx_cur_scope->__pyx_v_start_ = ((addr_t)__pyx_t_3); } __pyx_L4:;
9111:
+9112: if endex is None:
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_endex == Py_None); __pyx_t_1 = (__pyx_t_2 != 0); if (__pyx_t_1) { /* … */ goto __pyx_L5; }
+9113: endex_ = Memory_Endex(self._)
__pyx_cur_scope->__pyx_v_endex_ = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_cur_scope->__pyx_v_self->_);
+9114: elif endex is Ellipsis:
__pyx_t_1 = (__pyx_cur_scope->__pyx_v_endex == __pyx_builtin_Ellipsis); __pyx_t_2 = (__pyx_t_1 != 0); if (__pyx_t_2) { /* … */ goto __pyx_L5; }
+9115: endex_ = ADDR_MAX
__pyx_cur_scope->__pyx_v_endex_ = ADDR_MAX;
9116: else:
+9117: endex_ = <addr_t>endex
/*else*/ { __pyx_t_3 = __Pyx_PyInt_As_uint_fast64_t(__pyx_cur_scope->__pyx_v_endex); if (unlikely((__pyx_t_3 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9117, __pyx_L1_error) __pyx_cur_scope->__pyx_v_endex_ = ((addr_t)__pyx_t_3); } __pyx_L5:;
9118:
+9119: if pattern is not None:
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_pattern != Py_None); __pyx_t_1 = (__pyx_t_2 != 0); if (__pyx_t_1) { /* … */ }
+9120: if isinstance(pattern, int):
__pyx_t_1 = PyInt_Check(__pyx_cur_scope->__pyx_v_pattern);
__pyx_t_2 = (__pyx_t_1 != 0);
if (__pyx_t_2) {
/* … */
goto __pyx_L7;
}
+9121: pattern_value = <byte_t>pattern
__pyx_t_4 = __Pyx_PyInt_As_byte_t(__pyx_cur_scope->__pyx_v_pattern); if (unlikely((__pyx_t_4 == ((byte_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9121, __pyx_L1_error) __pyx_cur_scope->__pyx_v_pattern_value = ((byte_t)__pyx_t_4);
+9122: pattern_size = 1
__pyx_cur_scope->__pyx_v_pattern_size = 1;
+9123: pattern_data = &pattern_value
__pyx_cur_scope->__pyx_v_pattern_data = (&__pyx_cur_scope->__pyx_v_pattern_value);
9124: else:
+9125: try:
/*else*/ { { /*try:*/ { /* … */ } __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; goto __pyx_L13_try_end; __pyx_L8_error:; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); /* … */ __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ExceptionReset(__pyx_t_5, __pyx_t_6, __pyx_t_7); goto __pyx_L1_error; __pyx_L9_exception_handled:; __Pyx_XGIVEREF(__pyx_t_5); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_ExceptionReset(__pyx_t_5, __pyx_t_6, __pyx_t_7); __pyx_L13_try_end:; }
+9126: pattern_view = pattern
__pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_cur_scope->__pyx_v_pattern, 0); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(0, 9126, __pyx_L8_error) __pyx_cur_scope->__pyx_v_pattern_view = __pyx_t_8; __pyx_t_8.memview = NULL; __pyx_t_8.data = NULL;
+9127: except TypeError:
__pyx_t_9 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError); if (__pyx_t_9) { __Pyx_AddTraceback("cbytesparse.c.Memory.values", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12) < 0) __PYX_ERR(0, 9127, __pyx_L10_except_error) __Pyx_GOTREF(__pyx_t_10); __Pyx_GOTREF(__pyx_t_11); __Pyx_GOTREF(__pyx_t_12);
+9128: pattern_view = bytes(pattern)
__pyx_t_13 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_cur_scope->__pyx_v_pattern); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 9128, __pyx_L10_except_error) __Pyx_GOTREF(__pyx_t_13); __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_nn_byte_t__const__(__pyx_t_13, 0); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(0, 9128, __pyx_L10_except_error) __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0; __PYX_XDEC_MEMVIEW(&__pyx_cur_scope->__pyx_v_pattern_view, 1); __pyx_cur_scope->__pyx_v_pattern_view = __pyx_t_8; __pyx_t_8.memview = NULL; __pyx_t_8.data = NULL; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; goto __pyx_L9_exception_handled; } goto __pyx_L10_except_error; __pyx_L10_except_error:;
9129: with cython.boundscheck(False):
+9130: pattern_size = len(pattern_view)
__pyx_t_14 = __Pyx_MemoryView_Len(__pyx_cur_scope->__pyx_v_pattern_view);
__pyx_cur_scope->__pyx_v_pattern_size = __pyx_t_14;
+9131: pattern_data = &pattern_view[0]
__pyx_t_15 = 0; if (__pyx_t_15 < 0) __pyx_t_15 += __pyx_cur_scope->__pyx_v_pattern_view.shape[0]; __pyx_cur_scope->__pyx_v_pattern_data = (&(*((byte_t const *) ( /* dim=0 */ (__pyx_cur_scope->__pyx_v_pattern_view.data + __pyx_t_15 * __pyx_cur_scope->__pyx_v_pattern_view.strides[0]) )))); } __pyx_L7:;
9132:
+9133: try:
/*try:*/ {
+9134: rover = Rover_Create(self._, start_, endex_, pattern_size, pattern_data, True, endex is Ellipsis)
__pyx_t_2 = (__pyx_cur_scope->__pyx_v_endex == __pyx_builtin_Ellipsis);
__pyx_t_16 = __pyx_f_11cbytesparse_1c_Rover_Create(__pyx_cur_scope->__pyx_v_self->_, __pyx_cur_scope->__pyx_v_start_, __pyx_cur_scope->__pyx_v_endex_, __pyx_cur_scope->__pyx_v_pattern_size, __pyx_cur_scope->__pyx_v_pattern_data, 1, __pyx_t_2); if (unlikely(__pyx_t_16 == ((Rover_ *)NULL))) __PYX_ERR(0, 9134, __pyx_L17_error)
__pyx_cur_scope->__pyx_v_rover = __pyx_t_16;
+9135: while Rover_HasNext(rover):
while (1) { __pyx_t_2 = (__pyx_f_11cbytesparse_1c_Rover_HasNext(__pyx_cur_scope->__pyx_v_rover) != 0); if (!__pyx_t_2) break;
+9136: yield Rover_Next(rover)
__pyx_t_12 = __pyx_f_11cbytesparse_1c_Rover_Next(__pyx_cur_scope->__pyx_v_rover); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 9136, __pyx_L17_error) __Pyx_GOTREF(__pyx_t_12); __pyx_r = __pyx_t_12; __pyx_t_12 = 0; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); __Pyx_Coroutine_ResetAndClearException(__pyx_generator); /* return from generator, yielding value */ __pyx_generator->resume_label = 1; return __pyx_r; __pyx_L21_resume_from_yield:; if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 9136, __pyx_L17_error) } }
9137: finally:
+9138: rover = Rover_Free(rover)
/*finally:*/ { /*normal exit:*/{ __pyx_t_16 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_cur_scope->__pyx_v_rover); if (unlikely(__pyx_t_16 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 9138, __pyx_L1_error) __pyx_cur_scope->__pyx_v_rover = __pyx_t_16; goto __pyx_L18; } __pyx_L17_error:; /*exception exit:*/{ __Pyx_PyThreadState_assign __pyx_t_7 = 0; __pyx_t_6 = 0; __pyx_t_5 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1); if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_19, &__pyx_t_20, &__pyx_t_21); if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_7, &__pyx_t_6, &__pyx_t_5) < 0)) __Pyx_ErrFetch(&__pyx_t_7, &__pyx_t_6, &__pyx_t_5); __Pyx_XGOTREF(__pyx_t_7); __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_5); __Pyx_XGOTREF(__pyx_t_19); __Pyx_XGOTREF(__pyx_t_20); __Pyx_XGOTREF(__pyx_t_21); __pyx_t_9 = __pyx_lineno; __pyx_t_17 = __pyx_clineno; __pyx_t_18 = __pyx_filename; { __pyx_t_16 = __pyx_f_11cbytesparse_1c_Rover_Free(__pyx_cur_scope->__pyx_v_rover); if (unlikely(__pyx_t_16 == ((Rover_ *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 9138, __pyx_L23_error) __pyx_cur_scope->__pyx_v_rover = __pyx_t_16; } if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_19); __Pyx_XGIVEREF(__pyx_t_20); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ExceptionReset(__pyx_t_19, __pyx_t_20, __pyx_t_21); } __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_5); __Pyx_ErrRestore(__pyx_t_7, __pyx_t_6, __pyx_t_5); __pyx_t_7 = 0; __pyx_t_6 = 0; __pyx_t_5 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __pyx_lineno = __pyx_t_9; __pyx_clineno = __pyx_t_17; __pyx_filename = __pyx_t_18; goto __pyx_L1_error; __pyx_L23_error:; if (PY_MAJOR_VERSION >= 3) { __Pyx_XGIVEREF(__pyx_t_19); __Pyx_XGIVEREF(__pyx_t_20); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ExceptionReset(__pyx_t_19, __pyx_t_20, __pyx_t_21); } __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; goto __pyx_L1_error; } __pyx_L18:; } CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);
9139:
+9140: def view(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_pw_11cbytesparse_1c_6Memory_181view(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_180view[] = "Memory.view(self: Memory, start: Optional[Address] = None, endex: Optional[Address] = None) -> BlockView\nCreates a view over a range.\n\n Creates a memory view over the selected address range.\n Data within the range is required to be contiguous.\n\n Arguments:\n start (int):\n Inclusive start of the viewed range.\n If ``None``, :attr:`start` is considered.\n\n endex (int):\n Exclusive end of the viewed range.\n If ``None``, :attr:`endex` is considered.\n\n Returns:\n :obj:`memoryview`: A view of the selected address range.\n\n Raises:\n :obj:`ValueError`: Data not contiguous (see :attr:`contiguous`).\n\n Examples:\n +---+---+---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|\n +===+===+===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C | D]| |[$]| |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])\n >>> bytes(memory.view(2, 5))\n b'BCD'\n >>> bytes(memory.view(9, 10))\n b'y'\n >>> memory.view()\n Traceback (most recent call last):\n ...\n ValueError: non-contiguous data within range\n >>> memory.view(0, 6)\n Traceback (most recent call last):\n ...\n ValueError: non-contiguous data within range\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_181view = {"view", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_181view, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_180view}; static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_pw_11cbytesparse_1c_6Memory_181view(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_start = 0; PyObject *__pyx_v_endex = 0; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("view (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_start,&__pyx_n_s_endex,0}; PyObject* values[2] = {0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_pf_11cbytesparse_1c_6Memory_180view(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_start, PyObject *__pyx_v_endex) { Memory_ const *__pyx_v_memory; addr_t __pyx_v_start_; addr_t __pyx_v_endex_; struct __pyx_obj_11cbytesparse_1c_BlockView *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("view", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("cbytesparse.c.Memory.view", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__204 = PyTuple_Pack(6, __pyx_n_s_self, __pyx_n_s_start, __pyx_n_s_endex, __pyx_n_s_memory, __pyx_n_s_start_2, __pyx_n_s_endex_2); if (unlikely(!__pyx_tuple__204)) __PYX_ERR(0, 9140, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__204); __Pyx_GIVEREF(__pyx_tuple__204); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9140, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9140, __pyx_L1_error) /* … */ __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_181view, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_view, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__205)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9140, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_2, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_view, __pyx_t_2) < 0) __PYX_ERR(0, 9140, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__205 = (PyObject*)__Pyx_PyCode_New(3, 0, 6, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__204, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_view, 9140, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__205)) __PYX_ERR(0, 9140, __pyx_L1_error)
9141: self: Memory,
+9142: start: Optional[Address] = None,
values[0] = ((PyObject *)Py_None); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Optional); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9142, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9142, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9142, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_start, __pyx_t_5) < 0) __PYX_ERR(0, 9140, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+9143: endex: Optional[Address] = None,
values[1] = ((PyObject *)Py_None); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_start); if (value) { values[0] = value; kw_args--; } } CYTHON_FALLTHROUGH; case 1: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_endex); if (value) { values[1] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "view") < 0)) __PYX_ERR(0, 9140, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_start = values[0]; __pyx_v_endex = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("view", 0, 0, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 9140, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.view", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_180view(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_start, __pyx_v_endex); /* … */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Optional); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9143, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_Address); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9143, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_t_5, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9143, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_endex, __pyx_t_2) < 0) __PYX_ERR(0, 9140, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, __pyx_n_u_BlockView) < 0) __PYX_ERR(0, 9140, __pyx_L1_error)
9144: ) -> BlockView:
9145: r"""Creates a view over a range.
9146:
9147: Creates a memory view over the selected address range.
9148: Data within the range is required to be contiguous.
9149:
9150: Arguments:
9151: start (int):
9152: Inclusive start of the viewed range.
9153: If ``None``, :attr:`start` is considered.
9154:
9155: endex (int):
9156: Exclusive end of the viewed range.
9157: If ``None``, :attr:`endex` is considered.
9158:
9159: Returns:
9160: :obj:`memoryview`: A view of the selected address range.
9161:
9162: Raises:
9163: :obj:`ValueError`: Data not contiguous (see :attr:`contiguous`).
9164:
9165: Examples:
9166: +---+---+---+---+---+---+---+---+---+---+---+---+
9167: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10| 11|
9168: +===+===+===+===+===+===+===+===+===+===+===+===+
9169: | |[A | B | C | D]| |[$]| |[x | y | z]| |
9170: +---+---+---+---+---+---+---+---+---+---+---+---+
9171:
9172: >>> memory = Memory.from_blocks([[1, b'ABCD'], [6, b'$'], [8, b'xyz']])
9173: >>> bytes(memory.view(2, 5))
9174: b'BCD'
9175: >>> bytes(memory.view(9, 10))
9176: b'y'
9177: >>> memory.view()
9178: Traceback (most recent call last):
9179: ...
9180: ValueError: non-contiguous data within range
9181: >>> memory.view(0, 6)
9182: Traceback (most recent call last):
9183: ...
9184: ValueError: non-contiguous data within range
9185: """
9186: cdef:
+9187: const Memory_* memory = self._
__pyx_t_1 = __pyx_v_self->_; __pyx_v_memory = __pyx_t_1;
+9188: addr_t start_ = Memory_Start(memory) if start is None else <addr_t>start
__pyx_t_3 = (__pyx_v_start == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Start(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_start); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9188, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_start_ = __pyx_t_2;
+9189: addr_t endex_ = Memory_Endex(memory) if endex is None else <addr_t>endex
__pyx_t_3 = (__pyx_v_endex == Py_None); if ((__pyx_t_3 != 0)) { __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Endex(__pyx_v_memory); } else { __pyx_t_4 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_endex); if (unlikely((__pyx_t_4 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9189, __pyx_L1_error) __pyx_t_2 = ((addr_t)__pyx_t_4); } __pyx_v_endex_ = __pyx_t_2;
9190:
+9191: return Memory_View(memory, start_, endex_)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_5 = ((PyObject *)__pyx_f_11cbytesparse_1c_Memory_View(__pyx_v_memory, __pyx_v_start_, __pyx_v_endex_)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9191, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_BlockView *)__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L0;
9192:
+9193: def write(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_183write(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_182write[] = "Memory.write(self: Memory, address: Address, data: Union[AnyBytes, Value, Memory], clear: bool = False) -> None\nWrites data.\n\n Arguments:\n address (int):\n Address where to start writing data.\n\n data (bytes):\n Data to write.\n\n clear (bool):\n Clears the target range before writing data.\n Useful only if `data` is a :obj:`Memory` with empty spaces.\n\n Example:\n +---+---+---+---+---+---+---+---+---+---+\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |\n +===+===+===+===+===+===+===+===+===+===+\n | |[A | B | C]| | |[x | y | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n | |[A | B | C]| |[1 | 2 | 3 | z]| |\n +---+---+---+---+---+---+---+---+---+---+\n\n >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])\n >>> memory.write(5, b'123')\n >>> memory._blocks\n [[1, b'ABC'], [5, b'123z']]\n\n See Also:\n :meth:`write_backup`\n :meth:`write_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_183write = {"write", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_183write, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_182write}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_183write(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_data = 0; PyObject *__pyx_v_clear = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("write (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_data,&__pyx_n_s_clear,0}; PyObject* values[3] = {0,0,0}; /* … */ /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_182write(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_data, PyObject *__pyx_v_clear) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("write", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.write", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__206 = PyTuple_Pack(4, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_data, __pyx_n_s_clear); if (unlikely(!__pyx_tuple__206)) __PYX_ERR(0, 9193, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__206); __Pyx_GIVEREF(__pyx_tuple__206); /* … */ __pyx_t_2 = __Pyx_PyDict_NewPresized(5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9193, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9193, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_183write, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_write, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__207)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9193, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_write, __pyx_t_5) < 0) __PYX_ERR(0, 9193, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__207 = (PyObject*)__Pyx_PyCode_New(4, 0, 4, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__206, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_write, 9193, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__207)) __PYX_ERR(0, 9193, __pyx_L1_error)
9194: self: Memory,
+9195: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Address); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9195, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_address, __pyx_t_1) < 0) __PYX_ERR(0, 9193, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+9196: data: Union[AnyBytes, Value, Memory],
__Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Union); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9196, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9196, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_Value); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9196, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_7 = PyTuple_New(3); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9196, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6); __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_5); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_7, 2, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_6 = 0; __pyx_t_5 = 0; __pyx_t_5 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_t_7); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9196, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_data, __pyx_t_5) < 0) __PYX_ERR(0, 9193, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+9197: clear: bool = False,
values[2] = ((PyObject *)Py_False); if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_data)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("write", 0, 2, 3, 1); __PYX_ERR(0, 9193, __pyx_L3_error) } CYTHON_FALLTHROUGH; case 2: if (kw_args > 0) { PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_clear); if (value) { values[2] = value; kw_args--; } } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "write") < 0)) __PYX_ERR(0, 9193, __pyx_L3_error) } } else { switch (PyTuple_GET_SIZE(__pyx_args)) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); CYTHON_FALLTHROUGH; case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[0] = PyTuple_GET_ITEM(__pyx_args, 0); break; default: goto __pyx_L5_argtuple_error; } } __pyx_v_address = values[0]; __pyx_v_data = values[1]; __pyx_v_clear = values[2]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("write", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 9193, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.write", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_182write(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_data, __pyx_v_clear); /* … */ if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_clear, ((PyObject*)&PyBool_Type)) < 0) __PYX_ERR(0, 9193, __pyx_L1_error)
+9198: ) -> None:
if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 9193, __pyx_L1_error)
9199: r"""Writes data.
9200:
9201: Arguments:
9202: address (int):
9203: Address where to start writing data.
9204:
9205: data (bytes):
9206: Data to write.
9207:
9208: clear (bool):
9209: Clears the target range before writing data.
9210: Useful only if `data` is a :obj:`Memory` with empty spaces.
9211:
9212: Example:
9213: +---+---+---+---+---+---+---+---+---+---+
9214: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
9215: +===+===+===+===+===+===+===+===+===+===+
9216: | |[A | B | C]| | |[x | y | z]| |
9217: +---+---+---+---+---+---+---+---+---+---+
9218: | |[A | B | C]| |[1 | 2 | 3 | z]| |
9219: +---+---+---+---+---+---+---+---+---+---+
9220:
9221: >>> memory = Memory.from_blocks([[1, b'ABC'], [6, b'xyz']])
9222: >>> memory.write(5, b'123')
9223: >>> memory._blocks
9224: [[1, b'ABC'], [5, b'123z']]
9225:
9226: See Also:
9227: :meth:`write_backup`
9228: :meth:`write_restore`
9229: """
9230:
+9231: Memory_Write(self._, address, data, clear)
__pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_clear); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 9231, __pyx_L1_error) __pyx_t_2 = __pyx_f_11cbytesparse_1c_Memory_Write(__pyx_v_self->_, __pyx_v_address, __pyx_v_data, __pyx_t_1); if (unlikely(__pyx_t_2 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 9231, __pyx_L1_error)
9232:
+9233: def write_backup(
/* Python wrapper */ static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_185write_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_184write_backup[] = "Memory.write_backup(self: Memory, address: Address, data: Union[AnyBytes, Value, Memory]) -> Memory\nBackups a `write()` operation.\n\n Arguments:\n address (int):\n Address where to start writing data.\n\n data (bytes):\n Data to write.\n\n Returns:\n :obj:`Memory` list: Backup memory regions.\n\n See Also:\n :meth:`write`\n :meth:`write_restore`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_185write_backup = {"write_backup", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_11cbytesparse_1c_6Memory_185write_backup, METH_VARARGS|METH_KEYWORDS, __pyx_doc_11cbytesparse_1c_6Memory_184write_backup}; static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pw_11cbytesparse_1c_6Memory_185write_backup(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_address = 0; PyObject *__pyx_v_data = 0; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("write_backup (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_address,&__pyx_n_s_data,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); CYTHON_FALLTHROUGH; case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_address)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; CYTHON_FALLTHROUGH; case 1: if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_data)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("write_backup", 1, 2, 2, 1); __PYX_ERR(0, 9233, __pyx_L3_error) } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "write_backup") < 0)) __PYX_ERR(0, 9233, __pyx_L3_error) } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_address = values[0]; __pyx_v_data = values[1]; } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("write_backup", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 9233, __pyx_L3_error) __pyx_L3_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.write_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_184write_backup(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), __pyx_v_address, __pyx_v_data); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_pf_11cbytesparse_1c_6Memory_184write_backup(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, PyObject *__pyx_v_address, PyObject *__pyx_v_data) { CYTHON_UNUSED addr_t __pyx_v_address_; addr_t __pyx_v_size; struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("write_backup", 0); /* … */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("cbytesparse.c.Memory.write_backup", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF((PyObject *)__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__208 = PyTuple_Pack(5, __pyx_n_s_self, __pyx_n_s_address, __pyx_n_s_data, __pyx_n_s_address_2, __pyx_n_s_size); if (unlikely(!__pyx_tuple__208)) __PYX_ERR(0, 9233, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__208); __Pyx_GIVEREF(__pyx_tuple__208); /* … */ __pyx_t_5 = __Pyx_PyDict_NewPresized(4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9233, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9233, __pyx_L1_error) /* … */ __pyx_t_1 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_185write_backup, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_write_backup, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__209)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9233, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_1, __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_write_backup, __pyx_t_1) < 0) __PYX_ERR(0, 9233, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__209 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__208, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_write_backup, 9233, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__209)) __PYX_ERR(0, 9233, __pyx_L1_error)
9234: self: Memory,
+9235: address: Address,
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Address); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9235, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_address, __pyx_t_2) < 0) __PYX_ERR(0, 9233, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+9236: data: Union[AnyBytes, Value, Memory],
__Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_Union); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 9236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_AnyBytes); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 9236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Value); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_6 = PyTuple_New(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_GIVEREF(__pyx_t_7); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_7); __Pyx_GIVEREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_1); __Pyx_INCREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __Pyx_GIVEREF(((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); PyTuple_SET_ITEM(__pyx_t_6, 2, ((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory)); __pyx_t_7 = 0; __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9236, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_data, __pyx_t_1) < 0) __PYX_ERR(0, 9233, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_return, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9233, __pyx_L1_error)
9237: ) -> Memory:
9238: r"""Backups a `write()` operation.
9239:
9240: Arguments:
9241: address (int):
9242: Address where to start writing data.
9243:
9244: data (bytes):
9245: Data to write.
9246:
9247: Returns:
9248: :obj:`Memory` list: Backup memory regions.
9249:
9250: See Also:
9251: :meth:`write`
9252: :meth:`write_restore`
9253: """
9254: cdef:
+9255: addr_t address_ = <addr_t>address
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9255, __pyx_L1_error) __pyx_v_address_ = ((addr_t)__pyx_t_1);
+9256: addr_t size = 1 if isinstance(data, int) else <addr_t>len(data)
__pyx_t_2 = PyInt_Check(__pyx_v_data); if ((__pyx_t_2 != 0)) { __pyx_t_1 = 1; } else { __pyx_t_3 = PyObject_Length(__pyx_v_data); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-1))) __PYX_ERR(0, 9256, __pyx_L1_error) __pyx_t_1 = ((addr_t)__pyx_t_3); } __pyx_v_size = __pyx_t_1;
9257:
+9258: CheckAddAddrU(address, size)
__pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9258, __pyx_L1_error) __pyx_t_4 = __pyx_f_11cbytesparse_1c_CheckAddAddrU(__pyx_t_1, __pyx_v_size); if (unlikely(__pyx_t_4 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 9258, __pyx_L1_error)
+9259: return Memory_Extract_(self._, address, address + size, 0, NULL, 1, True)
__Pyx_XDECREF(((PyObject *)__pyx_r)); __pyx_t_1 = __Pyx_PyInt_As_uint_fast64_t(__pyx_v_address); if (unlikely((__pyx_t_1 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9259, __pyx_L1_error) __pyx_t_5 = __Pyx_PyInt_From_uint_fast64_t(__pyx_v_size); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9259, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = PyNumber_Add(__pyx_v_address, __pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9259, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyInt_As_uint_fast64_t(__pyx_t_6); if (unlikely((__pyx_t_7 == ((addr_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 9259, __pyx_L1_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_6 = __pyx_f_11cbytesparse_1c_Memory_Extract_(__pyx_v_self->_, __pyx_t_1, __pyx_t_7, 0, NULL, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 9259, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); if (!(likely(((__pyx_t_6) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_6, __pyx_ptype_11cbytesparse_1c_Memory))))) __PYX_ERR(0, 9259, __pyx_L1_error) __pyx_r = ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_t_6); __pyx_t_6 = 0; goto __pyx_L0;
9260:
+9261: def write_restore(
/* Python wrapper */ static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_187write_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup); /*proto*/ static char __pyx_doc_11cbytesparse_1c_6Memory_186write_restore[] = "Memory.write_restore(self: Memory, Memory backup: Memory) -> None\nRestores a `write()` operation.\n\n Arguments:\n backup (:obj:`Memory`):\n Backup memory region to restore.\n\n See Also:\n :meth:`write`\n :meth:`write_backup`\n "; static PyMethodDef __pyx_mdef_11cbytesparse_1c_6Memory_187write_restore = {"write_restore", (PyCFunction)__pyx_pw_11cbytesparse_1c_6Memory_187write_restore, METH_O, __pyx_doc_11cbytesparse_1c_6Memory_186write_restore}; static PyObject *__pyx_pw_11cbytesparse_1c_6Memory_187write_restore(PyObject *__pyx_v_self, PyObject *__pyx_v_backup) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("write_restore (wrapper)", 0); if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_backup), __pyx_ptype_11cbytesparse_1c_Memory, 0, "backup", 0))) __PYX_ERR(0, 9263, __pyx_L1_error) __pyx_r = __pyx_pf_11cbytesparse_1c_6Memory_186write_restore(((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_self), ((struct __pyx_obj_11cbytesparse_1c_Memory *)__pyx_v_backup)); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_11cbytesparse_1c_6Memory_186write_restore(struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_self, struct __pyx_obj_11cbytesparse_1c_Memory *__pyx_v_backup) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("write_restore", 0); /* … */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_AddTraceback("cbytesparse.c.Memory.write_restore", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* … */ __pyx_tuple__210 = PyTuple_Pack(2, __pyx_n_s_self, __pyx_n_s_backup); if (unlikely(!__pyx_tuple__210)) __PYX_ERR(0, 9261, __pyx_L1_error) __Pyx_GOTREF(__pyx_tuple__210); __Pyx_GIVEREF(__pyx_tuple__210); /* … */ __pyx_t_1 = __Pyx_PyDict_NewPresized(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9261, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_self, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9261, __pyx_L1_error) if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_backup, __pyx_n_u_Memory) < 0) __PYX_ERR(0, 9261, __pyx_L1_error) /* … */ __pyx_t_5 = __Pyx_CyFunction_New(&__pyx_mdef_11cbytesparse_1c_6Memory_187write_restore, __Pyx_CYFUNCTION_CCLASS, __pyx_n_s_Memory_write_restore, NULL, __pyx_n_s_cbytesparse_c, __pyx_d, ((PyObject *)__pyx_codeobj__211)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 9261, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_CyFunction_SetAnnotationsDict(__pyx_t_5, __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_11cbytesparse_1c_Memory->tp_dict, __pyx_n_s_write_restore, __pyx_t_5) < 0) __PYX_ERR(0, 9261, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; PyType_Modified(__pyx_ptype_11cbytesparse_1c_Memory); __pyx_codeobj__211 = (PyObject*)__Pyx_PyCode_New(2, 0, 2, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__210, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_src_cbytesparse_c_pyx, __pyx_n_s_write_restore, 9261, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__211)) __PYX_ERR(0, 9261, __pyx_L1_error)
9262: self: Memory,
9263: Memory backup not None: Memory,
+9264: ) -> None:
if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_return, Py_None) < 0) __PYX_ERR(0, 9261, __pyx_L1_error)
9265: r"""Restores a `write()` operation.
9266:
9267: Arguments:
9268: backup (:obj:`Memory`):
9269: Backup memory region to restore.
9270:
9271: See Also:
9272: :meth:`write`
9273: :meth:`write_backup`
9274: """
9275:
+9276: Memory_Write(self._, 0, backup, True)
__pyx_t_1 = __pyx_f_11cbytesparse_1c_Memory_Write(__pyx_v_self->_, __pyx_int_0, ((PyObject *)__pyx_v_backup), 1); if (unlikely(__pyx_t_1 == ((__pyx_t_11cbytesparse_1c_vint)-1))) __PYX_ERR(0, 9276, __pyx_L1_error)
9277: