@rogolev/value 0.0.2 → 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (133) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/README.md +19 -1
  3. package/docs/classes/Value/constructor.md +48 -0
  4. package/docs/classes/Value/get.md +51 -0
  5. package/docs/classes/Value/getType.md +71 -0
  6. package/docs/classes/Value/isArray.md +67 -0
  7. package/docs/classes/Value/isAssoc.md +68 -0
  8. package/docs/classes/Value/isBigInt.md +52 -0
  9. package/docs/classes/Value/isBool.md +60 -0
  10. package/docs/classes/Value/isBoolean.md +60 -0
  11. package/docs/classes/Value/isClass.md +55 -0
  12. package/docs/classes/Value/isEmpty.md +84 -0
  13. package/docs/classes/Value/isFloat.md +52 -0
  14. package/docs/classes/Value/isFunction.md +60 -0
  15. package/docs/classes/Value/isInfinity.md +60 -0
  16. package/docs/classes/Value/isInt.md +52 -0
  17. package/docs/classes/Value/isInteger.md +52 -0
  18. package/docs/classes/Value/isList.md +59 -0
  19. package/docs/classes/Value/isNaN.md +79 -0
  20. package/docs/classes/Value/isNull.md +59 -0
  21. package/docs/classes/Value/isNumber.md +80 -0
  22. package/docs/classes/Value/isNumeric.md +79 -0
  23. package/docs/classes/Value/isObject.md +68 -0
  24. package/docs/classes/Value/isScalar.md +72 -0
  25. package/docs/classes/Value/isString.md +67 -0
  26. package/docs/classes/Value/isSymbol.md +75 -0
  27. package/docs/classes/Value/isUndefined.md +67 -0
  28. package/docs/classes/Value/print.md +164 -0
  29. package/docs/classes/Value/printType.md +158 -0
  30. package/docs/classes/Value/setType.md +79 -0
  31. package/docs/classes/Value/toArray.md +85 -0
  32. package/docs/classes/Value/toAssoc.md +85 -0
  33. package/docs/classes/Value/toBool.md +71 -0
  34. package/docs/classes/Value/toBoolean.md +71 -0
  35. package/docs/classes/Value/toFloat.md +72 -0
  36. package/docs/classes/Value/toInt.md +72 -0
  37. package/docs/classes/Value/toInteger.md +72 -0
  38. package/docs/classes/Value/toList.md +77 -0
  39. package/docs/classes/Value/toObject.md +78 -0
  40. package/docs/classes/Value/toPrint.md +115 -0
  41. package/docs/classes/Value/toPrintType.md +110 -0
  42. package/docs/classes/Value/toString.md +134 -0
  43. package/docs/classes/Value.md +113 -0
  44. package/docs/classes.md +2 -0
  45. package/docs/constants.md +47 -0
  46. package/docs/helpers/value.md +95 -0
  47. package/docs/helpers.md +2 -0
  48. package/index.mjs +3 -0
  49. package/package.json +2 -2
  50. package/src/classes/Convert.mjs +818 -819
  51. package/src/classes/Type.mjs +1284 -1285
  52. package/src/classes/Value.mjs +2846 -0
  53. package/src/constants.mjs +14 -0
  54. package/src/helpers/array.mjs +107 -107
  55. package/src/helpers/empty.mjs +70 -70
  56. package/src/helpers/gettype.mjs +149 -133
  57. package/src/helpers/is_array.mjs +128 -128
  58. package/src/helpers/is_assoc.mjs +51 -51
  59. package/src/helpers/is_bigint.mjs +47 -47
  60. package/src/helpers/is_bool.mjs +43 -43
  61. package/src/helpers/is_boolean.mjs +43 -43
  62. package/src/helpers/is_class.mjs +87 -87
  63. package/src/helpers/is_float.mjs +67 -67
  64. package/src/helpers/is_function.mjs +74 -74
  65. package/src/helpers/is_infinity.mjs +52 -52
  66. package/src/helpers/is_int.mjs +57 -57
  67. package/src/helpers/is_integer.mjs +74 -74
  68. package/src/helpers/is_list.mjs +43 -43
  69. package/src/helpers/is_nan.mjs +51 -51
  70. package/src/helpers/is_null.mjs +37 -37
  71. package/src/helpers/is_number.mjs +49 -49
  72. package/src/helpers/is_numeric.mjs +64 -64
  73. package/src/helpers/is_object.mjs +72 -72
  74. package/src/helpers/is_scalar.mjs +45 -45
  75. package/src/helpers/is_string.mjs +46 -46
  76. package/src/helpers/is_symbol.mjs +46 -46
  77. package/src/helpers/is_undefined.mjs +44 -44
  78. package/src/helpers/print.mjs +245 -245
  79. package/src/helpers/print_type.mjs +261 -261
  80. package/src/helpers/settype.mjs +101 -101
  81. package/src/helpers/to_array.mjs +118 -118
  82. package/src/helpers/to_assoc.mjs +98 -98
  83. package/src/helpers/to_bool.mjs +68 -68
  84. package/src/helpers/to_boolean.mjs +64 -64
  85. package/src/helpers/to_float.mjs +72 -72
  86. package/src/helpers/to_int.mjs +93 -93
  87. package/src/helpers/to_integer.mjs +81 -81
  88. package/src/helpers/to_list.mjs +56 -56
  89. package/src/helpers/to_object.mjs +94 -94
  90. package/src/helpers/to_string.mjs +157 -157
  91. package/src/helpers/value.mjs +92 -0
  92. package/tests/classes/Convert.test.mjs +398 -399
  93. package/tests/classes/Type.test.mjs +1262 -1263
  94. package/tests/classes/Value.test.mjs +423 -0
  95. package/tests/constants.test.mjs +75 -0
  96. package/tests/helpers/array.test.mjs +58 -58
  97. package/tests/helpers/empty.test.mjs +22 -22
  98. package/tests/helpers/gettype.test.mjs +74 -74
  99. package/tests/helpers/is_array.test.mjs +404 -404
  100. package/tests/helpers/is_assoc.test.mjs +42 -42
  101. package/tests/helpers/is_bigint.test.mjs +51 -51
  102. package/tests/helpers/is_bool.test.mjs +43 -43
  103. package/tests/helpers/is_boolean.test.mjs +43 -43
  104. package/tests/helpers/is_class.test.mjs +84 -84
  105. package/tests/helpers/is_float.test.mjs +87 -87
  106. package/tests/helpers/is_function.test.mjs +83 -83
  107. package/tests/helpers/is_infinity.test.mjs +46 -46
  108. package/tests/helpers/is_int.test.mjs +45 -45
  109. package/tests/helpers/is_integer.test.mjs +64 -64
  110. package/tests/helpers/is_list.test.mjs +42 -42
  111. package/tests/helpers/is_nan.test.mjs +43 -43
  112. package/tests/helpers/is_null.test.mjs +17 -17
  113. package/tests/helpers/is_number.test.mjs +25 -25
  114. package/tests/helpers/is_numeric.test.mjs +30 -30
  115. package/tests/helpers/is_object.test.mjs +52 -52
  116. package/tests/helpers/is_scalar.test.mjs +21 -21
  117. package/tests/helpers/is_string.test.mjs +20 -20
  118. package/tests/helpers/is_symbol.test.mjs +20 -20
  119. package/tests/helpers/is_undefined.test.mjs +18 -18
  120. package/tests/helpers/print.test.mjs +62 -62
  121. package/tests/helpers/print_type.test.mjs +62 -62
  122. package/tests/helpers/settype.test.mjs +34 -34
  123. package/tests/helpers/to_array.test.mjs +38 -38
  124. package/tests/helpers/to_assoc.test.mjs +33 -33
  125. package/tests/helpers/to_bool.test.mjs +51 -51
  126. package/tests/helpers/to_boolean.test.mjs +51 -51
  127. package/tests/helpers/to_float.test.mjs +26 -26
  128. package/tests/helpers/to_int.test.mjs +48 -48
  129. package/tests/helpers/to_integer.test.mjs +48 -48
  130. package/tests/helpers/to_list.test.mjs +32 -32
  131. package/tests/helpers/to_object.test.mjs +36 -36
  132. package/tests/helpers/to_string.test.mjs +71 -71
  133. package/tests/helpers/value.test.mjs +68 -0
