blob: ded105760c421b4052f50459abc0200246ea85a3 [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 George55baff42014-01-21 21:40:13 +000049
Artyom Skrobov18b1ba02021-05-03 14:17:36 -040050#if MICROPY_QSTR_BYTES_IN_HASH == 1
51typedef uint8_t qstr_hash_t;
52#elif MICROPY_QSTR_BYTES_IN_HASH == 2
53typedef uint16_t qstr_hash_t;
54#else
55#error unimplemented qstr hash decoding
56#endif
57
58#if MICROPY_QSTR_BYTES_IN_LEN == 1
59typedef uint8_t qstr_len_t;
60#elif MICROPY_QSTR_BYTES_IN_LEN == 2
61typedef uint16_t qstr_len_t;
62#else
63#error unimplemented qstr length decoding
64#endif
65
Damien Georgeb4b10fd2015-01-01 23:30:53 +000066typedef struct _qstr_pool_t {
Artyom Skrobovf46a7142021-05-04 03:35:45 -040067 const struct _qstr_pool_t *prev;
Damien George25784852015-12-17 12:41:40 +000068 size_t total_prev_len;
69 size_t alloc;
70 size_t len;
Artyom Skrobov18b1ba02021-05-03 14:17:36 -040071 qstr_hash_t *hashes;
72 qstr_len_t *lengths;
73 const char *qstrs[];
Damien Georgeb4b10fd2015-01-01 23:30:53 +000074} qstr_pool_t;
75
Damien Georgea8775aa2018-02-15 18:12:01 +110076#define QSTR_TOTAL() (MP_STATE_VM(last_pool)->total_prev_len + MP_STATE_VM(last_pool)->len)
Damien George55baff42014-01-21 21:40:13 +000077
78void qstr_init(void);
79
Damien Georgec3f64d92015-11-27 12:23:18 +000080mp_uint_t qstr_compute_hash(const byte *data, size_t len);
Josh Lloyd7d58a192019-09-25 17:53:30 +120081qstr qstr_find_strn(const char *str, size_t str_len); // returns MP_QSTRnull if not found
Damien George5fa93b62014-01-22 14:35:10 +000082
Damien George55baff42014-01-21 21:40:13 +000083qstr qstr_from_str(const char *str);
Damien Georgec3f64d92015-11-27 12:23:18 +000084qstr qstr_from_strn(const char *str, size_t len);
Damien George55baff42014-01-21 21:40:13 +000085
Damien George40f3c022014-07-03 13:25:24 +010086mp_uint_t qstr_hash(qstr q);
Damien George2801e6f2015-04-04 15:53:11 +010087const char *qstr_str(qstr q);
Damien Georgec3f64d92015-11-27 12:23:18 +000088size_t qstr_len(qstr q);
89const byte *qstr_data(qstr q, size_t *len);
Damien George4d5b28c2014-01-29 18:56:46 +000090
Damien George25784852015-12-17 12:41:40 +000091void 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 +000092void qstr_dump_data(void);
Damien George9ddbe292014-12-29 01:02:19 +000093
Jim Mussared154b4eb2019-09-26 22:19:29 +100094#if MICROPY_ROM_TEXT_COMPRESSION
95void mp_decompress_rom_string(byte *dst, mp_rom_error_text_t src);
96#define MP_IS_COMPRESSED_ROM_STRING(s) (*(byte *)(s) == 0xff)
97#endif
98
Alexander Steffen299bc622017-06-29 23:14:58 +020099#endif // MICROPY_INCLUDED_PY_QSTR_H