blob: fa634f90b0ebb071a308caf5d09108bb86312df8 [file] [log] [blame]
Damien George04b91472014-05-03 23:27:38 +01001/*
Alexander Steffen55f33242017-06-30 09:22:17 +02002 * This file is part of the MicroPython project, http://micropython.org/
Damien George04b91472014-05-03 23:27:38 +01003 *
4 * The MIT License (MIT)
5 *
6 * Copyright (c) 2013, 2014 Damien P. George
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files (the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 */
Alexander Steffen299bc622017-06-29 23:14:58 +020026#ifndef MICROPY_INCLUDED_PY_QSTR_H
27#define MICROPY_INCLUDED_PY_QSTR_H
Damien George9ddbe292014-12-29 01:02:19 +000028
29#include "py/mpconfig.h"
30#include "py/misc.h"
Damien George04b91472014-05-03 23:27:38 +010031
Chris Angelico29bf7392014-06-04 03:15:46 +100032// See qstrdefs.h for a list of qstr's that are available as constants.
Damien George55baff42014-01-21 21:40:13 +000033// Reference them as MP_QSTR_xxxx.
34//
stijnb9a35be2021-01-16 09:18:31 +010035// Note: it would be possible to define MP_QSTR_xxx as qstr_from_str("xxx")
Damien George55baff42014-01-21 21:40:13 +000036// for qstrs that are referenced this way, but you don't want to have them in ROM.
37
Josh Lloyd7d58a192019-09-25 17:53:30 +120038// first entry in enum will be MP_QSTRnull=0, which indicates invalid/no qstr
Damien George55baff42014-01-21 21:40:13 +000039enum {
Damien George69661f32020-02-27 15:36:53 +110040 #ifndef NO_QSTR
Artyom Skrobov18b1ba02021-05-03 14:17:36 -040041#define QDEF(id, hash, len, str) id,
Damien George69661f32020-02-27 15:36:53 +110042 #include "genhdr/qstrdefs.generated.h"
Damien George6942f802015-01-11 17:52:45 +000043#undef QDEF
Damien George69661f32020-02-27 15:36:53 +110044 #endif
Damien George0a2e9652016-01-31 22:24:16 +000045 MP_QSTRnumber_of, // no underscore so it can't clash with any of the above
Damien George2813cb62014-04-12 17:53:05 +010046};
Damien George55baff42014-01-21 21:40:13 +000047
Damien George6e2fb562015-12-17 12:45:22 +000048typedef size_t qstr;
Damien Georgef2040bf2021-10-22 22:22:47 +110049typedef uint16_t qstr_short_t;
Damien George55baff42014-01-21 21:40:13 +000050
Artyom Skrobov18b1ba02021-05-03 14:17:36 -040051#if MICROPY_QSTR_BYTES_IN_HASH == 1
52typedef uint8_t qstr_hash_t;
53#elif MICROPY_QSTR_BYTES_IN_HASH == 2
54typedef uint16_t qstr_hash_t;
55#else
56#error unimplemented qstr hash decoding
57#endif
58
59#if MICROPY_QSTR_BYTES_IN_LEN == 1
60typedef uint8_t qstr_len_t;
61#elif MICROPY_QSTR_BYTES_IN_LEN == 2
62typedef uint16_t qstr_len_t;
63#else
64#error unimplemented qstr length decoding
65#endif
66
Damien Georgeb4b10fd2015-01-01 23:30:53 +000067typedef struct _qstr_pool_t {
Artyom Skrobovf46a7142021-05-04 03:35:45 -040068 const struct _qstr_pool_t *prev;
Damien George25784852015-12-17 12:41:40 +000069 size_t total_prev_len;
70 size_t alloc;
71 size_t len;
Artyom Skrobov18b1ba02021-05-03 14:17:36 -040072 qstr_hash_t *hashes;
73 qstr_len_t *lengths;
74 const char *qstrs[];
Damien Georgeb4b10fd2015-01-01 23:30:53 +000075} qstr_pool_t;
76
Damien Georgea8775aa2018-02-15 18:12:01 +110077#define QSTR_TOTAL() (MP_STATE_VM(last_pool)->total_prev_len + MP_STATE_VM(last_pool)->len)
Damien George55baff42014-01-21 21:40:13 +000078
79void qstr_init(void);
80
Damien Georgec3f64d92015-11-27 12:23:18 +000081mp_uint_t qstr_compute_hash(const byte *data, size_t len);
Josh Lloyd7d58a192019-09-25 17:53:30 +120082qstr qstr_find_strn(const char *str, size_t str_len); // returns MP_QSTRnull if not found
Damien George5fa93b62014-01-22 14:35:10 +000083
Damien George55baff42014-01-21 21:40:13 +000084qstr qstr_from_str(const char *str);
Damien Georgec3f64d92015-11-27 12:23:18 +000085qstr qstr_from_strn(const char *str, size_t len);
Damien George55baff42014-01-21 21:40:13 +000086
Damien George40f3c022014-07-03 13:25:24 +010087mp_uint_t qstr_hash(qstr q);
Damien George2801e6f2015-04-04 15:53:11 +010088const char *qstr_str(qstr q);
Damien Georgec3f64d92015-11-27 12:23:18 +000089size_t qstr_len(qstr q);
90const byte *qstr_data(qstr q, size_t *len);
Damien George4d5b28c2014-01-29 18:56:46 +000091
Damien George25784852015-12-17 12:41:40 +000092void qstr_pool_info(size_t *n_pool, size_t *n_qstr, size_t *n_str_data_bytes, size_t *n_total_bytes);
Damien Georgeea0461d2015-02-10 11:02:28 +000093void qstr_dump_data(void);
Damien George9ddbe292014-12-29 01:02:19 +000094
Jim Mussared154b4eb2019-09-26 22:19:29 +100095#if MICROPY_ROM_TEXT_COMPRESSION
96void mp_decompress_rom_string(byte *dst, mp_rom_error_text_t src);
97#define MP_IS_COMPRESSED_ROM_STRING(s) (*(byte *)(s) == 0xff)
98#endif
99
Alexander Steffen299bc622017-06-29 23:14:58 +0200100#endif // MICROPY_INCLUDED_PY_QSTR_H