@@ -1,245 +1,245 @@
1
- import gettype from './gettype.mjs';
2
- import is_bool from './is_bool.mjs';
3
- import is_class from './is_class.mjs';
4
- import to_string from './to_string.mjs';
5
-
6
- function print_array(value) {
7
- let result = Array.isArray(value) ? '[' : '{';
8
-
9
- for (const [k, v] of Object.entries(value)) {
10
- result += `\n ${k}: ${print(v, true).replace(/\n/g, '\n ')},`;
11
- }
12
-
13
- return (result += (result.length > 1 ? '\n' : '') + (Array.isArray(value) ? ']' : '}'));
14
- }
15
-
16
- function print_object(value) {
17
- let result = `${to_string(value)} {`;
18
-
19
- let new_line = false;
20
-
21
- for (const [k, v] of Object.entries(value)) {
22
- new_line = true;
23
-
24
- result += `\n ${k} = ${print(v, true).replace(/\n/g, '\n ')};`;
25
- }
26
-
27
- return (result += `${new_line ? '\n' : ''}${Array.isArray(value) ? ']' : '}'}`);
28
- }
29
-
30
- function print_class(value) {
31
- const parent = Object.getPrototypeOf(value);
32
-
33
- let result = `class ${value.name ? `${value.name} ` : ''}${is_class(parent) ? `extends ${parent.name} ` : ''}{`;
34
-
35
- let new_line = false;
36
-
37
- for (const [k, v] of Object.entries(value)) {
38
- new_line = true;
39
-
40
- result += `\n ${k} = ${print(v, true).replace(/\n/g, '\n ')};`;
41
- }
42
-
43
- return (result += `${new_line ? '\n' : ''}}`);
44
- }
45
-
46
- function print_string(value) {
47
- return `"${value}"`;
48
- }
49
-
50
- /**
51
- * Преобразует значение переменной в строку и выводит его на консоль.
52
- *
53
- * ### Описание
54
- *
55
- * Функция `print` используется для преобразования различных типов данных в строку и вывода их на консоль. Она обрабатывает массивы, объекты, классы, функции, символы и другие типы данных, возвращая их строковое представление.
56
- *
57
- * ### Параметры
58
- *
59
- * - `value` (any)
60
- * Переменная, значение которой необходимо преобразовать в строку и вывести на консоль.
61
- *
62
- * - `return_result` (boolean)
63
- * Если `true`, функция возвращает строковое представление значения переменной.
64
- * Если `false`, функция выводит строковое представление значения переменной на консоль.
65
- *
66
- * ### Возвращаемое значение
67
- *
68
- * Возвращает строковое представление значения переменной, если параметр `return_result` равен `true`. В противном случае возвращает `undefined`.
69
- *
70
- * ### Примеры использования
71
- *
72
- * 1. Преобразование строки:
73
- *
74
- * ```js
75
- * print('example');
76
- * ```
77
- * Вывод:
78
- * ```txt
79
- * "example"
80
- * ```
81
- *
82
- * 2. Преобразование числа:
83
- *
84
- * ```js
85
- * print(123);
86
- * ```
87
- * Вывод:
88
- * ```txt
89
- * 123
90
- * ```
91
- *
92
- * 3. Преобразование булевых значений:
93
- *
94
- * ```js
95
- * print(true);
96
- * ```
97
- * Вывод:
98
- * ```txt
99
- * true
100
- * ```
101
- *
102
- * ```js
103
- * print(false);
104
- * ```
105
- * Вывод:
106
- * ```txt
107
- * false
108
- * ```
109
- *
110
- * 4. Преобразование null и undefined:
111
- *
112
- * ```js
113
- * print(null);
114
- * ```
115
- * Вывод:
116
- * ```txt
117
- * null
118
- * ```
119
- *
120
- * ```js
121
- * print(undefined);
122
- * ```
123
- * Вывод:
124
- * ```txt
125
- * undefined
126
- * ```
127
- *
128
- * 5. Преобразование массива:
129
- *
130
- * ```js
131
- * const arr = [1, 2, 3];
132
- * print(arr);
133
- * ```
134
- * Вывод:
135
- * ```txt
136
- * [
137
- * 0: 1,
138
- * 1: 2,
139
- * 2: 3,
140
- * ]
141
- * ```
142
- *
143
- * 6. Преобразование ассоциативного массива:
144
- *
145
- * ```js
146
- * const obj = { key: 'value' };
147
- * print(obj);
148
- * ```
149
- * Вывод:
150
- * ```txt
151
- * {
152
- * key: "value",
153
- * }
154
- * ```
155
- *
156
- * 7. Преобразование функции:
157
- *
158
- * ```js
159
- * const func = function() {};
160
- * print(func);
161
- * ```
162
- * Вывод:
163
- * ```txt
164
- * function func() {}
165
- * ```
166
- *
167
- * 8. Преобразование символа:
168
- *
169
- * ```js
170
- * const symbol = Symbol('example');
171
- * print(symbol);
172
- * ```
173
- * Вывод:
174
- * ```txt
175
- * Symbol(example)
176
- * ```
177
- *
178
- * 9. Преобразование класса:
179
- *
180
- * ```js
181
- * class MyClass {
182
- * static test = 'test';
183
- * }
184
- * print(MyClass);
185
- * ```
186
- * Вывод:
187
- * ```txt
188
- * class MyClass {
189
- * test = "test";
190
- * }
191
- * ```
192
- *
193
- * 10. Преобразование экземпляра класса:
194
- *
195
- * ```js
196
- * class MyClass {
197
- * test = 'test';
198
- * }
199
- * const instance = new MyClass();
200
- * print(instance);
201
- * ```
202
- * Вывод:
203
- * ```txt
204
- * object MyClass {
205
- * test = "test";
206
- * }
207
- * ```
208
- *
209
- * @param {any} value Переменная, значение которой необходимо преобразовать в строку и вывести на консоль.
210
- * @param {boolean} return_result Если `true`, функция возвращает строковое представление значения переменной. Если `false`, функция выводит строковое представление значения переменной на консоль.
211
- * @returns {string|undefined} Возвращает строковое представление значения переменной, если параметр `return_result` равен `true`. В противном случае возвращает `undefined`.
212
- */
213
- export default function print(value, return_result = false) {
214
- if (!is_bool(return_result)) {
215
- throw new TypeError('Параметр "return_result" должен быть логическим типом.');
216
- }
217
-
218
- let result = '';
219
-
220
- switch (gettype(value)) {
221
- case 'array':
222
- result = print_array(value);
223
- break;
224
- case 'object':
225
- result =
226
- value.toString() === '[object Object]' ? print_object(value) : value.toString();
227
- break;
228
- case 'class':
229
- result = print_class(value);
230
- break;
231
- case 'string':
232
- result = print_string(value);
233
- break;
234
- default:
235
- result = to_string(value);
236
- }
237
-
238
- if (return_result) {
239
- return result;
240
- }
241
-
242
- console.log(result);
243
-
244
- return undefined;
245
- }
1
+ import gettype from './gettype.mjs';
2
+ import is_bool from './is_bool.mjs';
3
+ import is_class from './is_class.mjs';
4
+ import to_string from './to_string.mjs';
5
+
6
+ function print_array(value) {
7
+ let result = Array.isArray(value) ? '[' : '{';
8
+
9
+ for (const [k, v] of Object.entries(value)) {
10
+ result += `\n ${k}: ${print(v, true).replace(/\n/g, '\n ')},`;
11
+ }
12
+
13
+ return (result += (result.length > 1 ? '\n' : '') + (Array.isArray(value) ? ']' : '}'));
14
+ }
15
+
16
+ function print_object(value) {
17
+ let result = `${to_string(value)} {`;
18
+
19
+ let new_line = false;
20
+
21
+ for (const [k, v] of Object.entries(value)) {
22
+ new_line = true;
23
+
24
+ result += `\n ${k} = ${print(v, true).replace(/\n/g, '\n ')};`;
25
+ }
26
+
27
+ return (result += `${new_line ? '\n' : ''}${Array.isArray(value) ? ']' : '}'}`);
28
+ }
29
+
30
+ function print_class(value) {
31
+ const parent = Object.getPrototypeOf(value);
32
+
33
+ let result = `class ${value.name ? `${value.name} ` : ''}${is_class(parent) ? `extends ${parent.name} ` : ''}{`;
34
+
35
+ let new_line = false;
36
+
37
+ for (const [k, v] of Object.entries(value)) {
38
+ new_line = true;
39
+
40
+ result += `\n ${k} = ${print(v, true).replace(/\n/g, '\n ')};`;
41
+ }
42
+
43
+ return (result += `${new_line ? '\n' : ''}}`);
44
+ }
45
+
46
+ function print_string(value) {
47
+ return `"${value}"`;
48
+ }
49
+
50
+ /**
51
+ * Преобразует значение переменной в строку и выводит его на консоль.
52
+ *
53
+ * ### Описание
54
+ *
55
+ * Функция `print` используется для преобразования различных типов данных в строку и вывода их на консоль. Она обрабатывает массивы, объекты, классы, функции, символы и другие типы данных, возвращая их строковое представление.
56
+ *
57
+ * ### Параметры
58
+ *
59
+ * - `value` (any)
60
+ * Переменная, значение которой необходимо преобразовать в строку и вывести на консоль.
61
+ *
62
+ * - `return_result` (boolean)
63
+ * Если `true`, функция возвращает строковое представление значения переменной.
64
+ * Если `false`, функция выводит строковое представление значения переменной на консоль.
65
+ *
66
+ * ### Возвращаемое значение
67
+ *
68
+ * Возвращает строковое представление значения переменной, если параметр `return_result` равен `true`. В противном случае возвращает `undefined`.
69
+ *
70
+ * ### Примеры использования
71
+ *
72
+ * 1. Преобразование строки:
73
+ *
74
+ * ```js
75
+ * print('example');
76
+ * ```
77
+ * Вывод:
78
+ * ```txt
79
+ * "example"
80
+ * ```
81
+ *
82
+ * 2. Преобразование числа:
83
+ *
84
+ * ```js
85
+ * print(123);
86
+ * ```
87
+ * Вывод:
88
+ * ```txt
89
+ * 123
90
+ * ```
91
+ *
92
+ * 3. Преобразование булевых значений:
93
+ *
94
+ * ```js
95
+ * print(true);
96
+ * ```
97
+ * Вывод:
98
+ * ```txt
99
+ * true
100
+ * ```
101
+ *
102
+ * ```js
103
+ * print(false);
104
+ * ```
105
+ * Вывод:
106
+ * ```txt
107
+ * false
108
+ * ```
109
+ *
110
+ * 4. Преобразование null и undefined:
111
+ *
112
+ * ```js
113
+ * print(null);
114
+ * ```
115
+ * Вывод:
116
+ * ```txt
117
+ * null
118
+ * ```
119
+ *
120
+ * ```js
121
+ * print(undefined);
122
+ * ```
123
+ * Вывод:
124
+ * ```txt
125
+ * undefined
126
+ * ```
127
+ *
128
+ * 5. Преобразование массива:
129
+ *
130
+ * ```js
131
+ * const arr = [1, 2, 3];
132
+ * print(arr);
133
+ * ```
134
+ * Вывод:
135
+ * ```txt
136
+ * [
137
+ * 0: 1,
138
+ * 1: 2,
139
+ * 2: 3,
140
+ * ]
141
+ * ```
142
+ *
143
+ * 6. Преобразование ассоциативного массива:
144
+ *
145
+ * ```js
146
+ * const obj = { key: 'value' };
147
+ * print(obj);
148
+ * ```
149
+ * Вывод:
150
+ * ```txt
151
+ * {
152
+ * key: "value",
153
+ * }
154
+ * ```
155
+ *
156
+ * 7. Преобразование функции:
157
+ *
158
+ * ```js
159
+ * const func = function() {};
160
+ * print(func);
161
+ * ```
162
+ * Вывод:
163
+ * ```txt
164
+ * function func() {}
165
+ * ```
166
+ *
167
+ * 8. Преобразование символа:
168
+ *
169
+ * ```js
170
+ * const symbol = Symbol('example');
171
+ * print(symbol);
172
+ * ```
173
+ * Вывод:
174
+ * ```txt
175
+ * Symbol(example)
176
+ * ```
177
+ *
178
+ * 9. Преобразование класса:
179
+ *
180
+ * ```js
181
+ * class MyClass {
182
+ * static test = 'test';
183
+ * }
184
+ * print(MyClass);
185
+ * ```
186
+ * Вывод:
187
+ * ```txt
188
+ * class MyClass {
189
+ * test = "test";
190
+ * }
191
+ * ```
192
+ *
193
+ * 10. Преобразование экземпляра класса:
194
+ *
195
+ * ```js
196
+ * class MyClass {
197
+ * test = 'test';
198
+ * }
199
+ * const instance = new MyClass();
200
+ * print(instance);
201
+ * ```
202
+ * Вывод:
203
+ * ```txt
204
+ * object MyClass {
205
+ * test = "test";
206
+ * }
207
+ * ```
208
+ *
209
+ * @param {any} value Переменная, значение которой необходимо преобразовать в строку и вывести на консоль.
210
+ * @param {boolean} return_result Если `true`, функция возвращает строковое представление значения переменной. Если `false`, функция выводит строковое представление значения переменной на консоль.
211
+ * @returns {string|undefined} Возвращает строковое представление значения переменной, если параметр `return_result` равен `true`. В противном случае возвращает `undefined`.
212
+ */
213
+ export default function print(value, return_result = false) {
214
+ if (!is_bool(return_result)) {
215
+ throw new TypeError('Параметр "return_result" должен быть логическим типом.');
216
+ }
217
+
218
+ let result = '';
219
+
220
+ switch (gettype(value)) {
221
+ case 'array':
222
+ result = print_array(value);
223
+ break;
224
+ case 'object':
225
+ result =
226
+ value.toString() === '[object Object]' ? print_object(value) : value.toString();
227
+ break;
228
+ case 'class':
229
+ result = print_class(value);
230
+ break;
231
+ case 'string':
232
+ result = print_string(value);
233
+ break;
234
+ default:
235
+ result = to_string(value);
236
+ }
237
+
238
+ if (return_result) {
239
+ return result;
240
+ }
241
+
242
+ console.log(result);
243
+
244
+ return undefined;
245
+ }