Christian Fraß commited on 2021-03-12 22:01:27
Zeige 22 geänderte Dateien mit 517 Einfügungen und 6161 Löschungen.
| ... | ... |
@@ -1,394 +0,0 @@ |
| 1 |
-declare module lib_call {
|
|
| 2 |
- /** |
|
| 3 |
- * @desc hacked class for postfix function application |
|
| 4 |
- * @author fenris |
|
| 5 |
- */ |
|
| 6 |
- class class_valuewrapper<type_value> {
|
|
| 7 |
- /** |
|
| 8 |
- * @author fenris |
|
| 9 |
- */ |
|
| 10 |
- protected value: type_value; |
|
| 11 |
- /** |
|
| 12 |
- * @desc [constructor] |
|
| 13 |
- * @author fenris |
|
| 14 |
- */ |
|
| 15 |
- constructor(value: type_value); |
|
| 16 |
- /** |
|
| 17 |
- * @desc [accessor] applies a function and returns a new valuewrapper |
|
| 18 |
- * @author fenris |
|
| 19 |
- */ |
|
| 20 |
- pass<type_value_>(function_: (value: type_value) => type_value_): class_valuewrapper<type_value_>; |
|
| 21 |
- /** |
|
| 22 |
- * @desc [accessor] gives the wrapped value |
|
| 23 |
- * @author fenris |
|
| 24 |
- */ |
|
| 25 |
- extract(): type_value; |
|
| 26 |
- } |
|
| 27 |
- /** |
|
| 28 |
- * @desc shortcut for constructing a valuewrapper-object |
|
| 29 |
- * @author fenris |
|
| 30 |
- */ |
|
| 31 |
- function vw<type_value>(value: type_value): class_valuewrapper<type_value>; |
|
| 32 |
- /** |
|
| 33 |
- * @author fenris |
|
| 34 |
- */ |
|
| 35 |
- function use<type_input, type_output>(input: type_input, function_: (input: type_input) => type_output): type_output; |
|
| 36 |
- /** |
|
| 37 |
- * @desc just the identity; useful for some callbacks etc. |
|
| 38 |
- * @author fenris |
|
| 39 |
- */ |
|
| 40 |
- function id<type_value>(x: type_value): type_value; |
|
| 41 |
- /** |
|
| 42 |
- * @desc composes two functions (i.e. returns a function that return the result of the successive execution of both input-functions) |
|
| 43 |
- * @param {function} function_f
|
|
| 44 |
- * @param {function} function_g
|
|
| 45 |
- * @author fenris |
|
| 46 |
- */ |
|
| 47 |
- function compose<type_x, type_y, type_z>(function_f: (type_x: any) => type_y, function_g: (type_y: any) => type_z): (value: type_x) => type_z; |
|
| 48 |
- /** |
|
| 49 |
- * @desc transforms a function with sequential input into a function with leveled input; example: add(2,3) = curryfy(add)(2)(3) |
|
| 50 |
- * @param {function} f
|
|
| 51 |
- * @param {int} n (don't set manually)
|
|
| 52 |
- * @return {function} the currified version of the in put function
|
|
| 53 |
- * @author fenris |
|
| 54 |
- */ |
|
| 55 |
- function curryfy(f: Function, n?: int): Function; |
|
| 56 |
-} |
|
| 57 |
-declare module lib_call {
|
|
| 58 |
- /** |
|
| 59 |
- * @author fenris |
|
| 60 |
- */ |
|
| 61 |
- type type_executor<type_result, type_reason> = ((resolve: (result?: type_result) => any, reject?: (reason?: type_reason) => void) => void); |
|
| 62 |
- /** |
|
| 63 |
- * @author fenris |
|
| 64 |
- */ |
|
| 65 |
- function executor_resolve<type_result, type_reason>(result: type_result): type_executor<type_result, type_reason>; |
|
| 66 |
- /** |
|
| 67 |
- * @author fenris |
|
| 68 |
- */ |
|
| 69 |
- function executor_reject<type_result, type_reason>(reason: type_reason): type_executor<type_result, type_reason>; |
|
| 70 |
- /** |
|
| 71 |
- * @author fenris |
|
| 72 |
- */ |
|
| 73 |
- function executor_transform<type_result_from, type_error_from, type_result_to, type_error_to>(executor: type_executor<type_result_from, type_error_from>, transform_result: (result_from: type_result_from) => type_result_to, transform_reason: (error_from: type_error_from) => type_error_to): type_executor<type_result_to, type_error_to>; |
|
| 74 |
- /** |
|
| 75 |
- * @author fenris |
|
| 76 |
- */ |
|
| 77 |
- function executor_transform_default<type_result_from, type_result_to>(executor: type_executor<type_result_from, Error>, transform_result: (result_from: type_result_from) => type_result_to, wrap_string?: string): type_executor<type_result_to, Error>; |
|
| 78 |
- /** |
|
| 79 |
- * @author fenris |
|
| 80 |
- */ |
|
| 81 |
- function executor_compose_sequential<type_result_first, type_result_second, type_reason>(first: type_executor<type_result_first, type_reason>, second: (result: type_result_first) => type_executor<type_result_second, type_reason>): type_executor<type_result_second, type_reason>; |
|
| 82 |
- /** |
|
| 83 |
- * @author fenris |
|
| 84 |
- */ |
|
| 85 |
- function executor_chain<type_state, type_error>(state: type_state, executors: Array<(state: type_state) => type_executor<type_state, type_error>>): type_executor<type_state, type_error>; |
|
| 86 |
- /** |
|
| 87 |
- * @author fenris |
|
| 88 |
- */ |
|
| 89 |
- function executor_first<type_result, type_reason>(executors: Array<type_executor<type_result, type_reason>>): type_executor<type_result, Array<type_reason>>; |
|
| 90 |
- /** |
|
| 91 |
- * @author fenris |
|
| 92 |
- */ |
|
| 93 |
- function executor_condense<type_element>(executors: Array<type_executor<type_element, Error>>): type_executor<Array<type_element>, Error>; |
|
| 94 |
- /** |
|
| 95 |
- * @author fenris |
|
| 96 |
- * @deprecated use condense |
|
| 97 |
- */ |
|
| 98 |
- function executor_filter<type_element>(executors: Array<type_executor<type_element, Error>>, predicate: (element: type_element) => boolean): type_executor<Array<type_element>, Error>; |
|
| 99 |
- /** |
|
| 100 |
- * @author fenris |
|
| 101 |
- * @deprecated use condense |
|
| 102 |
- */ |
|
| 103 |
- function executor_map<type_element1, type_element2>(executors: Array<type_executor<type_element1, Error>>, transformator: (element1: type_element1) => type_element2): type_executor<Array<type_element2>, Error>; |
|
| 104 |
- /** |
|
| 105 |
- * @author fenris |
|
| 106 |
- * @deprecated use condense |
|
| 107 |
- */ |
|
| 108 |
- function executor_reduce<type_element, type_result>(executors: Array<type_executor<type_element, Error>>, initial: type_result, accumulator: (result: type_result, element: type_element) => type_result): type_executor<type_result, Error>; |
|
| 109 |
-} |
|
| 110 |
-declare module lib_call {
|
|
| 111 |
- /** |
|
| 112 |
- * @author fenris |
|
| 113 |
- */ |
|
| 114 |
- type type_promise<type_result, type_reason> = Promise<type_result>; |
|
| 115 |
- /** |
|
| 116 |
- * @author fenris |
|
| 117 |
- */ |
|
| 118 |
- function promise_reject<type_result, type_reason>(reason: type_reason): type_promise<type_result, type_reason>; |
|
| 119 |
- /** |
|
| 120 |
- * @author fenris |
|
| 121 |
- */ |
|
| 122 |
- function promise_resolve<type_result, type_reason>(result: type_result): type_promise<type_result, type_reason>; |
|
| 123 |
- /** |
|
| 124 |
- * @author fenris |
|
| 125 |
- */ |
|
| 126 |
- function promise_make<type_result, type_reason>(executor: (resolve: (result?: type_result) => void, reject: (reason?: type_reason) => void) => void): type_promise<type_result, type_reason>; |
|
| 127 |
- /** |
|
| 128 |
- * @author fenris |
|
| 129 |
- */ |
|
| 130 |
- function promise_then_close<type_result, type_reason>(promise: type_promise<type_result, type_reason>, resolver: (result: type_result) => void, rejector: (reason: type_reason) => void): void; |
|
| 131 |
- /** |
|
| 132 |
- * @author fenris |
|
| 133 |
- */ |
|
| 134 |
- function promise_then_append<type_result, type_reason, type_result_>(promise: type_promise<type_result, type_reason>, resolver: (result: type_result) => type_promise<type_result_, type_reason>, rejector?: (reason: type_reason) => type_promise<type_result_, type_reason>): type_promise<type_result_, type_result>; |
|
| 135 |
- /** |
|
| 136 |
- * @author fenris |
|
| 137 |
- */ |
|
| 138 |
- function promise_all<type_result, type_reason>(promises: Array<type_promise<type_result, type_reason>>): type_promise<Array<type_result>, type_reason>; |
|
| 139 |
- /** |
|
| 140 |
- * @author fenris |
|
| 141 |
- */ |
|
| 142 |
- function promise_chain<type_result, type_reason>(promises: Array<(input: type_result) => type_promise<type_result, type_reason>>, start?: type_result): type_promise<type_result, type_reason>; |
|
| 143 |
- /** |
|
| 144 |
- * @author fenris |
|
| 145 |
- */ |
|
| 146 |
- function promise_condense<type_element, type_reason>(promises: Array<() => type_promise<type_element, type_reason>>): type_promise<Array<type_element>, type_reason>; |
|
| 147 |
- /** |
|
| 148 |
- * @author fenris |
|
| 149 |
- */ |
|
| 150 |
- function promise_group<type_reason>(promises: {
|
|
| 151 |
- [name: string]: () => type_promise<any, type_reason>; |
|
| 152 |
- }, serial?: boolean): type_promise<{
|
|
| 153 |
- [name: string]: any; |
|
| 154 |
- }, type_reason>; |
|
| 155 |
- /** |
|
| 156 |
- * @author fenris |
|
| 157 |
- */ |
|
| 158 |
- function promise_wrap<type_result_inner, type_result_outer, type_reason>(promise: type_promise<type_result_inner, type_reason>, transformator_result: (reason: type_result_inner) => type_result_outer, transformator_reason?: (reason: type_reason) => type_reason): type_promise<type_result_outer, type_reason>; |
|
| 159 |
- /** |
|
| 160 |
- * @author fenris |
|
| 161 |
- */ |
|
| 162 |
- function promise_show<type_result, type_reason>(label: string): (result: type_result) => type_promise<type_result, type_reason>; |
|
| 163 |
- /** |
|
| 164 |
- * @author fenris |
|
| 165 |
- */ |
|
| 166 |
- function promise_log<type_result, type_reason>(result: type_result): (result: type_result) => type_promise<type_result, type_reason>; |
|
| 167 |
- /** |
|
| 168 |
- * @author fenris |
|
| 169 |
- */ |
|
| 170 |
- function promise_attach<type_reason>(state: {
|
|
| 171 |
- [name: string]: any; |
|
| 172 |
- }, promise: type_promise<any, type_reason>, name: string): type_promise<{
|
|
| 173 |
- [name: string]: any; |
|
| 174 |
- }, type_reason>; |
|
| 175 |
- /** |
|
| 176 |
- * @author fenris |
|
| 177 |
- */ |
|
| 178 |
- function promise_delay<type_result, type_reason>(promise: type_promise<type_result, type_reason>, delay: int): type_promise<type_result, type_reason>; |
|
| 179 |
- /** |
|
| 180 |
- * @author fenris |
|
| 181 |
- */ |
|
| 182 |
- function promise_to_executor<type_result, type_reason>(promise: type_promise<type_result, type_reason>): type_executor<type_result, type_reason>; |
|
| 183 |
-} |
|
| 184 |
-declare module lib_call {
|
|
| 185 |
- /** |
|
| 186 |
- * @author fenris |
|
| 187 |
- */ |
|
| 188 |
- type type_initializer_state = int; |
|
| 189 |
- const initializer_state_initial: type_initializer_state; |
|
| 190 |
- const initializer_state_waiting: type_initializer_state; |
|
| 191 |
- const initializer_state_successful: type_initializer_state; |
|
| 192 |
- const initializer_state_failed: type_initializer_state; |
|
| 193 |
- /** |
|
| 194 |
- * @author fenris |
|
| 195 |
- */ |
|
| 196 |
- type type_initializer<type_result, type_reason> = {
|
|
| 197 |
- fetcher: () => type_promise<type_result, type_reason>; |
|
| 198 |
- state?: type_initializer_state; |
|
| 199 |
- queue: Array<{
|
|
| 200 |
- resolve: (result?: type_result) => void; |
|
| 201 |
- reject: (reason?: type_reason) => void; |
|
| 202 |
- }>; |
|
| 203 |
- result?: type_result; |
|
| 204 |
- reason?: type_reason; |
|
| 205 |
- }; |
|
| 206 |
- /** |
|
| 207 |
- * @author fenris |
|
| 208 |
- */ |
|
| 209 |
- function initializer_make<type_result, type_reason>(fetcher: () => type_promise<type_result, type_reason>): type_initializer<type_result, type_reason>; |
|
| 210 |
- /** |
|
| 211 |
- * @author fenris |
|
| 212 |
- */ |
|
| 213 |
- function initializer_reset<type_result, type_reason>(subject: type_initializer<type_result, type_reason>): void; |
|
| 214 |
- /** |
|
| 215 |
- * @author fenris |
|
| 216 |
- */ |
|
| 217 |
- function initializer_state<type_result, type_reason>(subject: type_initializer<type_result, type_reason>): type_initializer_state; |
|
| 218 |
- /** |
|
| 219 |
- * @author fenris |
|
| 220 |
- */ |
|
| 221 |
- function initializer_get<type_result, type_reason>(subject: type_initializer<type_result, type_reason>): type_promise<type_result, type_reason>; |
|
| 222 |
-} |
|
| 223 |
-declare module lib_call {
|
|
| 224 |
- /** |
|
| 225 |
- * @author fenris |
|
| 226 |
- */ |
|
| 227 |
- type type_deferral<type_input, type_output> = {
|
|
| 228 |
- representation: (input: type_input) => Promise<type_output>; |
|
| 229 |
- }; |
|
| 230 |
- /** |
|
| 231 |
- * @author fenris |
|
| 232 |
- * @desc activates the deferral and handles its output according to a given procedure |
|
| 233 |
- * @param {(value : type_value)=>void} procedure a function which receives the output of the deferral as argument
|
|
| 234 |
- */ |
|
| 235 |
- function deferral_use<type_input, type_output>(deferral: type_deferral<type_input, type_output>, input: type_input, procedure: (output: type_output) => void): void; |
|
| 236 |
- /** |
|
| 237 |
- * @author fenris |
|
| 238 |
- * @desc creates a deferral-subject (similar to "new Promise", where "convey" reflects "resolve"/"reject") |
|
| 239 |
- */ |
|
| 240 |
- function deferral_make<type_input, type_output>(handler: (input: type_input, convey: (output: type_output) => void) => void): type_deferral<type_input, type_output>; |
|
| 241 |
- /** |
|
| 242 |
- * @author fenris |
|
| 243 |
- * @desc wraps a simple function into a deferral (similar to "Promise.resolve"/"Promise.reject") |
|
| 244 |
- */ |
|
| 245 |
- function deferral_wrap<type_input, type_output>(function_: (input: type_input) => type_output): type_deferral<type_input, type_output>; |
|
| 246 |
- /** |
|
| 247 |
- * @author fenris |
|
| 248 |
- */ |
|
| 249 |
- function deferral_id<type_value>(): type_deferral<type_value, type_value>; |
|
| 250 |
- /** |
|
| 251 |
- * @author fenris |
|
| 252 |
- */ |
|
| 253 |
- function deferral_const<type_value>(value: type_value): type_deferral<type_value, type_value>; |
|
| 254 |
- /** |
|
| 255 |
- * @author fenris |
|
| 256 |
- */ |
|
| 257 |
- function deferral_delay<type_output>(output: type_output, delay: int): type_deferral<any, type_output>; |
|
| 258 |
- /** |
|
| 259 |
- * @author fenris |
|
| 260 |
- * @desc connects two deferrals to form a new one; the output of the first is taken as input for the second |
|
| 261 |
- * (similar to "Promise.then" when passing a function which returns a new promise) |
|
| 262 |
- * @param {type_deferral<type_value1>} first a simple deferral
|
|
| 263 |
- * @param {(value1 : type_value1)=>type_deferral<type_value2>} second a function depending from a value returning a deferral
|
|
| 264 |
- */ |
|
| 265 |
- function deferral_compose_serial<type_input, type_between, type_output>(first: type_deferral<type_input, type_between>, second: type_deferral<type_between, type_output>): type_deferral<type_input, type_output>; |
|
| 266 |
- /** |
|
| 267 |
- * @author fenris |
|
| 268 |
- */ |
|
| 269 |
- function deferral_compose_parallel<type_input, type_output_left, type_output_right>({ "left": deferral_left, "right": deferral_right, }: {
|
|
| 270 |
- left: type_deferral<type_input, type_output_left>; |
|
| 271 |
- right: type_deferral<type_input, type_output_right>; |
|
| 272 |
- }): type_deferral<type_input, {
|
|
| 273 |
- left: type_output_left; |
|
| 274 |
- right: type_output_right; |
|
| 275 |
- }>; |
|
| 276 |
- /** |
|
| 277 |
- * @author fenris |
|
| 278 |
- * @desc repeatedly applied serial composition |
|
| 279 |
- */ |
|
| 280 |
- function deferral_chain<type_value>(members: Array<type_deferral<type_value, type_value>>): type_deferral<type_value, type_value>; |
|
| 281 |
- /** |
|
| 282 |
- * @author fenris |
|
| 283 |
- */ |
|
| 284 |
-} |
|
| 285 |
-declare module lib_call {
|
|
| 286 |
- /** |
|
| 287 |
- * @author fenris |
|
| 288 |
- */ |
|
| 289 |
- class class_deferral<type_input, type_output> {
|
|
| 290 |
- /** |
|
| 291 |
- * @author fenris |
|
| 292 |
- */ |
|
| 293 |
- private subject; |
|
| 294 |
- /** |
|
| 295 |
- * @author fenris |
|
| 296 |
- */ |
|
| 297 |
- private constructor(); |
|
| 298 |
- /** |
|
| 299 |
- * @author fenris |
|
| 300 |
- */ |
|
| 301 |
- private static _cram; |
|
| 302 |
- /** |
|
| 303 |
- * @author fenris |
|
| 304 |
- */ |
|
| 305 |
- private static _tear; |
|
| 306 |
- /** |
|
| 307 |
- * @author fenris |
|
| 308 |
- */ |
|
| 309 |
- static make<type_input, type_output>(handler: (input: type_input, convey: (value: type_output) => void) => void): class_deferral<type_input, type_output>; |
|
| 310 |
- /** |
|
| 311 |
- * @author fenris |
|
| 312 |
- */ |
|
| 313 |
- use(input: type_input, procedure: (value: type_output) => void): void; |
|
| 314 |
- /** |
|
| 315 |
- * @author fenris |
|
| 316 |
- */ |
|
| 317 |
- compose_serial<type_output_>(second: class_deferral<type_output, type_output_>): class_deferral<type_input, type_output_>; |
|
| 318 |
- /** |
|
| 319 |
- * @author fenris |
|
| 320 |
- */ |
|
| 321 |
- static chain<type_value>(members: Array<class_deferral<type_value, type_value>>): class_deferral<type_value, type_value>; |
|
| 322 |
- /** |
|
| 323 |
- * @author fenris |
|
| 324 |
- */ |
|
| 325 |
- static wrap<type_input, type_output>(function_: (input: type_input) => type_output): class_deferral<type_input, type_output>; |
|
| 326 |
- /** |
|
| 327 |
- * @author fenris |
|
| 328 |
- */ |
|
| 329 |
- static const_<type_value>(value: type_value): class_deferral<type_value, type_value>; |
|
| 330 |
- /** |
|
| 331 |
- * @author fenris |
|
| 332 |
- */ |
|
| 333 |
- static delay<type_output>(output: type_output, delay: int): class_deferral<any, type_output>; |
|
| 334 |
- } |
|
| 335 |
-} |
|
| 336 |
-declare module lib_call {
|
|
| 337 |
- /** |
|
| 338 |
- * @author fenris |
|
| 339 |
- */ |
|
| 340 |
- function timeout(function_: () => void, delay: int): int; |
|
| 341 |
- /** |
|
| 342 |
- * @desc a definition for a value being "defined" |
|
| 343 |
- * @author neuc |
|
| 344 |
- */ |
|
| 345 |
- function is_def<type_value>(obj: type_value, null_is_valid?: boolean): boolean; |
|
| 346 |
- /** |
|
| 347 |
- * @desc returns the value if set and, when a type is specified, if the type is correct, if not return default_value |
|
| 348 |
- * @author neuc |
|
| 349 |
- */ |
|
| 350 |
- function def_val(value: any, default_value: any, type?: string, null_is_valid?: boolean): any; |
|
| 351 |
- /** |
|
| 352 |
- * @desc just the empty function; useful for some callbacks etc. |
|
| 353 |
- * @author fenris |
|
| 354 |
- */ |
|
| 355 |
- function nothing(): void; |
|
| 356 |
- /** |
|
| 357 |
- * @desc outputs |
|
| 358 |
- * @author fenris |
|
| 359 |
- */ |
|
| 360 |
- function output(...args: Array<any>): void; |
|
| 361 |
- /** |
|
| 362 |
- * @desc converts the "arguments"-map into an array |
|
| 363 |
- * @param {Object} args
|
|
| 364 |
- * @author fenris |
|
| 365 |
- */ |
|
| 366 |
- function args2list(args: any): Array<any>; |
|
| 367 |
- /** |
|
| 368 |
- * @desc provides the call for an attribute of a class as a regular function |
|
| 369 |
- * @param {string} name the name of the attribute
|
|
| 370 |
- * @return {*}
|
|
| 371 |
- * @author fenris |
|
| 372 |
- */ |
|
| 373 |
- function attribute<type_object, type_attribute>(name: string): (object: type_object) => type_attribute; |
|
| 374 |
- /** |
|
| 375 |
- * @desc provides a method of a class as a regular function |
|
| 376 |
- * @param {string} name the name of the method
|
|
| 377 |
- * @return {function}
|
|
| 378 |
- * @author fenris |
|
| 379 |
- */ |
|
| 380 |
- function method<type_object, type_output>(name: string): (object: type_object) => type_output; |
|
| 381 |
- /** |
|
| 382 |
- * @author fenris |
|
| 383 |
- */ |
|
| 384 |
- type type_unival = {
|
|
| 385 |
- kind: string; |
|
| 386 |
- data?: any; |
|
| 387 |
- }; |
|
| 388 |
- /** |
|
| 389 |
- * @author fenris |
|
| 390 |
- */ |
|
| 391 |
- function distinguish(unival: type_unival, handlers: {
|
|
| 392 |
- [kind: string]: (data?: any) => any; |
|
| 393 |
- }, fallback?: (unival?: type_unival) => any): any; |
|
| 394 |
-} |
| ... | ... |
@@ -1,992 +0,0 @@ |
| 1 |
-/* |
|
| 2 |
-This file is part of »bacterio-plankton:call«. |
|
| 3 |
- |
|
| 4 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 5 |
-<info@greenscale.de> |
|
| 6 |
- |
|
| 7 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 8 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 9 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 10 |
-(at your option) any later version. |
|
| 11 |
- |
|
| 12 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 13 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 14 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 15 |
-GNU Lesser General Public License for more details. |
|
| 16 |
- |
|
| 17 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 18 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 19 |
- */ |
|
| 20 |
-"use strict"; |
|
| 21 |
-/* |
|
| 22 |
-This file is part of »bacterio-plankton:call«. |
|
| 23 |
- |
|
| 24 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 25 |
-<info@greenscale.de> |
|
| 26 |
- |
|
| 27 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 28 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 29 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 30 |
-(at your option) any later version. |
|
| 31 |
- |
|
| 32 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 33 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 34 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 35 |
-GNU Lesser General Public License for more details. |
|
| 36 |
- |
|
| 37 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 38 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 39 |
- */ |
|
| 40 |
-var lib_call; |
|
| 41 |
-(function (lib_call) {
|
|
| 42 |
- /** |
|
| 43 |
- * @desc hacked class for postfix function application |
|
| 44 |
- * @author fenris |
|
| 45 |
- */ |
|
| 46 |
- class class_valuewrapper {
|
|
| 47 |
- /** |
|
| 48 |
- * @desc [constructor] |
|
| 49 |
- * @author fenris |
|
| 50 |
- */ |
|
| 51 |
- constructor(value) {
|
|
| 52 |
- this.value = value; |
|
| 53 |
- } |
|
| 54 |
- /** |
|
| 55 |
- * @desc [accessor] applies a function and returns a new valuewrapper |
|
| 56 |
- * @author fenris |
|
| 57 |
- */ |
|
| 58 |
- pass(function_) {
|
|
| 59 |
- return (new class_valuewrapper(function_(this.value))); |
|
| 60 |
- } |
|
| 61 |
- /** |
|
| 62 |
- * @desc [accessor] gives the wrapped value |
|
| 63 |
- * @author fenris |
|
| 64 |
- */ |
|
| 65 |
- extract() {
|
|
| 66 |
- return this.value; |
|
| 67 |
- } |
|
| 68 |
- } |
|
| 69 |
- lib_call.class_valuewrapper = class_valuewrapper; |
|
| 70 |
- /** |
|
| 71 |
- * @desc shortcut for constructing a valuewrapper-object |
|
| 72 |
- * @author fenris |
|
| 73 |
- */ |
|
| 74 |
- function vw(value) {
|
|
| 75 |
- return (new class_valuewrapper(value)); |
|
| 76 |
- } |
|
| 77 |
- lib_call.vw = vw; |
|
| 78 |
- /** |
|
| 79 |
- * @author fenris |
|
| 80 |
- */ |
|
| 81 |
- function use(input, function_) {
|
|
| 82 |
- return function_(input); |
|
| 83 |
- } |
|
| 84 |
- lib_call.use = use; |
|
| 85 |
- /** |
|
| 86 |
- * @desc just the identity; useful for some callbacks etc. |
|
| 87 |
- * @author fenris |
|
| 88 |
- */ |
|
| 89 |
- function id(x) {
|
|
| 90 |
- return x; |
|
| 91 |
- } |
|
| 92 |
- lib_call.id = id; |
|
| 93 |
- /** |
|
| 94 |
- * @desc composes two functions (i.e. returns a function that return the result of the successive execution of both input-functions) |
|
| 95 |
- * @param {function} function_f
|
|
| 96 |
- * @param {function} function_g
|
|
| 97 |
- * @author fenris |
|
| 98 |
- */ |
|
| 99 |
- function compose(function_f, function_g) {
|
|
| 100 |
- return (function (x) {
|
|
| 101 |
- // return function_g(function_f(x)); |
|
| 102 |
- return function_g(function_f.apply(function_f, lib_call.args2list(arguments))); |
|
| 103 |
- }); |
|
| 104 |
- } |
|
| 105 |
- lib_call.compose = compose; |
|
| 106 |
- /** |
|
| 107 |
- * @desc transforms a function with sequential input into a function with leveled input; example: add(2,3) = curryfy(add)(2)(3) |
|
| 108 |
- * @param {function} f
|
|
| 109 |
- * @param {int} n (don't set manually)
|
|
| 110 |
- * @return {function} the currified version of the in put function
|
|
| 111 |
- * @author fenris |
|
| 112 |
- */ |
|
| 113 |
- function curryfy(f, n = f.length) {
|
|
| 114 |
- switch (n) {
|
|
| 115 |
- case 0: {
|
|
| 116 |
- throw (new Error("[curryfy] impossible"));
|
|
| 117 |
- // break; |
|
| 118 |
- } |
|
| 119 |
- case 1: {
|
|
| 120 |
- return f; |
|
| 121 |
- // break; |
|
| 122 |
- } |
|
| 123 |
- default: {
|
|
| 124 |
- return (function (x) {
|
|
| 125 |
- return (curryfy(function () { return f.apply(f, [x].concat(lib_call.args2list(arguments))); }, n - 1));
|
|
| 126 |
- }); |
|
| 127 |
- // break; |
|
| 128 |
- } |
|
| 129 |
- } |
|
| 130 |
- } |
|
| 131 |
- lib_call.curryfy = curryfy; |
|
| 132 |
-})(lib_call || (lib_call = {}));
|
|
| 133 |
-var lib_call; |
|
| 134 |
-(function (lib_call) {
|
|
| 135 |
- /** |
|
| 136 |
- * @author fenris |
|
| 137 |
- */ |
|
| 138 |
- function executor_resolve(result) {
|
|
| 139 |
- return ((resolve, reject) => resolve(result)); |
|
| 140 |
- } |
|
| 141 |
- lib_call.executor_resolve = executor_resolve; |
|
| 142 |
- /** |
|
| 143 |
- * @author fenris |
|
| 144 |
- */ |
|
| 145 |
- function executor_reject(reason) {
|
|
| 146 |
- return ((resolve, reject) => reject(reason)); |
|
| 147 |
- } |
|
| 148 |
- lib_call.executor_reject = executor_reject; |
|
| 149 |
- /** |
|
| 150 |
- * @author fenris |
|
| 151 |
- */ |
|
| 152 |
- function executor_transform(executor, transform_result, transform_reason) {
|
|
| 153 |
- return ((resolve, reject) => {
|
|
| 154 |
- executor(result => resolve(transform_result(result)), reason => reject(transform_reason(reason))); |
|
| 155 |
- }); |
|
| 156 |
- } |
|
| 157 |
- lib_call.executor_transform = executor_transform; |
|
| 158 |
- /** |
|
| 159 |
- * @author fenris |
|
| 160 |
- */ |
|
| 161 |
- function executor_transform_default(executor, transform_result, wrap_string = null) {
|
|
| 162 |
- let transform_reason = (error => ((wrap_string == null) ? error : new class_error(wrap_string, [error]))); |
|
| 163 |
- return (executor_transform(executor, transform_result, transform_reason)); |
|
| 164 |
- } |
|
| 165 |
- lib_call.executor_transform_default = executor_transform_default; |
|
| 166 |
- /** |
|
| 167 |
- * @author fenris |
|
| 168 |
- */ |
|
| 169 |
- function executor_compose_sequential(first, second) {
|
|
| 170 |
- return ((resolve, reject) => {
|
|
| 171 |
- first(result => {
|
|
| 172 |
- second(result)(resolve, reject); |
|
| 173 |
- }, reason => {
|
|
| 174 |
- reject(reason); |
|
| 175 |
- }); |
|
| 176 |
- }); |
|
| 177 |
- } |
|
| 178 |
- lib_call.executor_compose_sequential = executor_compose_sequential; |
|
| 179 |
- /** |
|
| 180 |
- * @author fenris |
|
| 181 |
- */ |
|
| 182 |
- function executor_chain(state, executors) {
|
|
| 183 |
- return ((resolve, reject) => {
|
|
| 184 |
- if (executors.length == 0) {
|
|
| 185 |
- return resolve(state); |
|
| 186 |
- } |
|
| 187 |
- else {
|
|
| 188 |
- return executors[0](state)(result => {
|
|
| 189 |
- executor_chain(result, executors.slice(1))(resolve, reject); |
|
| 190 |
- }, reject); |
|
| 191 |
- } |
|
| 192 |
- }); |
|
| 193 |
- /* |
|
| 194 |
- */ |
|
| 195 |
- /* |
|
| 196 |
- if (executors.length == 0) {
|
|
| 197 |
- return executor_resolve<type_state, type_error>(state); |
|
| 198 |
- } |
|
| 199 |
- else if (executors.length == 1) {
|
|
| 200 |
- return executors[0](state); |
|
| 201 |
- } |
|
| 202 |
- else {
|
|
| 203 |
- return ( |
|
| 204 |
- executor_chain<type_state, type_error>( |
|
| 205 |
- state, |
|
| 206 |
- [ |
|
| 207 |
- state => (resolve, reject) => executors[0](state)(result => executors[1](result)(resolve, reject), reject) |
|
| 208 |
- ].concat(executors.slice(2)) |
|
| 209 |
- ) |
|
| 210 |
- ); |
|
| 211 |
- } |
|
| 212 |
- */ |
|
| 213 |
- /* |
|
| 214 |
- return ( |
|
| 215 |
- executors.reduce( |
|
| 216 |
- (chain, current) => executor_compose_sequential<type_state, type_state, type_error>(chain, current, deferred), |
|
| 217 |
- executor_resolve<type_state, type_error>(state) |
|
| 218 |
- ) |
|
| 219 |
- ); |
|
| 220 |
- */ |
|
| 221 |
- } |
|
| 222 |
- lib_call.executor_chain = executor_chain; |
|
| 223 |
- /** |
|
| 224 |
- * @author fenris |
|
| 225 |
- */ |
|
| 226 |
- function executor_first(executors) {
|
|
| 227 |
- /* |
|
| 228 |
- return ( |
|
| 229 |
- (resolve, reject) => {
|
|
| 230 |
- if (executors.length == 0) {
|
|
| 231 |
- reject(new Error("all failed"));
|
|
| 232 |
- } |
|
| 233 |
- else {
|
|
| 234 |
- executors[0]( |
|
| 235 |
- result => {
|
|
| 236 |
- resolve(result); |
|
| 237 |
- }, |
|
| 238 |
- reason => {
|
|
| 239 |
- executor_first<type_result, type_reason>(executors.slice(1))(resolve, reject); |
|
| 240 |
- } |
|
| 241 |
- ) |
|
| 242 |
- } |
|
| 243 |
- } |
|
| 244 |
- ); |
|
| 245 |
- */ |
|
| 246 |
- return ((resolve, reject) => {
|
|
| 247 |
- executor_chain([], executors.map(executor => reasons => (resolve_, reject_) => {
|
|
| 248 |
- executor(result => reject_(result), reason => resolve_(reasons.concat([reason]))); |
|
| 249 |
- }))(errors => reject(errors), result => resolve(result)); |
|
| 250 |
- }); |
|
| 251 |
- } |
|
| 252 |
- lib_call.executor_first = executor_first; |
|
| 253 |
- /** |
|
| 254 |
- * @author fenris |
|
| 255 |
- */ |
|
| 256 |
- function executor_condense(executors) {
|
|
| 257 |
- return (executor_chain([], executors.map(executor => result => (resolve, reject) => {
|
|
| 258 |
- executor(element => resolve(result.concat([element])), reject); |
|
| 259 |
- }))); |
|
| 260 |
- } |
|
| 261 |
- lib_call.executor_condense = executor_condense; |
|
| 262 |
- /** |
|
| 263 |
- * @author fenris |
|
| 264 |
- * @deprecated use condense |
|
| 265 |
- */ |
|
| 266 |
- function executor_filter(executors, predicate) {
|
|
| 267 |
- return (executor_chain([], executors.map(executor => result => (resolve, reject) => {
|
|
| 268 |
- executor(element => resolve(predicate(element) ? result.concat([element]) : result), reject); |
|
| 269 |
- }))); |
|
| 270 |
- } |
|
| 271 |
- lib_call.executor_filter = executor_filter; |
|
| 272 |
- /** |
|
| 273 |
- * @author fenris |
|
| 274 |
- * @deprecated use condense |
|
| 275 |
- */ |
|
| 276 |
- function executor_map(executors, transformator) {
|
|
| 277 |
- return (executor_chain([], executors.map(executor => result => (resolve, reject) => {
|
|
| 278 |
- executor(element1 => resolve(result.concat([transformator(element1)])), reject); |
|
| 279 |
- }))); |
|
| 280 |
- } |
|
| 281 |
- lib_call.executor_map = executor_map; |
|
| 282 |
- /** |
|
| 283 |
- * @author fenris |
|
| 284 |
- * @deprecated use condense |
|
| 285 |
- */ |
|
| 286 |
- function executor_reduce(executors, initial, accumulator) {
|
|
| 287 |
- return (executor_chain(initial, executors.map(executor => result => (resolve, reject) => {
|
|
| 288 |
- executor(element => resolve(accumulator(result, element)), reject); |
|
| 289 |
- }))); |
|
| 290 |
- } |
|
| 291 |
- lib_call.executor_reduce = executor_reduce; |
|
| 292 |
-})(lib_call || (lib_call = {}));
|
|
| 293 |
-/* |
|
| 294 |
-This file is part of »bacterio-plankton:call«. |
|
| 295 |
- |
|
| 296 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 297 |
-<info@greenscale.de> |
|
| 298 |
- |
|
| 299 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 300 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 301 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 302 |
-(at your option) any later version. |
|
| 303 |
- |
|
| 304 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 305 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 306 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 307 |
-GNU Lesser General Public License for more details. |
|
| 308 |
- |
|
| 309 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 310 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 311 |
- */ |
|
| 312 |
-var lib_call; |
|
| 313 |
-(function (lib_call) {
|
|
| 314 |
- /** |
|
| 315 |
- * @author fenris |
|
| 316 |
- */ |
|
| 317 |
- function promise_reject(reason) {
|
|
| 318 |
- return Promise.reject(reason); |
|
| 319 |
- } |
|
| 320 |
- lib_call.promise_reject = promise_reject; |
|
| 321 |
- /** |
|
| 322 |
- * @author fenris |
|
| 323 |
- */ |
|
| 324 |
- function promise_resolve(result) {
|
|
| 325 |
- return Promise.resolve(result); |
|
| 326 |
- } |
|
| 327 |
- lib_call.promise_resolve = promise_resolve; |
|
| 328 |
- /** |
|
| 329 |
- * @author fenris |
|
| 330 |
- */ |
|
| 331 |
- function promise_make(executor) {
|
|
| 332 |
- return (new Promise(executor)); |
|
| 333 |
- } |
|
| 334 |
- lib_call.promise_make = promise_make; |
|
| 335 |
- /** |
|
| 336 |
- * @author fenris |
|
| 337 |
- */ |
|
| 338 |
- function promise_then_close(promise, resolver, rejector) {
|
|
| 339 |
- promise.then(resolver, rejector); |
|
| 340 |
- } |
|
| 341 |
- lib_call.promise_then_close = promise_then_close; |
|
| 342 |
- /** |
|
| 343 |
- * @author fenris |
|
| 344 |
- */ |
|
| 345 |
- function promise_then_append(promise, resolver, rejector = null) {
|
|
| 346 |
- if (rejector == null) {
|
|
| 347 |
- rejector = (reason) => promise_reject(reason); |
|
| 348 |
- } |
|
| 349 |
- return (promise.then(resolver, rejector)); |
|
| 350 |
- } |
|
| 351 |
- lib_call.promise_then_append = promise_then_append; |
|
| 352 |
- /** |
|
| 353 |
- * @author fenris |
|
| 354 |
- */ |
|
| 355 |
- function promise_all(promises) {
|
|
| 356 |
- return Promise.all(promises); |
|
| 357 |
- } |
|
| 358 |
- lib_call.promise_all = promise_all; |
|
| 359 |
- /** |
|
| 360 |
- * @author fenris |
|
| 361 |
- */ |
|
| 362 |
- function promise_chain(promises, start = undefined) {
|
|
| 363 |
- return (promises.reduce((chain, promise) => promise_then_append(chain, promise), promise_resolve(start))); |
|
| 364 |
- } |
|
| 365 |
- lib_call.promise_chain = promise_chain; |
|
| 366 |
- /** |
|
| 367 |
- * @author fenris |
|
| 368 |
- */ |
|
| 369 |
- function promise_condense(promises) {
|
|
| 370 |
- return (promise_chain(promises.map(promise => result => promise_then_append(promise(), element => promise_resolve(result.concat([element])))), [])); |
|
| 371 |
- } |
|
| 372 |
- lib_call.promise_condense = promise_condense; |
|
| 373 |
- /** |
|
| 374 |
- * @author fenris |
|
| 375 |
- */ |
|
| 376 |
- function promise_group(promises, serial = false) {
|
|
| 377 |
- const decorate = function (promise, name) {
|
|
| 378 |
- return (() => promise_then_append(promise(), value => promise_resolve({ "key": name, "value": value })));
|
|
| 379 |
- }; |
|
| 380 |
- const convert = function (array) {
|
|
| 381 |
- let object = {};
|
|
| 382 |
- array.forEach(({ "key": key, "value": value }) => { object[key] = value; });
|
|
| 383 |
- return object; |
|
| 384 |
- }; |
|
| 385 |
- if (serial) {
|
|
| 386 |
- return (promise_then_append(promise_condense(Object.keys(promises) |
|
| 387 |
- .map(name => decorate(promises[name], name))), list => promise_resolve(convert(list)))); |
|
| 388 |
- } |
|
| 389 |
- else {
|
|
| 390 |
- return (promise_then_append(promise_all(Object.keys(promises) |
|
| 391 |
- .map(name => decorate(promises[name], name)) |
|
| 392 |
- .map(promise => promise())), list => promise_resolve(convert(list)))); |
|
| 393 |
- } |
|
| 394 |
- } |
|
| 395 |
- lib_call.promise_group = promise_group; |
|
| 396 |
- /** |
|
| 397 |
- * @author fenris |
|
| 398 |
- */ |
|
| 399 |
- function promise_wrap(promise, transformator_result, transformator_reason = lib_call.id) {
|
|
| 400 |
- return (promise_make((resolve, reject) => {
|
|
| 401 |
- promise_then_close(promise, result => resolve(transformator_result(result)), reason => reject(transformator_reason(reason))); |
|
| 402 |
- })); |
|
| 403 |
- } |
|
| 404 |
- lib_call.promise_wrap = promise_wrap; |
|
| 405 |
- /** |
|
| 406 |
- * @author fenris |
|
| 407 |
- */ |
|
| 408 |
- function promise_show(label) {
|
|
| 409 |
- return (result => promise_make((resolve, reject) => {
|
|
| 410 |
- lib_log.info(label + ": " + instance_show(result)); |
|
| 411 |
- resolve(result); |
|
| 412 |
- })); |
|
| 413 |
- } |
|
| 414 |
- lib_call.promise_show = promise_show; |
|
| 415 |
- /** |
|
| 416 |
- * @author fenris |
|
| 417 |
- */ |
|
| 418 |
- function promise_log(result) {
|
|
| 419 |
- return promise_show("log");
|
|
| 420 |
- } |
|
| 421 |
- lib_call.promise_log = promise_log; |
|
| 422 |
- /** |
|
| 423 |
- * @author fenris |
|
| 424 |
- */ |
|
| 425 |
- function promise_attach(state, promise, name) {
|
|
| 426 |
- return (promise_wrap(promise, result => {
|
|
| 427 |
- state[name] = result; |
|
| 428 |
- return state; |
|
| 429 |
- })); |
|
| 430 |
- } |
|
| 431 |
- lib_call.promise_attach = promise_attach; |
|
| 432 |
- /** |
|
| 433 |
- * @author fenris |
|
| 434 |
- */ |
|
| 435 |
- function promise_delay(promise, delay) {
|
|
| 436 |
- return promise_make((resolve, reject) => {
|
|
| 437 |
- lib_call.timeout(() => {
|
|
| 438 |
- promise_then_close(promise, resolve, reject); |
|
| 439 |
- return null; |
|
| 440 |
- }, delay); |
|
| 441 |
- }); |
|
| 442 |
- } |
|
| 443 |
- lib_call.promise_delay = promise_delay; |
|
| 444 |
- /** |
|
| 445 |
- * @author fenris |
|
| 446 |
- */ |
|
| 447 |
- function promise_to_executor(promise) {
|
|
| 448 |
- return ((resolve, reject) => promise.then(resolve, reject)); |
|
| 449 |
- } |
|
| 450 |
- lib_call.promise_to_executor = promise_to_executor; |
|
| 451 |
-})(lib_call || (lib_call = {}));
|
|
| 452 |
-/* |
|
| 453 |
-This file is part of »bacterio-plankton:call«. |
|
| 454 |
- |
|
| 455 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 456 |
-<info@greenscale.de> |
|
| 457 |
- |
|
| 458 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 459 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 460 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 461 |
-(at your option) any later version. |
|
| 462 |
- |
|
| 463 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 464 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 465 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 466 |
-GNU Lesser General Public License for more details. |
|
| 467 |
- |
|
| 468 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 469 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 470 |
- */ |
|
| 471 |
-var lib_call; |
|
| 472 |
-(function (lib_call) {
|
|
| 473 |
- lib_call.initializer_state_initial = 0; |
|
| 474 |
- lib_call.initializer_state_waiting = 1; |
|
| 475 |
- lib_call.initializer_state_successful = 2; |
|
| 476 |
- lib_call.initializer_state_failed = 3; |
|
| 477 |
- /** |
|
| 478 |
- * @author fenris |
|
| 479 |
- */ |
|
| 480 |
- function initializer_make(fetcher) {
|
|
| 481 |
- let subject = {
|
|
| 482 |
- "fetcher": fetcher, |
|
| 483 |
- "state": lib_call.initializer_state_initial, |
|
| 484 |
- "queue": [], |
|
| 485 |
- "result": undefined, |
|
| 486 |
- "reason": undefined, |
|
| 487 |
- }; |
|
| 488 |
- return subject; |
|
| 489 |
- } |
|
| 490 |
- lib_call.initializer_make = initializer_make; |
|
| 491 |
- /** |
|
| 492 |
- * @author fenris |
|
| 493 |
- */ |
|
| 494 |
- function initializer_actuate(subject) {
|
|
| 495 |
- switch (subject.state) {
|
|
| 496 |
- case lib_call.initializer_state_successful: {
|
|
| 497 |
- subject.queue.forEach(entry => entry.resolve(subject.result)); |
|
| 498 |
- break; |
|
| 499 |
- } |
|
| 500 |
- case lib_call.initializer_state_failed: {
|
|
| 501 |
- subject.queue.forEach(entry => entry.reject(subject.reason)); |
|
| 502 |
- break; |
|
| 503 |
- } |
|
| 504 |
- default: {
|
|
| 505 |
- let message = `unhandled state ${subject.state}`;
|
|
| 506 |
- throw (new Error(message)); |
|
| 507 |
- break; |
|
| 508 |
- } |
|
| 509 |
- } |
|
| 510 |
- } |
|
| 511 |
- /** |
|
| 512 |
- * @author fenris |
|
| 513 |
- */ |
|
| 514 |
- function initializer_reset(subject) {
|
|
| 515 |
- subject.state = lib_call.initializer_state_initial; |
|
| 516 |
- subject.queue = []; |
|
| 517 |
- } |
|
| 518 |
- lib_call.initializer_reset = initializer_reset; |
|
| 519 |
- /** |
|
| 520 |
- * @author fenris |
|
| 521 |
- */ |
|
| 522 |
- function initializer_state(subject) {
|
|
| 523 |
- return subject.state; |
|
| 524 |
- } |
|
| 525 |
- lib_call.initializer_state = initializer_state; |
|
| 526 |
- /** |
|
| 527 |
- * @author fenris |
|
| 528 |
- */ |
|
| 529 |
- function initializer_get(subject) {
|
|
| 530 |
- switch (subject.state) {
|
|
| 531 |
- case lib_call.initializer_state_initial: {
|
|
| 532 |
- subject.state = lib_call.initializer_state_waiting; |
|
| 533 |
- return (lib_call.promise_make((resolve, reject) => {
|
|
| 534 |
- subject.queue.push({ "resolve": resolve, "reject": reject });
|
|
| 535 |
- subject.fetcher().then(result => {
|
|
| 536 |
- subject.state = lib_call.initializer_state_successful; |
|
| 537 |
- subject.result = result; |
|
| 538 |
- initializer_actuate(subject); |
|
| 539 |
- }, reason => {
|
|
| 540 |
- subject.state = lib_call.initializer_state_failed; |
|
| 541 |
- subject.reason = reason; |
|
| 542 |
- initializer_actuate(subject); |
|
| 543 |
- }); |
|
| 544 |
- })); |
|
| 545 |
- break; |
|
| 546 |
- } |
|
| 547 |
- case lib_call.initializer_state_waiting: {
|
|
| 548 |
- return (lib_call.promise_make((resolve, reject) => {
|
|
| 549 |
- subject.queue.push({ "resolve": resolve, "reject": reject });
|
|
| 550 |
- })); |
|
| 551 |
- break; |
|
| 552 |
- } |
|
| 553 |
- case lib_call.initializer_state_successful: {
|
|
| 554 |
- return (lib_call.promise_resolve(subject.result)); |
|
| 555 |
- break; |
|
| 556 |
- } |
|
| 557 |
- case lib_call.initializer_state_failed: {
|
|
| 558 |
- return (lib_call.promise_reject(subject.reason)); |
|
| 559 |
- break; |
|
| 560 |
- } |
|
| 561 |
- default: {
|
|
| 562 |
- let message = `unhandled state ${subject.state}`;
|
|
| 563 |
- throw (new Error(message)); |
|
| 564 |
- break; |
|
| 565 |
- } |
|
| 566 |
- } |
|
| 567 |
- } |
|
| 568 |
- lib_call.initializer_get = initializer_get; |
|
| 569 |
- /** |
|
| 570 |
- * @author fenris |
|
| 571 |
- */ |
|
| 572 |
- function initializer_get_sync(subject) {
|
|
| 573 |
- switch (subject.state) {
|
|
| 574 |
- case lib_call.initializer_state_successful: {
|
|
| 575 |
- return subject.result; |
|
| 576 |
- break; |
|
| 577 |
- } |
|
| 578 |
- case lib_call.initializer_state_failed: {
|
|
| 579 |
- throw subject.reason; |
|
| 580 |
- break; |
|
| 581 |
- } |
|
| 582 |
- default: {
|
|
| 583 |
- let message = `unhandled state ${subject.state}`;
|
|
| 584 |
- throw (new Error(message)); |
|
| 585 |
- break; |
|
| 586 |
- } |
|
| 587 |
- } |
|
| 588 |
- } |
|
| 589 |
- /** |
|
| 590 |
- * @author fenris |
|
| 591 |
- */ |
|
| 592 |
- function initializer_set_sync(subject, result) {
|
|
| 593 |
- switch (subject.state) {
|
|
| 594 |
- case lib_call.initializer_state_successful: {
|
|
| 595 |
- subject.result = result; |
|
| 596 |
- break; |
|
| 597 |
- } |
|
| 598 |
- case lib_call.initializer_state_failed: {
|
|
| 599 |
- subject.state = lib_call.initializer_state_successful; |
|
| 600 |
- subject.result = result; |
|
| 601 |
- break; |
|
| 602 |
- } |
|
| 603 |
- default: {
|
|
| 604 |
- let message = `unhandled state ${subject.state}`;
|
|
| 605 |
- throw (new Error(message)); |
|
| 606 |
- break; |
|
| 607 |
- } |
|
| 608 |
- } |
|
| 609 |
- } |
|
| 610 |
-})(lib_call || (lib_call = {}));
|
|
| 611 |
-/* |
|
| 612 |
-This file is part of »bacterio-plankton:call«. |
|
| 613 |
- |
|
| 614 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 615 |
-<info@greenscale.de> |
|
| 616 |
- |
|
| 617 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 618 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 619 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 620 |
-(at your option) any later version. |
|
| 621 |
- |
|
| 622 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 623 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 624 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 625 |
-GNU Lesser General Public License for more details. |
|
| 626 |
- |
|
| 627 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 628 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 629 |
- */ |
|
| 630 |
-var lib_call; |
|
| 631 |
-(function (lib_call) {
|
|
| 632 |
- /* |
|
| 633 |
- The core idea of this library is to provide means for asynchronous program flow. The old-school way to do is, |
|
| 634 |
- is to use callbacks. While this approach is simple and easy to understand, it has some disadvantages. As an |
|
| 635 |
- attempt to relief and improve this, the promise-system was introduced. In principle it solves most of the |
|
| 636 |
- problems found in the callback-approach; however it has some downsides as well: |
|
| 637 |
- |
|
| 638 |
- - Convolution of multiple principles |
|
| 639 |
- Promises unite the ideas of asynchronous program flow and error handling. |
|
| 640 |
- |
|
| 641 |
- - Instant execution |
|
| 642 |
- Creating a promise results in the instant execution of the given executor prodecure. While this might be |
|
| 643 |
- convenient in some cases, it can be quite disturbing and counter-intuitive in others. |
|
| 644 |
- |
|
| 645 |
- - Broken typing |
|
| 646 |
- The Promise system doesn't distinguish between an appending "then" (i.e. passing a function, which returns a |
|
| 647 |
- new promise) and a closing "then" (i.e. passing a function, which has no return value). On top of that it |
|
| 648 |
- allows returning simple values in an appending "then", which results in an implicit call of the executors |
|
| 649 |
- "resolve"-function. The price for these "pragmatic" features is that the whole system can't be typed well. |
|
| 650 |
- And even though JavaScript is not a strictly typed language, it was a quite questionable decision to design |
|
| 651 |
- the promise system in a way, which breaks typing from the start. |
|
| 652 |
- |
|
| 653 |
- The deferral-system forseeks to solve these issues while retaining the advantages of the promise-system. |
|
| 654 |
- */ |
|
| 655 |
- /** |
|
| 656 |
- * @author fenris |
|
| 657 |
- * @desc activates the deferral and handles its output according to a given procedure |
|
| 658 |
- * @param {(value : type_value)=>void} procedure a function which receives the output of the deferral as argument
|
|
| 659 |
- */ |
|
| 660 |
- function deferral_use(deferral, input, procedure) {
|
|
| 661 |
- deferral.representation(input).then(value => {
|
|
| 662 |
- procedure(value); |
|
| 663 |
- }, reason => {
|
|
| 664 |
- throw reason; |
|
| 665 |
- }); |
|
| 666 |
- } |
|
| 667 |
- lib_call.deferral_use = deferral_use; |
|
| 668 |
- /** |
|
| 669 |
- * @author fenris |
|
| 670 |
- * @desc creates a deferral-subject (similar to "new Promise", where "convey" reflects "resolve"/"reject") |
|
| 671 |
- */ |
|
| 672 |
- function deferral_make(handler) {
|
|
| 673 |
- return ({
|
|
| 674 |
- "representation": ((input) => (new Promise((resolve, reject) => {
|
|
| 675 |
- handler(input, resolve); |
|
| 676 |
- }))) |
|
| 677 |
- }); |
|
| 678 |
- } |
|
| 679 |
- lib_call.deferral_make = deferral_make; |
|
| 680 |
- /** |
|
| 681 |
- * @author fenris |
|
| 682 |
- * @desc wraps a simple function into a deferral (similar to "Promise.resolve"/"Promise.reject") |
|
| 683 |
- */ |
|
| 684 |
- function deferral_wrap(function_) {
|
|
| 685 |
- return (deferral_make((input, convey) => convey(function_(input)))); |
|
| 686 |
- } |
|
| 687 |
- lib_call.deferral_wrap = deferral_wrap; |
|
| 688 |
- /** |
|
| 689 |
- * @author fenris |
|
| 690 |
- */ |
|
| 691 |
- function deferral_id() {
|
|
| 692 |
- return (deferral_make((input, convey) => convey(input))); |
|
| 693 |
- } |
|
| 694 |
- lib_call.deferral_id = deferral_id; |
|
| 695 |
- /** |
|
| 696 |
- * @author fenris |
|
| 697 |
- */ |
|
| 698 |
- function deferral_const(value) {
|
|
| 699 |
- return (deferral_make((input, convey) => convey(value))); |
|
| 700 |
- } |
|
| 701 |
- lib_call.deferral_const = deferral_const; |
|
| 702 |
- /** |
|
| 703 |
- * @author fenris |
|
| 704 |
- */ |
|
| 705 |
- function deferral_delay(output, delay) {
|
|
| 706 |
- return (deferral_make((input, convey) => {
|
|
| 707 |
- setTimeout(() => convey(output), delay); |
|
| 708 |
- })); |
|
| 709 |
- } |
|
| 710 |
- lib_call.deferral_delay = deferral_delay; |
|
| 711 |
- /** |
|
| 712 |
- * @author fenris |
|
| 713 |
- * @desc connects two deferrals to form a new one; the output of the first is taken as input for the second |
|
| 714 |
- * (similar to "Promise.then" when passing a function which returns a new promise) |
|
| 715 |
- * @param {type_deferral<type_value1>} first a simple deferral
|
|
| 716 |
- * @param {(value1 : type_value1)=>type_deferral<type_value2>} second a function depending from a value returning a deferral
|
|
| 717 |
- */ |
|
| 718 |
- function deferral_compose_serial(first, second) {
|
|
| 719 |
- return {
|
|
| 720 |
- "representation": ((input) => first.representation(input).then((between) => second.representation(between))) |
|
| 721 |
- }; |
|
| 722 |
- } |
|
| 723 |
- lib_call.deferral_compose_serial = deferral_compose_serial; |
|
| 724 |
- /** |
|
| 725 |
- * @author fenris |
|
| 726 |
- */ |
|
| 727 |
- function deferral_compose_parallel({ "left": deferral_left, "right": deferral_right, }) {
|
|
| 728 |
- return (deferral_make((input, convey) => {
|
|
| 729 |
- let object = {
|
|
| 730 |
- "left": lib_maybe.make_nothing(), |
|
| 731 |
- "right": lib_maybe.make_nothing(), |
|
| 732 |
- }; |
|
| 733 |
- let finish = function () {
|
|
| 734 |
- if (lib_maybe.is_just(object.left) |
|
| 735 |
- && |
|
| 736 |
- lib_maybe.is_just(object.right)) {
|
|
| 737 |
- let result = {
|
|
| 738 |
- "left": lib_maybe.cull(object.left), |
|
| 739 |
- "right": lib_maybe.cull(object.right), |
|
| 740 |
- }; |
|
| 741 |
- convey(result); |
|
| 742 |
- } |
|
| 743 |
- else {
|
|
| 744 |
- // do nothing |
|
| 745 |
- } |
|
| 746 |
- }; |
|
| 747 |
- deferral_use(deferral_left, input, output_left => {
|
|
| 748 |
- object.left = lib_maybe.make_just(output_left); |
|
| 749 |
- finish(); |
|
| 750 |
- }); |
|
| 751 |
- deferral_use(deferral_right, input, output_right => {
|
|
| 752 |
- object.right = lib_maybe.make_just(output_right); |
|
| 753 |
- finish(); |
|
| 754 |
- }); |
|
| 755 |
- })); |
|
| 756 |
- } |
|
| 757 |
- lib_call.deferral_compose_parallel = deferral_compose_parallel; |
|
| 758 |
- /** |
|
| 759 |
- * @author fenris |
|
| 760 |
- * @desc repeatedly applied serial composition |
|
| 761 |
- */ |
|
| 762 |
- function deferral_chain(members) {
|
|
| 763 |
- return (members.reduce( |
|
| 764 |
- // (result, current) => deferral_compose_serial<type_value, type_value, type_value>(result, current), |
|
| 765 |
- deferral_compose_serial, deferral_id())); |
|
| 766 |
- } |
|
| 767 |
- lib_call.deferral_chain = deferral_chain; |
|
| 768 |
- /** |
|
| 769 |
- * @author fenris |
|
| 770 |
- */ |
|
| 771 |
- /* |
|
| 772 |
- export function deferral_bunch<type_input, type_output>( |
|
| 773 |
- members : {[name : string] : type_deferral<type_input, type_output>}
|
|
| 774 |
- ) : type_deferral<type_input, {[name : string] : type_output}> {
|
|
| 775 |
- |
|
| 776 |
- } |
|
| 777 |
- */ |
|
| 778 |
-})(lib_call || (lib_call = {}));
|
|
| 779 |
-/* |
|
| 780 |
-This file is part of »bacterio-plankton:call«. |
|
| 781 |
- |
|
| 782 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 783 |
-<info@greenscale.de> |
|
| 784 |
- |
|
| 785 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 786 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 787 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 788 |
-(at your option) any later version. |
|
| 789 |
- |
|
| 790 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 791 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 792 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 793 |
-GNU Lesser General Public License for more details. |
|
| 794 |
- |
|
| 795 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 796 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 797 |
- */ |
|
| 798 |
-var lib_call; |
|
| 799 |
-(function (lib_call) {
|
|
| 800 |
- /** |
|
| 801 |
- * @author fenris |
|
| 802 |
- */ |
|
| 803 |
- class class_deferral {
|
|
| 804 |
- /** |
|
| 805 |
- * @author fenris |
|
| 806 |
- */ |
|
| 807 |
- constructor(subject) {
|
|
| 808 |
- this.subject = subject; |
|
| 809 |
- } |
|
| 810 |
- /** |
|
| 811 |
- * @author fenris |
|
| 812 |
- */ |
|
| 813 |
- static _cram(subject) {
|
|
| 814 |
- return (new class_deferral(subject)); |
|
| 815 |
- } |
|
| 816 |
- /** |
|
| 817 |
- * @author fenris |
|
| 818 |
- */ |
|
| 819 |
- static _tear(instance) {
|
|
| 820 |
- return instance.subject; |
|
| 821 |
- } |
|
| 822 |
- /** |
|
| 823 |
- * @author fenris |
|
| 824 |
- */ |
|
| 825 |
- static make(handler) {
|
|
| 826 |
- return (class_deferral._cram(lib_call.deferral_make(handler))); |
|
| 827 |
- } |
|
| 828 |
- /** |
|
| 829 |
- * @author fenris |
|
| 830 |
- */ |
|
| 831 |
- use(input, procedure) {
|
|
| 832 |
- return (lib_call.deferral_use(class_deferral._tear(this), input, procedure)); |
|
| 833 |
- } |
|
| 834 |
- /** |
|
| 835 |
- * @author fenris |
|
| 836 |
- */ |
|
| 837 |
- compose_serial(second) {
|
|
| 838 |
- return (class_deferral._cram(lib_call.deferral_compose_serial(class_deferral._tear(this), class_deferral._tear(second)))); |
|
| 839 |
- } |
|
| 840 |
- /** |
|
| 841 |
- * @author fenris |
|
| 842 |
- */ |
|
| 843 |
- static chain(members) {
|
|
| 844 |
- return (class_deferral._cram(lib_call.deferral_chain(members.map(member => class_deferral._tear(member))))); |
|
| 845 |
- } |
|
| 846 |
- /** |
|
| 847 |
- * @author fenris |
|
| 848 |
- */ |
|
| 849 |
- static wrap(function_) {
|
|
| 850 |
- return (class_deferral._cram(lib_call.deferral_wrap(function_))); |
|
| 851 |
- } |
|
| 852 |
- /** |
|
| 853 |
- * @author fenris |
|
| 854 |
- */ |
|
| 855 |
- static const_(value) {
|
|
| 856 |
- return (class_deferral._cram(lib_call.deferral_const(value))); |
|
| 857 |
- } |
|
| 858 |
- /** |
|
| 859 |
- * @author fenris |
|
| 860 |
- */ |
|
| 861 |
- static delay(output, delay) {
|
|
| 862 |
- return (class_deferral._cram(lib_call.deferral_delay(output, delay))); |
|
| 863 |
- } |
|
| 864 |
- } |
|
| 865 |
- lib_call.class_deferral = class_deferral; |
|
| 866 |
-})(lib_call || (lib_call = {}));
|
|
| 867 |
-/* |
|
| 868 |
-This file is part of »bacterio-plankton:call«. |
|
| 869 |
- |
|
| 870 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 871 |
-<info@greenscale.de> |
|
| 872 |
- |
|
| 873 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 874 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 875 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 876 |
-(at your option) any later version. |
|
| 877 |
- |
|
| 878 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 879 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 880 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 881 |
-GNU Lesser General Public License for more details. |
|
| 882 |
- |
|
| 883 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 884 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 885 |
- */ |
|
| 886 |
-var lib_call; |
|
| 887 |
-(function (lib_call) {
|
|
| 888 |
- /** |
|
| 889 |
- * @author fenris |
|
| 890 |
- */ |
|
| 891 |
- function timeout(function_, delay) {
|
|
| 892 |
- return ( |
|
| 893 |
- /*window.*/ setTimeout(function_, delay)); |
|
| 894 |
- } |
|
| 895 |
- lib_call.timeout = timeout; |
|
| 896 |
- /** |
|
| 897 |
- * @desc a definition for a value being "defined" |
|
| 898 |
- * @author neuc |
|
| 899 |
- */ |
|
| 900 |
- function is_def(obj, null_is_valid = false) {
|
|
| 901 |
- return (!((typeof (obj) === "undefined") |
|
| 902 |
- || |
|
| 903 |
- (!null_is_valid && (obj === null)))); |
|
| 904 |
- } |
|
| 905 |
- lib_call.is_def = is_def; |
|
| 906 |
- /** |
|
| 907 |
- * @desc returns the value if set and, when a type is specified, if the type is correct, if not return default_value |
|
| 908 |
- * @author neuc |
|
| 909 |
- */ |
|
| 910 |
- function def_val(value, default_value, type = null, null_is_valid = false) {
|
|
| 911 |
- if (is_def(value, null_is_valid) |
|
| 912 |
- && |
|
| 913 |
- (is_def(type) |
|
| 914 |
- ? ((typeof value === type) |
|
| 915 |
- || |
|
| 916 |
- ((value === null) |
|
| 917 |
- && |
|
| 918 |
- null_is_valid)) |
|
| 919 |
- : true)) {
|
|
| 920 |
- return value; |
|
| 921 |
- } |
|
| 922 |
- else {
|
|
| 923 |
- return default_value; |
|
| 924 |
- } |
|
| 925 |
- } |
|
| 926 |
- lib_call.def_val = def_val; |
|
| 927 |
- ; |
|
| 928 |
- /** |
|
| 929 |
- * @desc just the empty function; useful for some callbacks etc. |
|
| 930 |
- * @author fenris |
|
| 931 |
- */ |
|
| 932 |
- function nothing() {
|
|
| 933 |
- } |
|
| 934 |
- lib_call.nothing = nothing; |
|
| 935 |
- /** |
|
| 936 |
- * @desc outputs |
|
| 937 |
- * @author fenris |
|
| 938 |
- */ |
|
| 939 |
- function output(...args) {
|
|
| 940 |
- lib_log.info.apply(lib_log, args); |
|
| 941 |
- } |
|
| 942 |
- lib_call.output = output; |
|
| 943 |
- /** |
|
| 944 |
- * @desc converts the "arguments"-map into an array |
|
| 945 |
- * @param {Object} args
|
|
| 946 |
- * @author fenris |
|
| 947 |
- */ |
|
| 948 |
- function args2list(args) {
|
|
| 949 |
- return Object.keys(args).map(key => args[key]); |
|
| 950 |
- } |
|
| 951 |
- lib_call.args2list = args2list; |
|
| 952 |
- /** |
|
| 953 |
- * @desc provides the call for an attribute of a class as a regular function |
|
| 954 |
- * @param {string} name the name of the attribute
|
|
| 955 |
- * @return {*}
|
|
| 956 |
- * @author fenris |
|
| 957 |
- */ |
|
| 958 |
- function attribute(name) {
|
|
| 959 |
- return ((object) => object[name]); |
|
| 960 |
- } |
|
| 961 |
- lib_call.attribute = attribute; |
|
| 962 |
- /** |
|
| 963 |
- * @desc provides a method of a class as a regular function |
|
| 964 |
- * @param {string} name the name of the method
|
|
| 965 |
- * @return {function}
|
|
| 966 |
- * @author fenris |
|
| 967 |
- */ |
|
| 968 |
- function method(name) {
|
|
| 969 |
- return (function (object) { return object[name].apply(object, args2list(arguments).slice(1)); });
|
|
| 970 |
- } |
|
| 971 |
- lib_call.method = method; |
|
| 972 |
- /** |
|
| 973 |
- * @author fenris |
|
| 974 |
- */ |
|
| 975 |
- function distinguish(unival, handlers, fallback = null) {
|
|
| 976 |
- if (unival.kind in handlers) {
|
|
| 977 |
- let handler = handlers[unival.kind]; |
|
| 978 |
- return handler(unival.data); |
|
| 979 |
- } |
|
| 980 |
- else {
|
|
| 981 |
- let message = ("unhandled kind '" + unival.kind + "'");
|
|
| 982 |
- if (fallback !== null) {
|
|
| 983 |
- console.warn(message); |
|
| 984 |
- return fallback(unival); |
|
| 985 |
- } |
|
| 986 |
- else {
|
|
| 987 |
- throw (new Error(message)); |
|
| 988 |
- } |
|
| 989 |
- } |
|
| 990 |
- } |
|
| 991 |
- lib_call.distinguish = distinguish; |
|
| 992 |
-})(lib_call || (lib_call = {}));
|
| ... | ... |
@@ -244,39 +244,6 @@ declare module lib_code {
|
| 244 | 244 |
decode(x: string): Date; |
| 245 | 245 |
} |
| 246 | 246 |
} |
| 247 |
-declare module lib_code {
|
|
| 248 |
- /** |
|
| 249 |
- * @author fenris |
|
| 250 |
- */ |
|
| 251 |
- function json_encode(x: any, formatted?: boolean): string; |
|
| 252 |
- /** |
|
| 253 |
- * @author fenris |
|
| 254 |
- */ |
|
| 255 |
- function json_decode(x: string): any; |
|
| 256 |
-} |
|
| 257 |
-declare module lib_code {
|
|
| 258 |
-} |
|
| 259 |
-declare module lib_code {
|
|
| 260 |
- /** |
|
| 261 |
- * @author fenris |
|
| 262 |
- */ |
|
| 263 |
- class class_code_json implements interface_code<any, string> {
|
|
| 264 |
- /** |
|
| 265 |
- * @author fenris |
|
| 266 |
- */ |
|
| 267 |
- constructor(); |
|
| 268 |
- /** |
|
| 269 |
- * @implementation |
|
| 270 |
- * @author fenris |
|
| 271 |
- */ |
|
| 272 |
- encode(x: any): string; |
|
| 273 |
- /** |
|
| 274 |
- * @implementation |
|
| 275 |
- * @author fenris |
|
| 276 |
- */ |
|
| 277 |
- decode(x: string): any; |
|
| 278 |
- } |
|
| 279 |
-} |
|
| 280 | 247 |
declare module lib_code {
|
| 281 | 248 |
/** |
| 282 | 249 |
* @author Christian Fraß <frass@greenscale.de> |
| ... | ... |
@@ -323,69 +290,3 @@ declare module lib_code {
|
| 323 | 290 |
decode(x: string): type_csv_from; |
| 324 | 291 |
} |
| 325 | 292 |
} |
| 326 |
-declare module lib_code {
|
|
| 327 |
- /** |
|
| 328 |
- * @author fenris |
|
| 329 |
- */ |
|
| 330 |
- function uri_encode(x: string): string; |
|
| 331 |
- /** |
|
| 332 |
- * @author fenris |
|
| 333 |
- */ |
|
| 334 |
- function uri_decode(x: string): string; |
|
| 335 |
-} |
|
| 336 |
-declare module lib_code {
|
|
| 337 |
-} |
|
| 338 |
-declare module lib_code {
|
|
| 339 |
- /** |
|
| 340 |
- * @author fenris |
|
| 341 |
- */ |
|
| 342 |
- class class_code_uri implements interface_code<string, string> {
|
|
| 343 |
- /** |
|
| 344 |
- * @author fenris |
|
| 345 |
- */ |
|
| 346 |
- constructor(); |
|
| 347 |
- /** |
|
| 348 |
- * @implementation |
|
| 349 |
- * @author fenris |
|
| 350 |
- */ |
|
| 351 |
- encode(x: string): string; |
|
| 352 |
- /** |
|
| 353 |
- * @implementation |
|
| 354 |
- * @author fenris |
|
| 355 |
- */ |
|
| 356 |
- decode(x: string): string; |
|
| 357 |
- } |
|
| 358 |
-} |
|
| 359 |
-declare module lib_code {
|
|
| 360 |
- /** |
|
| 361 |
- * @author fenris |
|
| 362 |
- */ |
|
| 363 |
- function base64_encode(x: string): string; |
|
| 364 |
- /** |
|
| 365 |
- * @author fenris |
|
| 366 |
- */ |
|
| 367 |
- function base64_decode(x: string): string; |
|
| 368 |
-} |
|
| 369 |
-declare module lib_code {
|
|
| 370 |
-} |
|
| 371 |
-declare module lib_code {
|
|
| 372 |
- /** |
|
| 373 |
- * @author fenris |
|
| 374 |
- */ |
|
| 375 |
- class class_code_base64 implements interface_code<string, string> {
|
|
| 376 |
- /** |
|
| 377 |
- * @author fenris |
|
| 378 |
- */ |
|
| 379 |
- constructor(); |
|
| 380 |
- /** |
|
| 381 |
- * @implementation |
|
| 382 |
- * @author fenris |
|
| 383 |
- */ |
|
| 384 |
- encode(x: string): string; |
|
| 385 |
- /** |
|
| 386 |
- * @implementation |
|
| 387 |
- * @author fenris |
|
| 388 |
- */ |
|
| 389 |
- decode(x: string): string; |
|
| 390 |
- } |
|
| 391 |
-} |
| ... | ... |
@@ -781,129 +781,6 @@ but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 781 | 781 |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 782 | 782 |
GNU Lesser General Public License for more details. |
| 783 | 783 |
|
| 784 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 785 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 786 |
- */ |
|
| 787 |
-var lib_code; |
|
| 788 |
-(function (lib_code) {
|
|
| 789 |
- /** |
|
| 790 |
- * @author fenris |
|
| 791 |
- */ |
|
| 792 |
- function json_encode(x, formatted = false) {
|
|
| 793 |
- return JSON.stringify(x, undefined, formatted ? "\t" : undefined); |
|
| 794 |
- } |
|
| 795 |
- lib_code.json_encode = json_encode; |
|
| 796 |
- /** |
|
| 797 |
- * @author fenris |
|
| 798 |
- */ |
|
| 799 |
- function json_decode(x) {
|
|
| 800 |
- return JSON.parse(x); |
|
| 801 |
- } |
|
| 802 |
- lib_code.json_decode = json_decode; |
|
| 803 |
-})(lib_code || (lib_code = {}));
|
|
| 804 |
-/* |
|
| 805 |
-This file is part of »bacterio-plankton:code«. |
|
| 806 |
- |
|
| 807 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 808 |
-<info@greenscale.de> |
|
| 809 |
- |
|
| 810 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 811 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 812 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 813 |
-(at your option) any later version. |
|
| 814 |
- |
|
| 815 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 816 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 817 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 818 |
-GNU Lesser General Public License for more details. |
|
| 819 |
- |
|
| 820 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 821 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 822 |
- */ |
|
| 823 |
-var lib_code; |
|
| 824 |
-(function (lib_code) {
|
|
| 825 |
- /** |
|
| 826 |
- * @author fenris |
|
| 827 |
- */ |
|
| 828 |
- lib_trait.attend("code", "json", {
|
|
| 829 |
- "from": {
|
|
| 830 |
- "name": "any" |
|
| 831 |
- }, |
|
| 832 |
- "to": {
|
|
| 833 |
- "name": "string" |
|
| 834 |
- } |
|
| 835 |
- }, {
|
|
| 836 |
- "encode": () => (x) => {
|
|
| 837 |
- return lib_code.json_encode(x); |
|
| 838 |
- }, |
|
| 839 |
- "decode": () => (y) => {
|
|
| 840 |
- return lib_code.json_decode(y); |
|
| 841 |
- } |
|
| 842 |
- }); |
|
| 843 |
-})(lib_code || (lib_code = {}));
|
|
| 844 |
-/* |
|
| 845 |
-This file is part of »bacterio-plankton:code«. |
|
| 846 |
- |
|
| 847 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 848 |
-<info@greenscale.de> |
|
| 849 |
- |
|
| 850 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 851 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 852 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 853 |
-(at your option) any later version. |
|
| 854 |
- |
|
| 855 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 856 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 857 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 858 |
-GNU Lesser General Public License for more details. |
|
| 859 |
- |
|
| 860 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 861 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 862 |
- */ |
|
| 863 |
-var lib_code; |
|
| 864 |
-(function (lib_code) {
|
|
| 865 |
- /** |
|
| 866 |
- * @author fenris |
|
| 867 |
- */ |
|
| 868 |
- class class_code_json {
|
|
| 869 |
- /** |
|
| 870 |
- * @author fenris |
|
| 871 |
- */ |
|
| 872 |
- constructor() {
|
|
| 873 |
- } |
|
| 874 |
- /** |
|
| 875 |
- * @implementation |
|
| 876 |
- * @author fenris |
|
| 877 |
- */ |
|
| 878 |
- encode(x) {
|
|
| 879 |
- return lib_code.json_encode(x); |
|
| 880 |
- } |
|
| 881 |
- /** |
|
| 882 |
- * @implementation |
|
| 883 |
- * @author fenris |
|
| 884 |
- */ |
|
| 885 |
- decode(x) {
|
|
| 886 |
- return lib_code.json_decode(x); |
|
| 887 |
- } |
|
| 888 |
- } |
|
| 889 |
- lib_code.class_code_json = class_code_json; |
|
| 890 |
-})(lib_code || (lib_code = {}));
|
|
| 891 |
-/* |
|
| 892 |
-This file is part of »bacterio-plankton:code«. |
|
| 893 |
- |
|
| 894 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 895 |
-<info@greenscale.de> |
|
| 896 |
- |
|
| 897 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 898 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 899 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 900 |
-(at your option) any later version. |
|
| 901 |
- |
|
| 902 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 903 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 904 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 905 |
-GNU Lesser General Public License for more details. |
|
| 906 |
- |
|
| 907 | 784 |
You should have received a copy of the GNU Lesser General Public License |
| 908 | 785 |
along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
| 909 | 786 |
*/ |
| ... | ... |
@@ -988,249 +865,3 @@ var lib_code; |
| 988 | 865 |
} |
| 989 | 866 |
lib_code.class_code_csv = class_code_csv; |
| 990 | 867 |
})(lib_code || (lib_code = {}));
|
| 991 |
-/* |
|
| 992 |
-This file is part of »bacterio-plankton:code«. |
|
| 993 |
- |
|
| 994 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 995 |
-<info@greenscale.de> |
|
| 996 |
- |
|
| 997 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 998 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 999 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 1000 |
-(at your option) any later version. |
|
| 1001 |
- |
|
| 1002 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 1003 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 1004 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 1005 |
-GNU Lesser General Public License for more details. |
|
| 1006 |
- |
|
| 1007 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 1008 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 1009 |
- */ |
|
| 1010 |
-var lib_code; |
|
| 1011 |
-(function (lib_code) {
|
|
| 1012 |
- /** |
|
| 1013 |
- * @author fenris |
|
| 1014 |
- */ |
|
| 1015 |
- function uri_encode(x) {
|
|
| 1016 |
- return encodeURIComponent(x); |
|
| 1017 |
- } |
|
| 1018 |
- lib_code.uri_encode = uri_encode; |
|
| 1019 |
- /** |
|
| 1020 |
- * @author fenris |
|
| 1021 |
- */ |
|
| 1022 |
- function uri_decode(x) {
|
|
| 1023 |
- return decodeURIComponent(x); |
|
| 1024 |
- } |
|
| 1025 |
- lib_code.uri_decode = uri_decode; |
|
| 1026 |
-})(lib_code || (lib_code = {}));
|
|
| 1027 |
-/* |
|
| 1028 |
-This file is part of »bacterio-plankton:code«. |
|
| 1029 |
- |
|
| 1030 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 1031 |
-<info@greenscale.de> |
|
| 1032 |
- |
|
| 1033 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 1034 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 1035 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 1036 |
-(at your option) any later version. |
|
| 1037 |
- |
|
| 1038 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 1039 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 1040 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 1041 |
-GNU Lesser General Public License for more details. |
|
| 1042 |
- |
|
| 1043 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 1044 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 1045 |
- */ |
|
| 1046 |
-var lib_code; |
|
| 1047 |
-(function (lib_code) {
|
|
| 1048 |
- /** |
|
| 1049 |
- * @author fenris |
|
| 1050 |
- */ |
|
| 1051 |
- lib_trait.attend("code", "uri", {
|
|
| 1052 |
- "from": {
|
|
| 1053 |
- "name": "string" |
|
| 1054 |
- }, |
|
| 1055 |
- "to": {
|
|
| 1056 |
- "name": "string" |
|
| 1057 |
- } |
|
| 1058 |
- }, {
|
|
| 1059 |
- "encode": () => (x) => {
|
|
| 1060 |
- return lib_code.uri_encode(x); |
|
| 1061 |
- }, |
|
| 1062 |
- "decode": () => (y) => {
|
|
| 1063 |
- return lib_code.uri_decode(y); |
|
| 1064 |
- } |
|
| 1065 |
- }); |
|
| 1066 |
-})(lib_code || (lib_code = {}));
|
|
| 1067 |
-/* |
|
| 1068 |
-This file is part of »bacterio-plankton:code«. |
|
| 1069 |
- |
|
| 1070 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 1071 |
-<info@greenscale.de> |
|
| 1072 |
- |
|
| 1073 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 1074 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 1075 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 1076 |
-(at your option) any later version. |
|
| 1077 |
- |
|
| 1078 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 1079 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 1080 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 1081 |
-GNU Lesser General Public License for more details. |
|
| 1082 |
- |
|
| 1083 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 1084 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 1085 |
- */ |
|
| 1086 |
-var lib_code; |
|
| 1087 |
-(function (lib_code) {
|
|
| 1088 |
- /** |
|
| 1089 |
- * @author fenris |
|
| 1090 |
- */ |
|
| 1091 |
- class class_code_uri {
|
|
| 1092 |
- /** |
|
| 1093 |
- * @author fenris |
|
| 1094 |
- */ |
|
| 1095 |
- constructor() {
|
|
| 1096 |
- } |
|
| 1097 |
- /** |
|
| 1098 |
- * @implementation |
|
| 1099 |
- * @author fenris |
|
| 1100 |
- */ |
|
| 1101 |
- encode(x) {
|
|
| 1102 |
- return lib_code.uri_encode(x); |
|
| 1103 |
- } |
|
| 1104 |
- /** |
|
| 1105 |
- * @implementation |
|
| 1106 |
- * @author fenris |
|
| 1107 |
- */ |
|
| 1108 |
- decode(x) {
|
|
| 1109 |
- return lib_code.uri_decode(x); |
|
| 1110 |
- } |
|
| 1111 |
- } |
|
| 1112 |
- lib_code.class_code_uri = class_code_uri; |
|
| 1113 |
-})(lib_code || (lib_code = {}));
|
|
| 1114 |
-/* |
|
| 1115 |
-This file is part of »bacterio-plankton:code«. |
|
| 1116 |
- |
|
| 1117 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 1118 |
-<info@greenscale.de> |
|
| 1119 |
- |
|
| 1120 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 1121 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 1122 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 1123 |
-(at your option) any later version. |
|
| 1124 |
- |
|
| 1125 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 1126 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 1127 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 1128 |
-GNU Lesser General Public License for more details. |
|
| 1129 |
- |
|
| 1130 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 1131 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 1132 |
- */ |
|
| 1133 |
-var lib_code; |
|
| 1134 |
-(function (lib_code) {
|
|
| 1135 |
- /** |
|
| 1136 |
- * @author fenris |
|
| 1137 |
- */ |
|
| 1138 |
- function base64_encode(x) {
|
|
| 1139 |
- return (new Buffer(x)).toString("base64");
|
|
| 1140 |
- } |
|
| 1141 |
- lib_code.base64_encode = base64_encode; |
|
| 1142 |
- /** |
|
| 1143 |
- * @author fenris |
|
| 1144 |
- */ |
|
| 1145 |
- function base64_decode(x) {
|
|
| 1146 |
- return (new Buffer(x, "base64")).toString(); |
|
| 1147 |
- } |
|
| 1148 |
- lib_code.base64_decode = base64_decode; |
|
| 1149 |
-})(lib_code || (lib_code = {}));
|
|
| 1150 |
-/* |
|
| 1151 |
-This file is part of »bacterio-plankton:code«. |
|
| 1152 |
- |
|
| 1153 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 1154 |
-<info@greenscale.de> |
|
| 1155 |
- |
|
| 1156 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 1157 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 1158 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 1159 |
-(at your option) any later version. |
|
| 1160 |
- |
|
| 1161 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 1162 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 1163 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 1164 |
-GNU Lesser General Public License for more details. |
|
| 1165 |
- |
|
| 1166 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 1167 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 1168 |
- */ |
|
| 1169 |
-var lib_code; |
|
| 1170 |
-(function (lib_code) {
|
|
| 1171 |
- /** |
|
| 1172 |
- * @author fenris |
|
| 1173 |
- */ |
|
| 1174 |
- lib_trait.attend("code", "base64", {
|
|
| 1175 |
- "from": {
|
|
| 1176 |
- "name": "string" |
|
| 1177 |
- }, |
|
| 1178 |
- "to": {
|
|
| 1179 |
- "name": "string" |
|
| 1180 |
- } |
|
| 1181 |
- }, {
|
|
| 1182 |
- "encode": () => (x) => {
|
|
| 1183 |
- return lib_code.base64_encode(x); |
|
| 1184 |
- }, |
|
| 1185 |
- "decode": () => (y) => {
|
|
| 1186 |
- return lib_code.base64_decode(y); |
|
| 1187 |
- } |
|
| 1188 |
- }); |
|
| 1189 |
-})(lib_code || (lib_code = {}));
|
|
| 1190 |
-/* |
|
| 1191 |
-This file is part of »bacterio-plankton:code«. |
|
| 1192 |
- |
|
| 1193 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 1194 |
-<info@greenscale.de> |
|
| 1195 |
- |
|
| 1196 |
-»bacterio-plankton:code« is free software: you can redistribute it and/or modify |
|
| 1197 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 1198 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 1199 |
-(at your option) any later version. |
|
| 1200 |
- |
|
| 1201 |
-»bacterio-plankton:code« is distributed in the hope that it will be useful, |
|
| 1202 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 1203 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 1204 |
-GNU Lesser General Public License for more details. |
|
| 1205 |
- |
|
| 1206 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 1207 |
-along with »bacterio-plankton:code«. If not, see <http://www.gnu.org/licenses/>. |
|
| 1208 |
- */ |
|
| 1209 |
-var lib_code; |
|
| 1210 |
-(function (lib_code) {
|
|
| 1211 |
- /** |
|
| 1212 |
- * @author fenris |
|
| 1213 |
- */ |
|
| 1214 |
- class class_code_base64 {
|
|
| 1215 |
- /** |
|
| 1216 |
- * @author fenris |
|
| 1217 |
- */ |
|
| 1218 |
- constructor() {
|
|
| 1219 |
- } |
|
| 1220 |
- /** |
|
| 1221 |
- * @implementation |
|
| 1222 |
- * @author fenris |
|
| 1223 |
- */ |
|
| 1224 |
- encode(x) {
|
|
| 1225 |
- return lib_code.base64_encode(x); |
|
| 1226 |
- } |
|
| 1227 |
- /** |
|
| 1228 |
- * @implementation |
|
| 1229 |
- * @author fenris |
|
| 1230 |
- */ |
|
| 1231 |
- decode(x) {
|
|
| 1232 |
- return lib_code.base64_decode(x); |
|
| 1233 |
- } |
|
| 1234 |
- } |
|
| 1235 |
- lib_code.class_code_base64 = class_code_base64; |
|
| 1236 |
-})(lib_code || (lib_code = {}));
|
| ... | ... |
@@ -1,861 +0,0 @@ |
| 1 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 2 |
-<info@greenscale.de> |
|
| 3 |
- |
|
| 4 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 5 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 6 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 7 |
-(at your option) any later version. |
|
| 8 |
- |
|
| 9 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 10 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 11 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 12 |
-GNU Lesser General Public License for more details. |
|
| 13 |
- |
|
| 14 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 15 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 16 |
- |
|
| 17 |
- |
|
| 18 |
- |
|
| 19 |
- GNU GENERAL PUBLIC LICENSE |
|
| 20 |
- Version 3, 29 June 2007 |
|
| 21 |
- |
|
| 22 |
- Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/> |
|
| 23 |
- Everyone is permitted to copy and distribute verbatim copies |
|
| 24 |
- of this license document, but changing it is not allowed. |
|
| 25 |
- |
|
| 26 |
- Preamble |
|
| 27 |
- |
|
| 28 |
- The GNU General Public License is a free, copyleft license for |
|
| 29 |
-software and other kinds of works. |
|
| 30 |
- |
|
| 31 |
- The licenses for most software and other practical works are designed |
|
| 32 |
-to take away your freedom to share and change the works. By contrast, |
|
| 33 |
-the GNU General Public License is intended to guarantee your freedom to |
|
| 34 |
-share and change all versions of a program--to make sure it remains free |
|
| 35 |
-software for all its users. We, the Free Software Foundation, use the |
|
| 36 |
-GNU General Public License for most of our software; it applies also to |
|
| 37 |
-any other work released this way by its authors. You can apply it to |
|
| 38 |
-your programs, too. |
|
| 39 |
- |
|
| 40 |
- When we speak of free software, we are referring to freedom, not |
|
| 41 |
-price. Our General Public Licenses are designed to make sure that you |
|
| 42 |
-have the freedom to distribute copies of free software (and charge for |
|
| 43 |
-them if you wish), that you receive source code or can get it if you |
|
| 44 |
-want it, that you can change the software or use pieces of it in new |
|
| 45 |
-free programs, and that you know you can do these things. |
|
| 46 |
- |
|
| 47 |
- To protect your rights, we need to prevent others from denying you |
|
| 48 |
-these rights or asking you to surrender the rights. Therefore, you have |
|
| 49 |
-certain responsibilities if you distribute copies of the software, or if |
|
| 50 |
-you modify it: responsibilities to respect the freedom of others. |
|
| 51 |
- |
|
| 52 |
- For example, if you distribute copies of such a program, whether |
|
| 53 |
-gratis or for a fee, you must pass on to the recipients the same |
|
| 54 |
-freedoms that you received. You must make sure that they, too, receive |
|
| 55 |
-or can get the source code. And you must show them these terms so they |
|
| 56 |
-know their rights. |
|
| 57 |
- |
|
| 58 |
- Developers that use the GNU GPL protect your rights with two steps: |
|
| 59 |
-(1) assert copyright on the software, and (2) offer you this License |
|
| 60 |
-giving you legal permission to copy, distribute and/or modify it. |
|
| 61 |
- |
|
| 62 |
- For the developers' and authors' protection, the GPL clearly explains |
|
| 63 |
-that there is no warranty for this free software. For both users' and |
|
| 64 |
-authors' sake, the GPL requires that modified versions be marked as |
|
| 65 |
-changed, so that their problems will not be attributed erroneously to |
|
| 66 |
-authors of previous versions. |
|
| 67 |
- |
|
| 68 |
- Some devices are designed to deny users access to install or run |
|
| 69 |
-modified versions of the software inside them, although the manufacturer |
|
| 70 |
-can do so. This is fundamentally incompatible with the aim of |
|
| 71 |
-protecting users' freedom to change the software. The systematic |
|
| 72 |
-pattern of such abuse occurs in the area of products for individuals to |
|
| 73 |
-use, which is precisely where it is most unacceptable. Therefore, we |
|
| 74 |
-have designed this version of the GPL to prohibit the practice for those |
|
| 75 |
-products. If such problems arise substantially in other domains, we |
|
| 76 |
-stand ready to extend this provision to those domains in future versions |
|
| 77 |
-of the GPL, as needed to protect the freedom of users. |
|
| 78 |
- |
|
| 79 |
- Finally, every program is threatened constantly by software patents. |
|
| 80 |
-States should not allow patents to restrict development and use of |
|
| 81 |
-software on general-purpose computers, but in those that do, we wish to |
|
| 82 |
-avoid the special danger that patents applied to a free program could |
|
| 83 |
-make it effectively proprietary. To prevent this, the GPL assures that |
|
| 84 |
-patents cannot be used to render the program non-free. |
|
| 85 |
- |
|
| 86 |
- The precise terms and conditions for copying, distribution and |
|
| 87 |
-modification follow. |
|
| 88 |
- |
|
| 89 |
- TERMS AND CONDITIONS |
|
| 90 |
- |
|
| 91 |
- 0. Definitions. |
|
| 92 |
- |
|
| 93 |
- "This License" refers to version 3 of the GNU General Public License. |
|
| 94 |
- |
|
| 95 |
- "Copyright" also means copyright-like laws that apply to other kinds of |
|
| 96 |
-works, such as semiconductor masks. |
|
| 97 |
- |
|
| 98 |
- "The Program" refers to any copyrightable work licensed under this |
|
| 99 |
-License. Each licensee is addressed as "you". "Licensees" and |
|
| 100 |
-"recipients" may be individuals or organizations. |
|
| 101 |
- |
|
| 102 |
- To "modify" a work means to copy from or adapt all or part of the work |
|
| 103 |
-in a fashion requiring copyright permission, other than the making of an |
|
| 104 |
-exact copy. The resulting work is called a "modified version" of the |
|
| 105 |
-earlier work or a work "based on" the earlier work. |
|
| 106 |
- |
|
| 107 |
- A "covered work" means either the unmodified Program or a work based |
|
| 108 |
-on the Program. |
|
| 109 |
- |
|
| 110 |
- To "propagate" a work means to do anything with it that, without |
|
| 111 |
-permission, would make you directly or secondarily liable for |
|
| 112 |
-infringement under applicable copyright law, except executing it on a |
|
| 113 |
-computer or modifying a private copy. Propagation includes copying, |
|
| 114 |
-distribution (with or without modification), making available to the |
|
| 115 |
-public, and in some countries other activities as well. |
|
| 116 |
- |
|
| 117 |
- To "convey" a work means any kind of propagation that enables other |
|
| 118 |
-parties to make or receive copies. Mere interaction with a user through |
|
| 119 |
-a computer network, with no transfer of a copy, is not conveying. |
|
| 120 |
- |
|
| 121 |
- An interactive user interface displays "Appropriate Legal Notices" |
|
| 122 |
-to the extent that it includes a convenient and prominently visible |
|
| 123 |
-feature that (1) displays an appropriate copyright notice, and (2) |
|
| 124 |
-tells the user that there is no warranty for the work (except to the |
|
| 125 |
-extent that warranties are provided), that licensees may convey the |
|
| 126 |
-work under this License, and how to view a copy of this License. If |
|
| 127 |
-the interface presents a list of user commands or options, such as a |
|
| 128 |
-menu, a prominent item in the list meets this criterion. |
|
| 129 |
- |
|
| 130 |
- 1. Source Code. |
|
| 131 |
- |
|
| 132 |
- The "source code" for a work means the preferred form of the work |
|
| 133 |
-for making modifications to it. "Object code" means any non-source |
|
| 134 |
-form of a work. |
|
| 135 |
- |
|
| 136 |
- A "Standard Interface" means an interface that either is an official |
|
| 137 |
-standard defined by a recognized standards body, or, in the case of |
|
| 138 |
-interfaces specified for a particular programming language, one that |
|
| 139 |
-is widely used among developers working in that language. |
|
| 140 |
- |
|
| 141 |
- The "System Libraries" of an executable work include anything, other |
|
| 142 |
-than the work as a whole, that (a) is included in the normal form of |
|
| 143 |
-packaging a Major Component, but which is not part of that Major |
|
| 144 |
-Component, and (b) serves only to enable use of the work with that |
|
| 145 |
-Major Component, or to implement a Standard Interface for which an |
|
| 146 |
-implementation is available to the public in source code form. A |
|
| 147 |
-"Major Component", in this context, means a major essential component |
|
| 148 |
-(kernel, window system, and so on) of the specific operating system |
|
| 149 |
-(if any) on which the executable work runs, or a compiler used to |
|
| 150 |
-produce the work, or an object code interpreter used to run it. |
|
| 151 |
- |
|
| 152 |
- The "Corresponding Source" for a work in object code form means all |
|
| 153 |
-the source code needed to generate, install, and (for an executable |
|
| 154 |
-work) run the object code and to modify the work, including scripts to |
|
| 155 |
-control those activities. However, it does not include the work's |
|
| 156 |
-System Libraries, or general-purpose tools or generally available free |
|
| 157 |
-programs which are used unmodified in performing those activities but |
|
| 158 |
-which are not part of the work. For example, Corresponding Source |
|
| 159 |
-includes interface definition files associated with source files for |
|
| 160 |
-the work, and the source code for shared libraries and dynamically |
|
| 161 |
-linked subprograms that the work is specifically designed to require, |
|
| 162 |
-such as by intimate data communication or control flow between those |
|
| 163 |
-subprograms and other parts of the work. |
|
| 164 |
- |
|
| 165 |
- The Corresponding Source need not include anything that users |
|
| 166 |
-can regenerate automatically from other parts of the Corresponding |
|
| 167 |
-Source. |
|
| 168 |
- |
|
| 169 |
- The Corresponding Source for a work in source code form is that |
|
| 170 |
-same work. |
|
| 171 |
- |
|
| 172 |
- 2. Basic Permissions. |
|
| 173 |
- |
|
| 174 |
- All rights granted under this License are granted for the term of |
|
| 175 |
-copyright on the Program, and are irrevocable provided the stated |
|
| 176 |
-conditions are met. This License explicitly affirms your unlimited |
|
| 177 |
-permission to run the unmodified Program. The output from running a |
|
| 178 |
-covered work is covered by this License only if the output, given its |
|
| 179 |
-content, constitutes a covered work. This License acknowledges your |
|
| 180 |
-rights of fair use or other equivalent, as provided by copyright law. |
|
| 181 |
- |
|
| 182 |
- You may make, run and propagate covered works that you do not |
|
| 183 |
-convey, without conditions so long as your license otherwise remains |
|
| 184 |
-in force. You may convey covered works to others for the sole purpose |
|
| 185 |
-of having them make modifications exclusively for you, or provide you |
|
| 186 |
-with facilities for running those works, provided that you comply with |
|
| 187 |
-the terms of this License in conveying all material for which you do |
|
| 188 |
-not control copyright. Those thus making or running the covered works |
|
| 189 |
-for you must do so exclusively on your behalf, under your direction |
|
| 190 |
-and control, on terms that prohibit them from making any copies of |
|
| 191 |
-your copyrighted material outside their relationship with you. |
|
| 192 |
- |
|
| 193 |
- Conveying under any other circumstances is permitted solely under |
|
| 194 |
-the conditions stated below. Sublicensing is not allowed; section 10 |
|
| 195 |
-makes it unnecessary. |
|
| 196 |
- |
|
| 197 |
- 3. Protecting Users' Legal Rights From Anti-Circumvention Law. |
|
| 198 |
- |
|
| 199 |
- No covered work shall be deemed part of an effective technological |
|
| 200 |
-measure under any applicable law fulfilling obligations under article |
|
| 201 |
-11 of the WIPO copyright treaty adopted on 20 December 1996, or |
|
| 202 |
-similar laws prohibiting or restricting circumvention of such |
|
| 203 |
-measures. |
|
| 204 |
- |
|
| 205 |
- When you convey a covered work, you waive any legal power to forbid |
|
| 206 |
-circumvention of technological measures to the extent such circumvention |
|
| 207 |
-is effected by exercising rights under this License with respect to |
|
| 208 |
-the covered work, and you disclaim any intention to limit operation or |
|
| 209 |
-modification of the work as a means of enforcing, against the work's |
|
| 210 |
-users, your or third parties' legal rights to forbid circumvention of |
|
| 211 |
-technological measures. |
|
| 212 |
- |
|
| 213 |
- 4. Conveying Verbatim Copies. |
|
| 214 |
- |
|
| 215 |
- You may convey verbatim copies of the Program's source code as you |
|
| 216 |
-receive it, in any medium, provided that you conspicuously and |
|
| 217 |
-appropriately publish on each copy an appropriate copyright notice; |
|
| 218 |
-keep intact all notices stating that this License and any |
|
| 219 |
-non-permissive terms added in accord with section 7 apply to the code; |
|
| 220 |
-keep intact all notices of the absence of any warranty; and give all |
|
| 221 |
-recipients a copy of this License along with the Program. |
|
| 222 |
- |
|
| 223 |
- You may charge any price or no price for each copy that you convey, |
|
| 224 |
-and you may offer support or warranty protection for a fee. |
|
| 225 |
- |
|
| 226 |
- 5. Conveying Modified Source Versions. |
|
| 227 |
- |
|
| 228 |
- You may convey a work based on the Program, or the modifications to |
|
| 229 |
-produce it from the Program, in the form of source code under the |
|
| 230 |
-terms of section 4, provided that you also meet all of these conditions: |
|
| 231 |
- |
|
| 232 |
- a) The work must carry prominent notices stating that you modified |
|
| 233 |
- it, and giving a relevant date. |
|
| 234 |
- |
|
| 235 |
- b) The work must carry prominent notices stating that it is |
|
| 236 |
- released under this License and any conditions added under section |
|
| 237 |
- 7. This requirement modifies the requirement in section 4 to |
|
| 238 |
- "keep intact all notices". |
|
| 239 |
- |
|
| 240 |
- c) You must license the entire work, as a whole, under this |
|
| 241 |
- License to anyone who comes into possession of a copy. This |
|
| 242 |
- License will therefore apply, along with any applicable section 7 |
|
| 243 |
- additional terms, to the whole of the work, and all its parts, |
|
| 244 |
- regardless of how they are packaged. This License gives no |
|
| 245 |
- permission to license the work in any other way, but it does not |
|
| 246 |
- invalidate such permission if you have separately received it. |
|
| 247 |
- |
|
| 248 |
- d) If the work has interactive user interfaces, each must display |
|
| 249 |
- Appropriate Legal Notices; however, if the Program has interactive |
|
| 250 |
- interfaces that do not display Appropriate Legal Notices, your |
|
| 251 |
- work need not make them do so. |
|
| 252 |
- |
|
| 253 |
- A compilation of a covered work with other separate and independent |
|
| 254 |
-works, which are not by their nature extensions of the covered work, |
|
| 255 |
-and which are not combined with it such as to form a larger program, |
|
| 256 |
-in or on a volume of a storage or distribution medium, is called an |
|
| 257 |
-"aggregate" if the compilation and its resulting copyright are not |
|
| 258 |
-used to limit the access or legal rights of the compilation's users |
|
| 259 |
-beyond what the individual works permit. Inclusion of a covered work |
|
| 260 |
-in an aggregate does not cause this License to apply to the other |
|
| 261 |
-parts of the aggregate. |
|
| 262 |
- |
|
| 263 |
- 6. Conveying Non-Source Forms. |
|
| 264 |
- |
|
| 265 |
- You may convey a covered work in object code form under the terms |
|
| 266 |
-of sections 4 and 5, provided that you also convey the |
|
| 267 |
-machine-readable Corresponding Source under the terms of this License, |
|
| 268 |
-in one of these ways: |
|
| 269 |
- |
|
| 270 |
- a) Convey the object code in, or embodied in, a physical product |
|
| 271 |
- (including a physical distribution medium), accompanied by the |
|
| 272 |
- Corresponding Source fixed on a durable physical medium |
|
| 273 |
- customarily used for software interchange. |
|
| 274 |
- |
|
| 275 |
- b) Convey the object code in, or embodied in, a physical product |
|
| 276 |
- (including a physical distribution medium), accompanied by a |
|
| 277 |
- written offer, valid for at least three years and valid for as |
|
| 278 |
- long as you offer spare parts or customer support for that product |
|
| 279 |
- model, to give anyone who possesses the object code either (1) a |
|
| 280 |
- copy of the Corresponding Source for all the software in the |
|
| 281 |
- product that is covered by this License, on a durable physical |
|
| 282 |
- medium customarily used for software interchange, for a price no |
|
| 283 |
- more than your reasonable cost of physically performing this |
|
| 284 |
- conveying of source, or (2) access to copy the |
|
| 285 |
- Corresponding Source from a network server at no charge. |
|
| 286 |
- |
|
| 287 |
- c) Convey individual copies of the object code with a copy of the |
|
| 288 |
- written offer to provide the Corresponding Source. This |
|
| 289 |
- alternative is allowed only occasionally and noncommercially, and |
|
| 290 |
- only if you received the object code with such an offer, in accord |
|
| 291 |
- with subsection 6b. |
|
| 292 |
- |
|
| 293 |
- d) Convey the object code by offering access from a designated |
|
| 294 |
- place (gratis or for a charge), and offer equivalent access to the |
|
| 295 |
- Corresponding Source in the same way through the same place at no |
|
| 296 |
- further charge. You need not require recipients to copy the |
|
| 297 |
- Corresponding Source along with the object code. If the place to |
|
| 298 |
- copy the object code is a network server, the Corresponding Source |
|
| 299 |
- may be on a different server (operated by you or a third party) |
|
| 300 |
- that supports equivalent copying facilities, provided you maintain |
|
| 301 |
- clear directions next to the object code saying where to find the |
|
| 302 |
- Corresponding Source. Regardless of what server hosts the |
|
| 303 |
- Corresponding Source, you remain obligated to ensure that it is |
|
| 304 |
- available for as long as needed to satisfy these requirements. |
|
| 305 |
- |
|
| 306 |
- e) Convey the object code using peer-to-peer transmission, provided |
|
| 307 |
- you inform other peers where the object code and Corresponding |
|
| 308 |
- Source of the work are being offered to the general public at no |
|
| 309 |
- charge under subsection 6d. |
|
| 310 |
- |
|
| 311 |
- A separable portion of the object code, whose source code is excluded |
|
| 312 |
-from the Corresponding Source as a System Library, need not be |
|
| 313 |
-included in conveying the object code work. |
|
| 314 |
- |
|
| 315 |
- A "User Product" is either (1) a "consumer product", which means any |
|
| 316 |
-tangible personal property which is normally used for personal, family, |
|
| 317 |
-or household purposes, or (2) anything designed or sold for incorporation |
|
| 318 |
-into a dwelling. In determining whether a product is a consumer product, |
|
| 319 |
-doubtful cases shall be resolved in favor of coverage. For a particular |
|
| 320 |
-product received by a particular user, "normally used" refers to a |
|
| 321 |
-typical or common use of that class of product, regardless of the status |
|
| 322 |
-of the particular user or of the way in which the particular user |
|
| 323 |
-actually uses, or expects or is expected to use, the product. A product |
|
| 324 |
-is a consumer product regardless of whether the product has substantial |
|
| 325 |
-commercial, industrial or non-consumer uses, unless such uses represent |
|
| 326 |
-the only significant mode of use of the product. |
|
| 327 |
- |
|
| 328 |
- "Installation Information" for a User Product means any methods, |
|
| 329 |
-procedures, authorization keys, or other information required to install |
|
| 330 |
-and execute modified versions of a covered work in that User Product from |
|
| 331 |
-a modified version of its Corresponding Source. The information must |
|
| 332 |
-suffice to ensure that the continued functioning of the modified object |
|
| 333 |
-code is in no case prevented or interfered with solely because |
|
| 334 |
-modification has been made. |
|
| 335 |
- |
|
| 336 |
- If you convey an object code work under this section in, or with, or |
|
| 337 |
-specifically for use in, a User Product, and the conveying occurs as |
|
| 338 |
-part of a transaction in which the right of possession and use of the |
|
| 339 |
-User Product is transferred to the recipient in perpetuity or for a |
|
| 340 |
-fixed term (regardless of how the transaction is characterized), the |
|
| 341 |
-Corresponding Source conveyed under this section must be accompanied |
|
| 342 |
-by the Installation Information. But this requirement does not apply |
|
| 343 |
-if neither you nor any third party retains the ability to install |
|
| 344 |
-modified object code on the User Product (for example, the work has |
|
| 345 |
-been installed in ROM). |
|
| 346 |
- |
|
| 347 |
- The requirement to provide Installation Information does not include a |
|
| 348 |
-requirement to continue to provide support service, warranty, or updates |
|
| 349 |
-for a work that has been modified or installed by the recipient, or for |
|
| 350 |
-the User Product in which it has been modified or installed. Access to a |
|
| 351 |
-network may be denied when the modification itself materially and |
|
| 352 |
-adversely affects the operation of the network or violates the rules and |
|
| 353 |
-protocols for communication across the network. |
|
| 354 |
- |
|
| 355 |
- Corresponding Source conveyed, and Installation Information provided, |
|
| 356 |
-in accord with this section must be in a format that is publicly |
|
| 357 |
-documented (and with an implementation available to the public in |
|
| 358 |
-source code form), and must require no special password or key for |
|
| 359 |
-unpacking, reading or copying. |
|
| 360 |
- |
|
| 361 |
- 7. Additional Terms. |
|
| 362 |
- |
|
| 363 |
- "Additional permissions" are terms that supplement the terms of this |
|
| 364 |
-License by making exceptions from one or more of its conditions. |
|
| 365 |
-Additional permissions that are applicable to the entire Program shall |
|
| 366 |
-be treated as though they were included in this License, to the extent |
|
| 367 |
-that they are valid under applicable law. If additional permissions |
|
| 368 |
-apply only to part of the Program, that part may be used separately |
|
| 369 |
-under those permissions, but the entire Program remains governed by |
|
| 370 |
-this License without regard to the additional permissions. |
|
| 371 |
- |
|
| 372 |
- When you convey a copy of a covered work, you may at your option |
|
| 373 |
-remove any additional permissions from that copy, or from any part of |
|
| 374 |
-it. (Additional permissions may be written to require their own |
|
| 375 |
-removal in certain cases when you modify the work.) You may place |
|
| 376 |
-additional permissions on material, added by you to a covered work, |
|
| 377 |
-for which you have or can give appropriate copyright permission. |
|
| 378 |
- |
|
| 379 |
- Notwithstanding any other provision of this License, for material you |
|
| 380 |
-add to a covered work, you may (if authorized by the copyright holders of |
|
| 381 |
-that material) supplement the terms of this License with terms: |
|
| 382 |
- |
|
| 383 |
- a) Disclaiming warranty or limiting liability differently from the |
|
| 384 |
- terms of sections 15 and 16 of this License; or |
|
| 385 |
- |
|
| 386 |
- b) Requiring preservation of specified reasonable legal notices or |
|
| 387 |
- author attributions in that material or in the Appropriate Legal |
|
| 388 |
- Notices displayed by works containing it; or |
|
| 389 |
- |
|
| 390 |
- c) Prohibiting misrepresentation of the origin of that material, or |
|
| 391 |
- requiring that modified versions of such material be marked in |
|
| 392 |
- reasonable ways as different from the original version; or |
|
| 393 |
- |
|
| 394 |
- d) Limiting the use for publicity purposes of names of licensors or |
|
| 395 |
- authors of the material; or |
|
| 396 |
- |
|
| 397 |
- e) Declining to grant rights under trademark law for use of some |
|
| 398 |
- trade names, trademarks, or service marks; or |
|
| 399 |
- |
|
| 400 |
- f) Requiring indemnification of licensors and authors of that |
|
| 401 |
- material by anyone who conveys the material (or modified versions of |
|
| 402 |
- it) with contractual assumptions of liability to the recipient, for |
|
| 403 |
- any liability that these contractual assumptions directly impose on |
|
| 404 |
- those licensors and authors. |
|
| 405 |
- |
|
| 406 |
- All other non-permissive additional terms are considered "further |
|
| 407 |
-restrictions" within the meaning of section 10. If the Program as you |
|
| 408 |
-received it, or any part of it, contains a notice stating that it is |
|
| 409 |
-governed by this License along with a term that is a further |
|
| 410 |
-restriction, you may remove that term. If a license document contains |
|
| 411 |
-a further restriction but permits relicensing or conveying under this |
|
| 412 |
-License, you may add to a covered work material governed by the terms |
|
| 413 |
-of that license document, provided that the further restriction does |
|
| 414 |
-not survive such relicensing or conveying. |
|
| 415 |
- |
|
| 416 |
- If you add terms to a covered work in accord with this section, you |
|
| 417 |
-must place, in the relevant source files, a statement of the |
|
| 418 |
-additional terms that apply to those files, or a notice indicating |
|
| 419 |
-where to find the applicable terms. |
|
| 420 |
- |
|
| 421 |
- Additional terms, permissive or non-permissive, may be stated in the |
|
| 422 |
-form of a separately written license, or stated as exceptions; |
|
| 423 |
-the above requirements apply either way. |
|
| 424 |
- |
|
| 425 |
- 8. Termination. |
|
| 426 |
- |
|
| 427 |
- You may not propagate or modify a covered work except as expressly |
|
| 428 |
-provided under this License. Any attempt otherwise to propagate or |
|
| 429 |
-modify it is void, and will automatically terminate your rights under |
|
| 430 |
-this License (including any patent licenses granted under the third |
|
| 431 |
-paragraph of section 11). |
|
| 432 |
- |
|
| 433 |
- However, if you cease all violation of this License, then your |
|
| 434 |
-license from a particular copyright holder is reinstated (a) |
|
| 435 |
-provisionally, unless and until the copyright holder explicitly and |
|
| 436 |
-finally terminates your license, and (b) permanently, if the copyright |
|
| 437 |
-holder fails to notify you of the violation by some reasonable means |
|
| 438 |
-prior to 60 days after the cessation. |
|
| 439 |
- |
|
| 440 |
- Moreover, your license from a particular copyright holder is |
|
| 441 |
-reinstated permanently if the copyright holder notifies you of the |
|
| 442 |
-violation by some reasonable means, this is the first time you have |
|
| 443 |
-received notice of violation of this License (for any work) from that |
|
| 444 |
-copyright holder, and you cure the violation prior to 30 days after |
|
| 445 |
-your receipt of the notice. |
|
| 446 |
- |
|
| 447 |
- Termination of your rights under this section does not terminate the |
|
| 448 |
-licenses of parties who have received copies or rights from you under |
|
| 449 |
-this License. If your rights have been terminated and not permanently |
|
| 450 |
-reinstated, you do not qualify to receive new licenses for the same |
|
| 451 |
-material under section 10. |
|
| 452 |
- |
|
| 453 |
- 9. Acceptance Not Required for Having Copies. |
|
| 454 |
- |
|
| 455 |
- You are not required to accept this License in order to receive or |
|
| 456 |
-run a copy of the Program. Ancillary propagation of a covered work |
|
| 457 |
-occurring solely as a consequence of using peer-to-peer transmission |
|
| 458 |
-to receive a copy likewise does not require acceptance. However, |
|
| 459 |
-nothing other than this License grants you permission to propagate or |
|
| 460 |
-modify any covered work. These actions infringe copyright if you do |
|
| 461 |
-not accept this License. Therefore, by modifying or propagating a |
|
| 462 |
-covered work, you indicate your acceptance of this License to do so. |
|
| 463 |
- |
|
| 464 |
- 10. Automatic Licensing of Downstream Recipients. |
|
| 465 |
- |
|
| 466 |
- Each time you convey a covered work, the recipient automatically |
|
| 467 |
-receives a license from the original licensors, to run, modify and |
|
| 468 |
-propagate that work, subject to this License. You are not responsible |
|
| 469 |
-for enforcing compliance by third parties with this License. |
|
| 470 |
- |
|
| 471 |
- An "entity transaction" is a transaction transferring control of an |
|
| 472 |
-organization, or substantially all assets of one, or subdividing an |
|
| 473 |
-organization, or merging organizations. If propagation of a covered |
|
| 474 |
-work results from an entity transaction, each party to that |
|
| 475 |
-transaction who receives a copy of the work also receives whatever |
|
| 476 |
-licenses to the work the party's predecessor in interest had or could |
|
| 477 |
-give under the previous paragraph, plus a right to possession of the |
|
| 478 |
-Corresponding Source of the work from the predecessor in interest, if |
|
| 479 |
-the predecessor has it or can get it with reasonable efforts. |
|
| 480 |
- |
|
| 481 |
- You may not impose any further restrictions on the exercise of the |
|
| 482 |
-rights granted or affirmed under this License. For example, you may |
|
| 483 |
-not impose a license fee, royalty, or other charge for exercise of |
|
| 484 |
-rights granted under this License, and you may not initiate litigation |
|
| 485 |
-(including a cross-claim or counterclaim in a lawsuit) alleging that |
|
| 486 |
-any patent claim is infringed by making, using, selling, offering for |
|
| 487 |
-sale, or importing the Program or any portion of it. |
|
| 488 |
- |
|
| 489 |
- 11. Patents. |
|
| 490 |
- |
|
| 491 |
- A "contributor" is a copyright holder who authorizes use under this |
|
| 492 |
-License of the Program or a work on which the Program is based. The |
|
| 493 |
-work thus licensed is called the contributor's "contributor version". |
|
| 494 |
- |
|
| 495 |
- A contributor's "essential patent claims" are all patent claims |
|
| 496 |
-owned or controlled by the contributor, whether already acquired or |
|
| 497 |
-hereafter acquired, that would be infringed by some manner, permitted |
|
| 498 |
-by this License, of making, using, or selling its contributor version, |
|
| 499 |
-but do not include claims that would be infringed only as a |
|
| 500 |
-consequence of further modification of the contributor version. For |
|
| 501 |
-purposes of this definition, "control" includes the right to grant |
|
| 502 |
-patent sublicenses in a manner consistent with the requirements of |
|
| 503 |
-this License. |
|
| 504 |
- |
|
| 505 |
- Each contributor grants you a non-exclusive, worldwide, royalty-free |
|
| 506 |
-patent license under the contributor's essential patent claims, to |
|
| 507 |
-make, use, sell, offer for sale, import and otherwise run, modify and |
|
| 508 |
-propagate the contents of its contributor version. |
|
| 509 |
- |
|
| 510 |
- In the following three paragraphs, a "patent license" is any express |
|
| 511 |
-agreement or commitment, however denominated, not to enforce a patent |
|
| 512 |
-(such as an express permission to practice a patent or covenant not to |
|
| 513 |
-sue for patent infringement). To "grant" such a patent license to a |
|
| 514 |
-party means to make such an agreement or commitment not to enforce a |
|
| 515 |
-patent against the party. |
|
| 516 |
- |
|
| 517 |
- If you convey a covered work, knowingly relying on a patent license, |
|
| 518 |
-and the Corresponding Source of the work is not available for anyone |
|
| 519 |
-to copy, free of charge and under the terms of this License, through a |
|
| 520 |
-publicly available network server or other readily accessible means, |
|
| 521 |
-then you must either (1) cause the Corresponding Source to be so |
|
| 522 |
-available, or (2) arrange to deprive yourself of the benefit of the |
|
| 523 |
-patent license for this particular work, or (3) arrange, in a manner |
|
| 524 |
-consistent with the requirements of this License, to extend the patent |
|
| 525 |
-license to downstream recipients. "Knowingly relying" means you have |
|
| 526 |
-actual knowledge that, but for the patent license, your conveying the |
|
| 527 |
-covered work in a country, or your recipient's use of the covered work |
|
| 528 |
-in a country, would infringe one or more identifiable patents in that |
|
| 529 |
-country that you have reason to believe are valid. |
|
| 530 |
- |
|
| 531 |
- If, pursuant to or in connection with a single transaction or |
|
| 532 |
-arrangement, you convey, or propagate by procuring conveyance of, a |
|
| 533 |
-covered work, and grant a patent license to some of the parties |
|
| 534 |
-receiving the covered work authorizing them to use, propagate, modify |
|
| 535 |
-or convey a specific copy of the covered work, then the patent license |
|
| 536 |
-you grant is automatically extended to all recipients of the covered |
|
| 537 |
-work and works based on it. |
|
| 538 |
- |
|
| 539 |
- A patent license is "discriminatory" if it does not include within |
|
| 540 |
-the scope of its coverage, prohibits the exercise of, or is |
|
| 541 |
-conditioned on the non-exercise of one or more of the rights that are |
|
| 542 |
-specifically granted under this License. You may not convey a covered |
|
| 543 |
-work if you are a party to an arrangement with a third party that is |
|
| 544 |
-in the business of distributing software, under which you make payment |
|
| 545 |
-to the third party based on the extent of your activity of conveying |
|
| 546 |
-the work, and under which the third party grants, to any of the |
|
| 547 |
-parties who would receive the covered work from you, a discriminatory |
|
| 548 |
-patent license (a) in connection with copies of the covered work |
|
| 549 |
-conveyed by you (or copies made from those copies), or (b) primarily |
|
| 550 |
-for and in connection with specific products or compilations that |
|
| 551 |
-contain the covered work, unless you entered into that arrangement, |
|
| 552 |
-or that patent license was granted, prior to 28 March 2007. |
|
| 553 |
- |
|
| 554 |
- Nothing in this License shall be construed as excluding or limiting |
|
| 555 |
-any implied license or other defenses to infringement that may |
|
| 556 |
-otherwise be available to you under applicable patent law. |
|
| 557 |
- |
|
| 558 |
- 12. No Surrender of Others' Freedom. |
|
| 559 |
- |
|
| 560 |
- If conditions are imposed on you (whether by court order, agreement or |
|
| 561 |
-otherwise) that contradict the conditions of this License, they do not |
|
| 562 |
-excuse you from the conditions of this License. If you cannot convey a |
|
| 563 |
-covered work so as to satisfy simultaneously your obligations under this |
|
| 564 |
-License and any other pertinent obligations, then as a consequence you may |
|
| 565 |
-not convey it at all. For example, if you agree to terms that obligate you |
|
| 566 |
-to collect a royalty for further conveying from those to whom you convey |
|
| 567 |
-the Program, the only way you could satisfy both those terms and this |
|
| 568 |
-License would be to refrain entirely from conveying the Program. |
|
| 569 |
- |
|
| 570 |
- 13. Use with the GNU Affero General Public License. |
|
| 571 |
- |
|
| 572 |
- Notwithstanding any other provision of this License, you have |
|
| 573 |
-permission to link or combine any covered work with a work licensed |
|
| 574 |
-under version 3 of the GNU Affero General Public License into a single |
|
| 575 |
-combined work, and to convey the resulting work. The terms of this |
|
| 576 |
-License will continue to apply to the part which is the covered work, |
|
| 577 |
-but the special requirements of the GNU Affero General Public License, |
|
| 578 |
-section 13, concerning interaction through a network will apply to the |
|
| 579 |
-combination as such. |
|
| 580 |
- |
|
| 581 |
- 14. Revised Versions of this License. |
|
| 582 |
- |
|
| 583 |
- The Free Software Foundation may publish revised and/or new versions of |
|
| 584 |
-the GNU General Public License from time to time. Such new versions will |
|
| 585 |
-be similar in spirit to the present version, but may differ in detail to |
|
| 586 |
-address new problems or concerns. |
|
| 587 |
- |
|
| 588 |
- Each version is given a distinguishing version number. If the |
|
| 589 |
-Program specifies that a certain numbered version of the GNU General |
|
| 590 |
-Public License "or any later version" applies to it, you have the |
|
| 591 |
-option of following the terms and conditions either of that numbered |
|
| 592 |
-version or of any later version published by the Free Software |
|
| 593 |
-Foundation. If the Program does not specify a version number of the |
|
| 594 |
-GNU General Public License, you may choose any version ever published |
|
| 595 |
-by the Free Software Foundation. |
|
| 596 |
- |
|
| 597 |
- If the Program specifies that a proxy can decide which future |
|
| 598 |
-versions of the GNU General Public License can be used, that proxy's |
|
| 599 |
-public statement of acceptance of a version permanently authorizes you |
|
| 600 |
-to choose that version for the Program. |
|
| 601 |
- |
|
| 602 |
- Later license versions may give you additional or different |
|
| 603 |
-permissions. However, no additional obligations are imposed on any |
|
| 604 |
-author or copyright holder as a result of your choosing to follow a |
|
| 605 |
-later version. |
|
| 606 |
- |
|
| 607 |
- 15. Disclaimer of Warranty. |
|
| 608 |
- |
|
| 609 |
- THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY |
|
| 610 |
-APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT |
|
| 611 |
-HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY |
|
| 612 |
-OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, |
|
| 613 |
-THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
| 614 |
-PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM |
|
| 615 |
-IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF |
|
| 616 |
-ALL NECESSARY SERVICING, REPAIR OR CORRECTION. |
|
| 617 |
- |
|
| 618 |
- 16. Limitation of Liability. |
|
| 619 |
- |
|
| 620 |
- IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING |
|
| 621 |
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS |
|
| 622 |
-THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY |
|
| 623 |
-GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE |
|
| 624 |
-USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF |
|
| 625 |
-DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD |
|
| 626 |
-PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), |
|
| 627 |
-EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF |
|
| 628 |
-SUCH DAMAGES. |
|
| 629 |
- |
|
| 630 |
- 17. Interpretation of Sections 15 and 16. |
|
| 631 |
- |
|
| 632 |
- If the disclaimer of warranty and limitation of liability provided |
|
| 633 |
-above cannot be given local legal effect according to their terms, |
|
| 634 |
-reviewing courts shall apply local law that most closely approximates |
|
| 635 |
-an absolute waiver of all civil liability in connection with the |
|
| 636 |
-Program, unless a warranty or assumption of liability accompanies a |
|
| 637 |
-copy of the Program in return for a fee. |
|
| 638 |
- |
|
| 639 |
- END OF TERMS AND CONDITIONS |
|
| 640 |
- |
|
| 641 |
- How to Apply These Terms to Your New Programs |
|
| 642 |
- |
|
| 643 |
- If you develop a new program, and you want it to be of the greatest |
|
| 644 |
-possible use to the public, the best way to achieve this is to make it |
|
| 645 |
-free software which everyone can redistribute and change under these terms. |
|
| 646 |
- |
|
| 647 |
- To do so, attach the following notices to the program. It is safest |
|
| 648 |
-to attach them to the start of each source file to most effectively |
|
| 649 |
-state the exclusion of warranty; and each file should have at least |
|
| 650 |
-the "copyright" line and a pointer to where the full notice is found. |
|
| 651 |
- |
|
| 652 |
- <one line to give the program's name and a brief idea of what it does.> |
|
| 653 |
- Copyright (C) <year> <name of author> |
|
| 654 |
- |
|
| 655 |
- This program is free software: you can redistribute it and/or modify |
|
| 656 |
- it under the terms of the GNU General Public License as published by |
|
| 657 |
- the Free Software Foundation, either version 3 of the License, or |
|
| 658 |
- (at your option) any later version. |
|
| 659 |
- |
|
| 660 |
- This program is distributed in the hope that it will be useful, |
|
| 661 |
- but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 662 |
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 663 |
- GNU General Public License for more details. |
|
| 664 |
- |
|
| 665 |
- You should have received a copy of the GNU General Public License |
|
| 666 |
- along with this program. If not, see <https://www.gnu.org/licenses/>. |
|
| 667 |
- |
|
| 668 |
-Also add information on how to contact you by electronic and paper mail. |
|
| 669 |
- |
|
| 670 |
- If the program does terminal interaction, make it output a short |
|
| 671 |
-notice like this when it starts in an interactive mode: |
|
| 672 |
- |
|
| 673 |
- <program> Copyright (C) <year> <name of author> |
|
| 674 |
- This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. |
|
| 675 |
- This is free software, and you are welcome to redistribute it |
|
| 676 |
- under certain conditions; type `show c' for details. |
|
| 677 |
- |
|
| 678 |
-The hypothetical commands `show w' and `show c' should show the appropriate |
|
| 679 |
-parts of the General Public License. Of course, your program's commands |
|
| 680 |
-might be different; for a GUI interface, you would use an "about box". |
|
| 681 |
- |
|
| 682 |
- You should also get your employer (if you work as a programmer) or school, |
|
| 683 |
-if any, to sign a "copyright disclaimer" for the program, if necessary. |
|
| 684 |
-For more information on this, and how to apply and follow the GNU GPL, see |
|
| 685 |
-<https://www.gnu.org/licenses/>. |
|
| 686 |
- |
|
| 687 |
- The GNU General Public License does not permit incorporating your program |
|
| 688 |
-into proprietary programs. If your program is a subroutine library, you |
|
| 689 |
-may consider it more useful to permit linking proprietary applications with |
|
| 690 |
-the library. If this is what you want to do, use the GNU Lesser General |
|
| 691 |
-Public License instead of this License. But first, please read |
|
| 692 |
-<https://www.gnu.org/licenses/why-not-lgpl.html>. |
|
| 693 |
- |
|
| 694 |
- |
|
| 695 |
- |
|
| 696 |
- GNU LESSER GENERAL PUBLIC LICENSE |
|
| 697 |
- Version 3, 29 June 2007 |
|
| 698 |
- |
|
| 699 |
- Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/> |
|
| 700 |
- Everyone is permitted to copy and distribute verbatim copies |
|
| 701 |
- of this license document, but changing it is not allowed. |
|
| 702 |
- |
|
| 703 |
- |
|
| 704 |
- This version of the GNU Lesser General Public License incorporates |
|
| 705 |
-the terms and conditions of version 3 of the GNU General Public |
|
| 706 |
-License, supplemented by the additional permissions listed below. |
|
| 707 |
- |
|
| 708 |
- 0. Additional Definitions. |
|
| 709 |
- |
|
| 710 |
- As used herein, "this License" refers to version 3 of the GNU Lesser |
|
| 711 |
-General Public License, and the "GNU GPL" refers to version 3 of the GNU |
|
| 712 |
-General Public License. |
|
| 713 |
- |
|
| 714 |
- "The Library" refers to a covered work governed by this License, |
|
| 715 |
-other than an Application or a Combined Work as defined below. |
|
| 716 |
- |
|
| 717 |
- An "Application" is any work that makes use of an interface provided |
|
| 718 |
-by the Library, but which is not otherwise based on the Library. |
|
| 719 |
-Defining a subclass of a class defined by the Library is deemed a mode |
|
| 720 |
-of using an interface provided by the Library. |
|
| 721 |
- |
|
| 722 |
- A "Combined Work" is a work produced by combining or linking an |
|
| 723 |
-Application with the Library. The particular version of the Library |
|
| 724 |
-with which the Combined Work was made is also called the "Linked |
|
| 725 |
-Version". |
|
| 726 |
- |
|
| 727 |
- The "Minimal Corresponding Source" for a Combined Work means the |
|
| 728 |
-Corresponding Source for the Combined Work, excluding any source code |
|
| 729 |
-for portions of the Combined Work that, considered in isolation, are |
|
| 730 |
-based on the Application, and not on the Linked Version. |
|
| 731 |
- |
|
| 732 |
- The "Corresponding Application Code" for a Combined Work means the |
|
| 733 |
-object code and/or source code for the Application, including any data |
|
| 734 |
-and utility programs needed for reproducing the Combined Work from the |
|
| 735 |
-Application, but excluding the System Libraries of the Combined Work. |
|
| 736 |
- |
|
| 737 |
- 1. Exception to Section 3 of the GNU GPL. |
|
| 738 |
- |
|
| 739 |
- You may convey a covered work under sections 3 and 4 of this License |
|
| 740 |
-without being bound by section 3 of the GNU GPL. |
|
| 741 |
- |
|
| 742 |
- 2. Conveying Modified Versions. |
|
| 743 |
- |
|
| 744 |
- If you modify a copy of the Library, and, in your modifications, a |
|
| 745 |
-facility refers to a function or data to be supplied by an Application |
|
| 746 |
-that uses the facility (other than as an argument passed when the |
|
| 747 |
-facility is invoked), then you may convey a copy of the modified |
|
| 748 |
-version: |
|
| 749 |
- |
|
| 750 |
- a) under this License, provided that you make a good faith effort to |
|
| 751 |
- ensure that, in the event an Application does not supply the |
|
| 752 |
- function or data, the facility still operates, and performs |
|
| 753 |
- whatever part of its purpose remains meaningful, or |
|
| 754 |
- |
|
| 755 |
- b) under the GNU GPL, with none of the additional permissions of |
|
| 756 |
- this License applicable to that copy. |
|
| 757 |
- |
|
| 758 |
- 3. Object Code Incorporating Material from Library Header Files. |
|
| 759 |
- |
|
| 760 |
- The object code form of an Application may incorporate material from |
|
| 761 |
-a header file that is part of the Library. You may convey such object |
|
| 762 |
-code under terms of your choice, provided that, if the incorporated |
|
| 763 |
-material is not limited to numerical parameters, data structure |
|
| 764 |
-layouts and accessors, or small macros, inline functions and templates |
|
| 765 |
-(ten or fewer lines in length), you do both of the following: |
|
| 766 |
- |
|
| 767 |
- a) Give prominent notice with each copy of the object code that the |
|
| 768 |
- Library is used in it and that the Library and its use are |
|
| 769 |
- covered by this License. |
|
| 770 |
- |
|
| 771 |
- b) Accompany the object code with a copy of the GNU GPL and this license |
|
| 772 |
- document. |
|
| 773 |
- |
|
| 774 |
- 4. Combined Works. |
|
| 775 |
- |
|
| 776 |
- You may convey a Combined Work under terms of your choice that, |
|
| 777 |
-taken together, effectively do not restrict modification of the |
|
| 778 |
-portions of the Library contained in the Combined Work and reverse |
|
| 779 |
-engineering for debugging such modifications, if you also do each of |
|
| 780 |
-the following: |
|
| 781 |
- |
|
| 782 |
- a) Give prominent notice with each copy of the Combined Work that |
|
| 783 |
- the Library is used in it and that the Library and its use are |
|
| 784 |
- covered by this License. |
|
| 785 |
- |
|
| 786 |
- b) Accompany the Combined Work with a copy of the GNU GPL and this license |
|
| 787 |
- document. |
|
| 788 |
- |
|
| 789 |
- c) For a Combined Work that displays copyright notices during |
|
| 790 |
- execution, include the copyright notice for the Library among |
|
| 791 |
- these notices, as well as a reference directing the user to the |
|
| 792 |
- copies of the GNU GPL and this license document. |
|
| 793 |
- |
|
| 794 |
- d) Do one of the following: |
|
| 795 |
- |
|
| 796 |
- 0) Convey the Minimal Corresponding Source under the terms of this |
|
| 797 |
- License, and the Corresponding Application Code in a form |
|
| 798 |
- suitable for, and under terms that permit, the user to |
|
| 799 |
- recombine or relink the Application with a modified version of |
|
| 800 |
- the Linked Version to produce a modified Combined Work, in the |
|
| 801 |
- manner specified by section 6 of the GNU GPL for conveying |
|
| 802 |
- Corresponding Source. |
|
| 803 |
- |
|
| 804 |
- 1) Use a suitable shared library mechanism for linking with the |
|
| 805 |
- Library. A suitable mechanism is one that (a) uses at run time |
|
| 806 |
- a copy of the Library already present on the user's computer |
|
| 807 |
- system, and (b) will operate properly with a modified version |
|
| 808 |
- of the Library that is interface-compatible with the Linked |
|
| 809 |
- Version. |
|
| 810 |
- |
|
| 811 |
- e) Provide Installation Information, but only if you would otherwise |
|
| 812 |
- be required to provide such information under section 6 of the |
|
| 813 |
- GNU GPL, and only to the extent that such information is |
|
| 814 |
- necessary to install and execute a modified version of the |
|
| 815 |
- Combined Work produced by recombining or relinking the |
|
| 816 |
- Application with a modified version of the Linked Version. (If |
|
| 817 |
- you use option 4d0, the Installation Information must accompany |
|
| 818 |
- the Minimal Corresponding Source and Corresponding Application |
|
| 819 |
- Code. If you use option 4d1, you must provide the Installation |
|
| 820 |
- Information in the manner specified by section 6 of the GNU GPL |
|
| 821 |
- for conveying Corresponding Source.) |
|
| 822 |
- |
|
| 823 |
- 5. Combined Libraries. |
|
| 824 |
- |
|
| 825 |
- You may place library facilities that are a work based on the |
|
| 826 |
-Library side by side in a single library together with other library |
|
| 827 |
-facilities that are not Applications and are not covered by this |
|
| 828 |
-License, and convey such a combined library under terms of your |
|
| 829 |
-choice, if you do both of the following: |
|
| 830 |
- |
|
| 831 |
- a) Accompany the combined library with a copy of the same work based |
|
| 832 |
- on the Library, uncombined with any other library facilities, |
|
| 833 |
- conveyed under the terms of this License. |
|
| 834 |
- |
|
| 835 |
- b) Give prominent notice with the combined library that part of it |
|
| 836 |
- is a work based on the Library, and explaining where to find the |
|
| 837 |
- accompanying uncombined form of the same work. |
|
| 838 |
- |
|
| 839 |
- 6. Revised Versions of the GNU Lesser General Public License. |
|
| 840 |
- |
|
| 841 |
- The Free Software Foundation may publish revised and/or new versions |
|
| 842 |
-of the GNU Lesser General Public License from time to time. Such new |
|
| 843 |
-versions will be similar in spirit to the present version, but may |
|
| 844 |
-differ in detail to address new problems or concerns. |
|
| 845 |
- |
|
| 846 |
- Each version is given a distinguishing version number. If the |
|
| 847 |
-Library as you received it specifies that a certain numbered version |
|
| 848 |
-of the GNU Lesser General Public License "or any later version" |
|
| 849 |
-applies to it, you have the option of following the terms and |
|
| 850 |
-conditions either of that published version or of any later version |
|
| 851 |
-published by the Free Software Foundation. If the Library as you |
|
| 852 |
-received it does not specify a version number of the GNU Lesser |
|
| 853 |
-General Public License, you may choose any version of the GNU Lesser |
|
| 854 |
-General Public License ever published by the Free Software Foundation. |
|
| 855 |
- |
|
| 856 |
- If the Library as you received it specifies that a proxy can decide |
|
| 857 |
-whether future versions of the GNU Lesser General Public License shall |
|
| 858 |
-apply, that proxy's public statement of acceptance of any version is |
|
| 859 |
-permanent authorization for you to choose that version for the |
|
| 860 |
-Library. |
|
| 861 |
- |
| ... | ... |
@@ -1,206 +0,0 @@ |
| 1 |
-declare module lib_comm {
|
|
| 2 |
- /** |
|
| 3 |
- * @author fenris |
|
| 4 |
- */ |
|
| 5 |
- type type_answering_executor<type_message_in, type_message_out> = (message: type_message_in) => lib_call.type_executor<type_message_out, Error>; |
|
| 6 |
- /** |
|
| 7 |
- * @author fenris |
|
| 8 |
- */ |
|
| 9 |
- type type_answering_promise<type_message_in, type_message_out> = (message: type_message_in) => lib_call.type_promise<type_message_out, Error>; |
|
| 10 |
- /** |
|
| 11 |
- * @author fenris |
|
| 12 |
- */ |
|
| 13 |
- type type_answering<type_message_in, type_message_out> = type_answering_promise<type_message_in, type_message_out>; |
|
| 14 |
-} |
|
| 15 |
-declare module lib_comm {
|
|
| 16 |
-} |
|
| 17 |
-declare module lib_comm {
|
|
| 18 |
- /** |
|
| 19 |
- * @author fenris |
|
| 20 |
- */ |
|
| 21 |
- interface interface_server<type_message_in, type_message_out> {
|
|
| 22 |
- /** |
|
| 23 |
- * @desc this method shall prepare the server to a point, where it just needs to be started afterwards |
|
| 24 |
- * @param {type_answering<type_message_in, type_message_out>} answering specifies how the server should handle incoming messages to formulate an answer
|
|
| 25 |
- * @author fenris |
|
| 26 |
- */ |
|
| 27 |
- setup(answering: type_answering<type_message_in, type_message_out>): lib_call.type_promise<void, Error>; |
|
| 28 |
- /** |
|
| 29 |
- * @desc starts to listen |
|
| 30 |
- * @author fenris |
|
| 31 |
- */ |
|
| 32 |
- run(): void; |
|
| 33 |
- } |
|
| 34 |
-} |
|
| 35 |
-declare module lib_comm {
|
|
| 36 |
- /** |
|
| 37 |
- * @author fenris |
|
| 38 |
- */ |
|
| 39 |
- type type_response_server_http = {
|
|
| 40 |
- code: int; |
|
| 41 |
- text: string; |
|
| 42 |
- }; |
|
| 43 |
- /** |
|
| 44 |
- * @author fenris |
|
| 45 |
- */ |
|
| 46 |
- type type_parameters_server_http = {
|
|
| 47 |
- protocol?: string; |
|
| 48 |
- port?: int; |
|
| 49 |
- headers?: {
|
|
| 50 |
- [name: string]: string; |
|
| 51 |
- }; |
|
| 52 |
- ssl_key?: string; |
|
| 53 |
- ssl_cert?: string; |
|
| 54 |
- ssl_ca?: string; |
|
| 55 |
- }; |
|
| 56 |
- /** |
|
| 57 |
- * @author fenris |
|
| 58 |
- */ |
|
| 59 |
- var default_parameters_server_http: type_parameters_server_http; |
|
| 60 |
-} |
|
| 61 |
-declare module lib_comm {
|
|
| 62 |
- /** |
|
| 63 |
- * @author fenris |
|
| 64 |
- */ |
|
| 65 |
- type type_server_http = {
|
|
| 66 |
- parameters: type_parameters_server_http; |
|
| 67 |
- answering: type_answering<string, type_response_server_http>; |
|
| 68 |
- serverinstance: any; |
|
| 69 |
- }; |
|
| 70 |
- /** |
|
| 71 |
- * @author fenris |
|
| 72 |
- */ |
|
| 73 |
- function server_http_construct(parameters?: type_parameters_server_http): type_server_http; |
|
| 74 |
- /** |
|
| 75 |
- * @author fenris |
|
| 76 |
- */ |
|
| 77 |
- function server_http_setup(subject: type_server_http, answering: type_answering<string, type_response_server_http>): lib_call.type_promise<void, Error>; |
|
| 78 |
- /** |
|
| 79 |
- * @author fenris |
|
| 80 |
- */ |
|
| 81 |
- function server_http_run(subject: type_server_http): void; |
|
| 82 |
-} |
|
| 83 |
-declare module lib_comm {
|
|
| 84 |
-} |
|
| 85 |
-declare module lib_comm {
|
|
| 86 |
- /** |
|
| 87 |
- * @author fenris |
|
| 88 |
- */ |
|
| 89 |
- class class_server_http implements interface_server<string, type_response_server_http> {
|
|
| 90 |
- /** |
|
| 91 |
- * @author fenris |
|
| 92 |
- */ |
|
| 93 |
- protected subject: type_server_http; |
|
| 94 |
- /** |
|
| 95 |
- * @author fenris |
|
| 96 |
- */ |
|
| 97 |
- constructor(parameters?: type_parameters_server_http); |
|
| 98 |
- /** |
|
| 99 |
- * @author fenris |
|
| 100 |
- * @implementation |
|
| 101 |
- */ |
|
| 102 |
- setup(answering: type_answering<string, type_response_server_http>): lib_call.type_promise<void, Error>; |
|
| 103 |
- /** |
|
| 104 |
- * @author fenris |
|
| 105 |
- * @implementation |
|
| 106 |
- */ |
|
| 107 |
- run(): void; |
|
| 108 |
- } |
|
| 109 |
-} |
|
| 110 |
-declare module lib_comm {
|
|
| 111 |
- /** |
|
| 112 |
- * @author fenris |
|
| 113 |
- */ |
|
| 114 |
- class class_server_mhttp implements interface_server<string, string> {
|
|
| 115 |
- /** |
|
| 116 |
- * @author fenris |
|
| 117 |
- */ |
|
| 118 |
- protected core: class_server_http; |
|
| 119 |
- /** |
|
| 120 |
- * @author fenris |
|
| 121 |
- */ |
|
| 122 |
- constructor(parameters?: type_parameters_server_http); |
|
| 123 |
- /** |
|
| 124 |
- * @author fenris |
|
| 125 |
- * @implementation |
|
| 126 |
- */ |
|
| 127 |
- setup(answering: type_answering<string, string>): lib_call.type_promise<void, Error>; |
|
| 128 |
- /** |
|
| 129 |
- * @author fenris |
|
| 130 |
- * @implementation |
|
| 131 |
- */ |
|
| 132 |
- run(): void; |
|
| 133 |
- } |
|
| 134 |
-} |
|
| 135 |
-declare module lib_comm {
|
|
| 136 |
- /** |
|
| 137 |
- * @desc wrapper for string-based servers |
|
| 138 |
- * @author fenris |
|
| 139 |
- */ |
|
| 140 |
- class class_server_complex implements interface_server<any, any> {
|
|
| 141 |
- /** |
|
| 142 |
- * @author fenris |
|
| 143 |
- */ |
|
| 144 |
- protected core: interface_server<string, string>; |
|
| 145 |
- /** |
|
| 146 |
- * @author fenris |
|
| 147 |
- */ |
|
| 148 |
- protected code: lib_code.interface_code<any, string>; |
|
| 149 |
- /** |
|
| 150 |
- * @author fenris |
|
| 151 |
- */ |
|
| 152 |
- constructor(core: interface_server<string, string>, code?: lib_code.interface_code<any, string>); |
|
| 153 |
- /** |
|
| 154 |
- * @author fenris |
|
| 155 |
- * @implementation |
|
| 156 |
- */ |
|
| 157 |
- setup(answering: type_answering<any, any>): lib_call.type_promise<void, Error>; |
|
| 158 |
- /** |
|
| 159 |
- * @author fenris |
|
| 160 |
- * @implementation |
|
| 161 |
- */ |
|
| 162 |
- run(): void; |
|
| 163 |
- } |
|
| 164 |
-} |
|
| 165 |
-declare module lib_comm {
|
|
| 166 |
- /** |
|
| 167 |
- */ |
|
| 168 |
- type type_server_common = {
|
|
| 169 |
- port: int; |
|
| 170 |
- handle: (input: string) => Promise<string>; |
|
| 171 |
- verbosity: int; |
|
| 172 |
- server: any; |
|
| 173 |
- }; |
|
| 174 |
- /** |
|
| 175 |
- */ |
|
| 176 |
- function server_common_make(port: int, handle: (input: string) => Promise<string>, verbosity?: int): type_server_common; |
|
| 177 |
- /** |
|
| 178 |
- */ |
|
| 179 |
- function server_common_start(subject: type_server_common, finish?: () => void): void; |
|
| 180 |
- /** |
|
| 181 |
- */ |
|
| 182 |
- function server_common_kill(subject: type_server_common): void; |
|
| 183 |
-} |
|
| 184 |
-declare module lib_comm {
|
|
| 185 |
- /** |
|
| 186 |
- * @author fenris |
|
| 187 |
- */ |
|
| 188 |
- class class_server_common {
|
|
| 189 |
- /** |
|
| 190 |
- * @author fenris |
|
| 191 |
- */ |
|
| 192 |
- protected subject: type_server_common; |
|
| 193 |
- /** |
|
| 194 |
- * @author fenris |
|
| 195 |
- */ |
|
| 196 |
- constructor(port: int, handle: (input: string) => Promise<string>, verbosity?: int); |
|
| 197 |
- /** |
|
| 198 |
- * @author fenris |
|
| 199 |
- */ |
|
| 200 |
- start(finish?: () => void): void; |
|
| 201 |
- /** |
|
| 202 |
- * @author fenris |
|
| 203 |
- */ |
|
| 204 |
- kill(): void; |
|
| 205 |
- } |
|
| 206 |
-} |
| ... | ... |
@@ -1,206 +0,0 @@ |
| 1 |
-declare module lib_comm {
|
|
| 2 |
- /** |
|
| 3 |
- * @author fenris |
|
| 4 |
- */ |
|
| 5 |
- type type_answering_executor<type_message_in, type_message_out> = (message: type_message_in) => lib_call.type_executor<type_message_out, Error>; |
|
| 6 |
- /** |
|
| 7 |
- * @author fenris |
|
| 8 |
- */ |
|
| 9 |
- type type_answering_promise<type_message_in, type_message_out> = (message: type_message_in) => lib_call.type_promise<type_message_out, Error>; |
|
| 10 |
- /** |
|
| 11 |
- * @author fenris |
|
| 12 |
- */ |
|
| 13 |
- type type_answering<type_message_in, type_message_out> = type_answering_promise<type_message_in, type_message_out>; |
|
| 14 |
-} |
|
| 15 |
-declare module lib_comm {
|
|
| 16 |
-} |
|
| 17 |
-declare module lib_comm {
|
|
| 18 |
- /** |
|
| 19 |
- * @author fenris |
|
| 20 |
- */ |
|
| 21 |
- interface interface_server<type_message_in, type_message_out> {
|
|
| 22 |
- /** |
|
| 23 |
- * @desc this method shall prepare the server to a point, where it just needs to be started afterwards |
|
| 24 |
- * @param {type_answering<type_message_in, type_message_out>} answering specifies how the server should handle incoming messages to formulate an answer
|
|
| 25 |
- * @author fenris |
|
| 26 |
- */ |
|
| 27 |
- setup(answering: type_answering<type_message_in, type_message_out>): lib_call.type_promise<void, Error>; |
|
| 28 |
- /** |
|
| 29 |
- * @desc starts to listen |
|
| 30 |
- * @author fenris |
|
| 31 |
- */ |
|
| 32 |
- run(): void; |
|
| 33 |
- } |
|
| 34 |
-} |
|
| 35 |
-declare module lib_comm {
|
|
| 36 |
- /** |
|
| 37 |
- * @author fenris |
|
| 38 |
- */ |
|
| 39 |
- type type_response_server_http = {
|
|
| 40 |
- code: int; |
|
| 41 |
- text: string; |
|
| 42 |
- }; |
|
| 43 |
- /** |
|
| 44 |
- * @author fenris |
|
| 45 |
- */ |
|
| 46 |
- type type_parameters_server_http = {
|
|
| 47 |
- protocol?: string; |
|
| 48 |
- port?: int; |
|
| 49 |
- headers?: {
|
|
| 50 |
- [name: string]: string; |
|
| 51 |
- }; |
|
| 52 |
- ssl_key?: string; |
|
| 53 |
- ssl_cert?: string; |
|
| 54 |
- ssl_ca?: string; |
|
| 55 |
- }; |
|
| 56 |
- /** |
|
| 57 |
- * @author fenris |
|
| 58 |
- */ |
|
| 59 |
- var default_parameters_server_http: type_parameters_server_http; |
|
| 60 |
-} |
|
| 61 |
-declare module lib_comm {
|
|
| 62 |
- /** |
|
| 63 |
- * @author fenris |
|
| 64 |
- */ |
|
| 65 |
- type type_server_http = {
|
|
| 66 |
- parameters: type_parameters_server_http; |
|
| 67 |
- answering: type_answering<string, type_response_server_http>; |
|
| 68 |
- serverinstance: any; |
|
| 69 |
- }; |
|
| 70 |
- /** |
|
| 71 |
- * @author fenris |
|
| 72 |
- */ |
|
| 73 |
- function server_http_construct(parameters?: type_parameters_server_http): type_server_http; |
|
| 74 |
- /** |
|
| 75 |
- * @author fenris |
|
| 76 |
- */ |
|
| 77 |
- function server_http_setup(subject: type_server_http, answering: type_answering<string, type_response_server_http>): lib_call.type_promise<void, Error>; |
|
| 78 |
- /** |
|
| 79 |
- * @author fenris |
|
| 80 |
- */ |
|
| 81 |
- function server_http_run(subject: type_server_http): void; |
|
| 82 |
-} |
|
| 83 |
-declare module lib_comm {
|
|
| 84 |
-} |
|
| 85 |
-declare module lib_comm {
|
|
| 86 |
- /** |
|
| 87 |
- * @author fenris |
|
| 88 |
- */ |
|
| 89 |
- class class_server_http implements interface_server<string, type_response_server_http> {
|
|
| 90 |
- /** |
|
| 91 |
- * @author fenris |
|
| 92 |
- */ |
|
| 93 |
- protected subject: type_server_http; |
|
| 94 |
- /** |
|
| 95 |
- * @author fenris |
|
| 96 |
- */ |
|
| 97 |
- constructor(parameters?: type_parameters_server_http); |
|
| 98 |
- /** |
|
| 99 |
- * @author fenris |
|
| 100 |
- * @implementation |
|
| 101 |
- */ |
|
| 102 |
- setup(answering: type_answering<string, type_response_server_http>): lib_call.type_promise<void, Error>; |
|
| 103 |
- /** |
|
| 104 |
- * @author fenris |
|
| 105 |
- * @implementation |
|
| 106 |
- */ |
|
| 107 |
- run(): void; |
|
| 108 |
- } |
|
| 109 |
-} |
|
| 110 |
-declare module lib_comm {
|
|
| 111 |
- /** |
|
| 112 |
- * @author fenris |
|
| 113 |
- */ |
|
| 114 |
- class class_server_mhttp implements interface_server<string, string> {
|
|
| 115 |
- /** |
|
| 116 |
- * @author fenris |
|
| 117 |
- */ |
|
| 118 |
- protected core: class_server_http; |
|
| 119 |
- /** |
|
| 120 |
- * @author fenris |
|
| 121 |
- */ |
|
| 122 |
- constructor(parameters?: type_parameters_server_http); |
|
| 123 |
- /** |
|
| 124 |
- * @author fenris |
|
| 125 |
- * @implementation |
|
| 126 |
- */ |
|
| 127 |
- setup(answering: type_answering<string, string>): lib_call.type_promise<void, Error>; |
|
| 128 |
- /** |
|
| 129 |
- * @author fenris |
|
| 130 |
- * @implementation |
|
| 131 |
- */ |
|
| 132 |
- run(): void; |
|
| 133 |
- } |
|
| 134 |
-} |
|
| 135 |
-declare module lib_comm {
|
|
| 136 |
- /** |
|
| 137 |
- * @desc wrapper for string-based servers |
|
| 138 |
- * @author fenris |
|
| 139 |
- */ |
|
| 140 |
- class class_server_complex implements interface_server<any, any> {
|
|
| 141 |
- /** |
|
| 142 |
- * @author fenris |
|
| 143 |
- */ |
|
| 144 |
- protected core: interface_server<string, string>; |
|
| 145 |
- /** |
|
| 146 |
- * @author fenris |
|
| 147 |
- */ |
|
| 148 |
- protected code: lib_code.interface_code<any, string>; |
|
| 149 |
- /** |
|
| 150 |
- * @author fenris |
|
| 151 |
- */ |
|
| 152 |
- constructor(core: interface_server<string, string>, code?: lib_code.interface_code<any, string>); |
|
| 153 |
- /** |
|
| 154 |
- * @author fenris |
|
| 155 |
- * @implementation |
|
| 156 |
- */ |
|
| 157 |
- setup(answering: type_answering<any, any>): lib_call.type_promise<void, Error>; |
|
| 158 |
- /** |
|
| 159 |
- * @author fenris |
|
| 160 |
- * @implementation |
|
| 161 |
- */ |
|
| 162 |
- run(): void; |
|
| 163 |
- } |
|
| 164 |
-} |
|
| 165 |
-declare module lib_comm {
|
|
| 166 |
- /** |
|
| 167 |
- */ |
|
| 168 |
- type type_server_common = {
|
|
| 169 |
- port: int; |
|
| 170 |
- handle: (input: string) => Promise<string>; |
|
| 171 |
- verbosity: int; |
|
| 172 |
- server: any; |
|
| 173 |
- }; |
|
| 174 |
- /** |
|
| 175 |
- */ |
|
| 176 |
- function server_common_make(port: int, handle: (input: string) => Promise<string>, verbosity?: int): type_server_common; |
|
| 177 |
- /** |
|
| 178 |
- */ |
|
| 179 |
- function server_common_start(subject: type_server_common, finish?: () => void): void; |
|
| 180 |
- /** |
|
| 181 |
- */ |
|
| 182 |
- function server_common_kill(subject: type_server_common): void; |
|
| 183 |
-} |
|
| 184 |
-declare module lib_comm {
|
|
| 185 |
- /** |
|
| 186 |
- * @author fenris |
|
| 187 |
- */ |
|
| 188 |
- class class_server_common {
|
|
| 189 |
- /** |
|
| 190 |
- * @author fenris |
|
| 191 |
- */ |
|
| 192 |
- protected subject: type_server_common; |
|
| 193 |
- /** |
|
| 194 |
- * @author fenris |
|
| 195 |
- */ |
|
| 196 |
- constructor(port: int, handle: (input: string) => Promise<string>, verbosity?: int); |
|
| 197 |
- /** |
|
| 198 |
- * @author fenris |
|
| 199 |
- */ |
|
| 200 |
- start(finish?: () => void): void; |
|
| 201 |
- /** |
|
| 202 |
- * @author fenris |
|
| 203 |
- */ |
|
| 204 |
- kill(): void; |
|
| 205 |
- } |
|
| 206 |
-} |
| ... | ... |
@@ -1,611 +0,0 @@ |
| 1 |
-/* |
|
| 2 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 3 |
- |
|
| 4 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 5 |
-<info@greenscale.de> |
|
| 6 |
- |
|
| 7 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 8 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 9 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 10 |
-(at your option) any later version. |
|
| 11 |
- |
|
| 12 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 13 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 14 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 15 |
-GNU Lesser General Public License for more details. |
|
| 16 |
- |
|
| 17 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 18 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 19 |
- */ |
|
| 20 |
-/* |
|
| 21 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 22 |
- |
|
| 23 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 24 |
-<info@greenscale.de> |
|
| 25 |
- |
|
| 26 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 27 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 28 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 29 |
-(at your option) any later version. |
|
| 30 |
- |
|
| 31 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 32 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 33 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 34 |
-GNU Lesser General Public License for more details. |
|
| 35 |
- |
|
| 36 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 37 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 38 |
- */ |
|
| 39 |
-var lib_comm; |
|
| 40 |
-(function (lib_comm) {
|
|
| 41 |
- /** |
|
| 42 |
- * @author fenris |
|
| 43 |
- */ |
|
| 44 |
- lib_trait.define("comm-server", {
|
|
| 45 |
- "state": null, |
|
| 46 |
- "message_in": null, |
|
| 47 |
- "message_out": null |
|
| 48 |
- }, {
|
|
| 49 |
- "setup": {
|
|
| 50 |
- "shape": {
|
|
| 51 |
- "name": "function", |
|
| 52 |
- "parameters": {
|
|
| 53 |
- "shape_input": {
|
|
| 54 |
- "name": "variable", |
|
| 55 |
- "parameters": {
|
|
| 56 |
- "name": "state" |
|
| 57 |
- } |
|
| 58 |
- }, |
|
| 59 |
- "shape_output": {
|
|
| 60 |
- "name": "function", |
|
| 61 |
- "parameters": {
|
|
| 62 |
- "shape_input": {
|
|
| 63 |
- "name": "any" |
|
| 64 |
- }, |
|
| 65 |
- "shape_output": {
|
|
| 66 |
- "name": "promise", |
|
| 67 |
- "parameters": {
|
|
| 68 |
- "shape_result": {
|
|
| 69 |
- "name": "variable", |
|
| 70 |
- "parameters": {
|
|
| 71 |
- "name": "state" |
|
| 72 |
- } |
|
| 73 |
- }, |
|
| 74 |
- "shape_reason": {
|
|
| 75 |
- "name": "any" |
|
| 76 |
- } |
|
| 77 |
- } |
|
| 78 |
- } |
|
| 79 |
- } |
|
| 80 |
- } |
|
| 81 |
- } |
|
| 82 |
- } |
|
| 83 |
- }, |
|
| 84 |
- "run": {
|
|
| 85 |
- "shape": {
|
|
| 86 |
- "name": "function", |
|
| 87 |
- "parameters": {
|
|
| 88 |
- "shape_input": {
|
|
| 89 |
- "name": "variable", |
|
| 90 |
- "parameters": {
|
|
| 91 |
- "name": "state" |
|
| 92 |
- } |
|
| 93 |
- }, |
|
| 94 |
- "shape_output": {
|
|
| 95 |
- "name": "void" |
|
| 96 |
- } |
|
| 97 |
- } |
|
| 98 |
- } |
|
| 99 |
- } |
|
| 100 |
- }); |
|
| 101 |
-})(lib_comm || (lib_comm = {}));
|
|
| 102 |
-/* |
|
| 103 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 104 |
- |
|
| 105 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 106 |
-<info@greenscale.de> |
|
| 107 |
- |
|
| 108 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 109 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 110 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 111 |
-(at your option) any later version. |
|
| 112 |
- |
|
| 113 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 114 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 115 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 116 |
-GNU Lesser General Public License for more details. |
|
| 117 |
- |
|
| 118 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 119 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 120 |
- */ |
|
| 121 |
-/* |
|
| 122 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 123 |
- |
|
| 124 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 125 |
-<info@greenscale.de> |
|
| 126 |
- |
|
| 127 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 128 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 129 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 130 |
-(at your option) any later version. |
|
| 131 |
- |
|
| 132 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 133 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 134 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 135 |
-GNU Lesser General Public License for more details. |
|
| 136 |
- |
|
| 137 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 138 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 139 |
- */ |
|
| 140 |
-var lib_comm; |
|
| 141 |
-(function (lib_comm) {
|
|
| 142 |
- /** |
|
| 143 |
- * @author fenris |
|
| 144 |
- */ |
|
| 145 |
- lib_comm.default_parameters_server_http = {
|
|
| 146 |
- "protocol": "http", |
|
| 147 |
- "port": 80, |
|
| 148 |
- "headers": {
|
|
| 149 |
- "Access-Control-Allow-Methods": "OPTIONS, POST", |
|
| 150 |
- "Access-Control-Allow-Origin": "*", |
|
| 151 |
- "Access-Control-Allow-Headers": "origin, content-type", |
|
| 152 |
- "Access-Control-Allow-Credentials": null, |
|
| 153 |
- "Content-Type": "plain/text; charset=utf-8", |
|
| 154 |
- } |
|
| 155 |
- }; |
|
| 156 |
-})(lib_comm || (lib_comm = {}));
|
|
| 157 |
-/* |
|
| 158 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 159 |
- |
|
| 160 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 161 |
-<info@greenscale.de> |
|
| 162 |
- |
|
| 163 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 164 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 165 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 166 |
-(at your option) any later version. |
|
| 167 |
- |
|
| 168 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 169 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 170 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 171 |
-GNU Lesser General Public License for more details. |
|
| 172 |
- |
|
| 173 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 174 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 175 |
- */ |
|
| 176 |
-var lib_comm; |
|
| 177 |
-(function (lib_comm) {
|
|
| 178 |
- /** |
|
| 179 |
- * @author fenris |
|
| 180 |
- */ |
|
| 181 |
- function server_http_construct(parameters = {}) {
|
|
| 182 |
- return {
|
|
| 183 |
- "parameters": lib_object.patched(lib_comm.default_parameters_server_http, parameters), |
|
| 184 |
- "answering": null, |
|
| 185 |
- "serverinstance": null, |
|
| 186 |
- }; |
|
| 187 |
- } |
|
| 188 |
- lib_comm.server_http_construct = server_http_construct; |
|
| 189 |
- /** |
|
| 190 |
- * @author fenris |
|
| 191 |
- */ |
|
| 192 |
- function server_http_setup(subject, answering) {
|
|
| 193 |
- subject.answering = answering; |
|
| 194 |
- let factory; |
|
| 195 |
- switch (subject.parameters.protocol) {
|
|
| 196 |
- case undefined: |
|
| 197 |
- case "http": {
|
|
| 198 |
- factory = ((options, listener) => require("http").createServer(listener));
|
|
| 199 |
- break; |
|
| 200 |
- } |
|
| 201 |
- case "https": {
|
|
| 202 |
- factory = ((options, listener) => require("https").createServer(options, listener));
|
|
| 203 |
- break; |
|
| 204 |
- } |
|
| 205 |
- default: {
|
|
| 206 |
- return lib_call.promise_reject(new Error(`no module for protocol '${subject.parameters.protocol}'`));
|
|
| 207 |
- break; |
|
| 208 |
- } |
|
| 209 |
- } |
|
| 210 |
- const listener = (request, response) => {
|
|
| 211 |
- // headers |
|
| 212 |
- {
|
|
| 213 |
- Object.keys(subject.parameters.headers) |
|
| 214 |
- .forEach((name) => {
|
|
| 215 |
- const value = subject.parameters.headers[name]; |
|
| 216 |
- if (value != null) {
|
|
| 217 |
- response.setHeader(name, value); |
|
| 218 |
- } |
|
| 219 |
- }); |
|
| 220 |
- } |
|
| 221 |
- let message = null; |
|
| 222 |
- request.on("data", (buffer) => {
|
|
| 223 |
- message = buffer.toString(); |
|
| 224 |
- }); |
|
| 225 |
- request.on("end", () => {
|
|
| 226 |
- switch (request.method) {
|
|
| 227 |
- case "OPTIONS": {
|
|
| 228 |
- response.writeHead(200); |
|
| 229 |
- response.end("options-echo");
|
|
| 230 |
- break; |
|
| 231 |
- } |
|
| 232 |
- case "POST": {
|
|
| 233 |
- lib_call.promise_then_close(subject.answering(message), (answer) => {
|
|
| 234 |
- response.writeHead(answer.code); |
|
| 235 |
- response.end(answer.text); |
|
| 236 |
- }, (error) => {
|
|
| 237 |
- console.error(error); |
|
| 238 |
- response.writeHead(500); |
|
| 239 |
- response.end("internal error");
|
|
| 240 |
- }); |
|
| 241 |
- break; |
|
| 242 |
- } |
|
| 243 |
- default: {
|
|
| 244 |
- response.writeHead(500); |
|
| 245 |
- response.end(`unhandled method ${request.method}`);
|
|
| 246 |
- break; |
|
| 247 |
- } |
|
| 248 |
- } |
|
| 249 |
- }); |
|
| 250 |
- }; |
|
| 251 |
- const _fs = require("fs");
|
|
| 252 |
- let options = {};
|
|
| 253 |
- if (subject.parameters.ssl_key !== undefined) {
|
|
| 254 |
- options["key"] = _fs.readFileSync(subject.parameters.ssl_key); |
|
| 255 |
- } |
|
| 256 |
- if (subject.parameters.ssl_cert !== undefined) {
|
|
| 257 |
- options["cert"] = _fs.readFileSync(subject.parameters.ssl_cert); |
|
| 258 |
- } |
|
| 259 |
- if (subject.parameters.ssl_ca !== undefined) {
|
|
| 260 |
- options["ca"] = _fs.readFileSync(subject.parameters.ssl_ca); |
|
| 261 |
- } |
|
| 262 |
- // setup server instance |
|
| 263 |
- subject.serverinstance = factory(options, listener); |
|
| 264 |
- subject.serverinstance.on("clientError", (error, socket) => {
|
|
| 265 |
- socket.end("HTTP/1.1 400 Bad Request\r\n\r\n");
|
|
| 266 |
- }); |
|
| 267 |
- return lib_call.promise_resolve(undefined); |
|
| 268 |
- } |
|
| 269 |
- lib_comm.server_http_setup = server_http_setup; |
|
| 270 |
- /** |
|
| 271 |
- * @author fenris |
|
| 272 |
- */ |
|
| 273 |
- function server_http_run(subject) {
|
|
| 274 |
- subject.serverinstance.listen(subject.parameters.port); |
|
| 275 |
- } |
|
| 276 |
- lib_comm.server_http_run = server_http_run; |
|
| 277 |
-})(lib_comm || (lib_comm = {}));
|
|
| 278 |
-/* |
|
| 279 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 280 |
- |
|
| 281 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 282 |
-<info@greenscale.de> |
|
| 283 |
- |
|
| 284 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 285 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 286 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 287 |
-(at your option) any later version. |
|
| 288 |
- |
|
| 289 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 290 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 291 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 292 |
-GNU Lesser General Public License for more details. |
|
| 293 |
- |
|
| 294 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 295 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 296 |
- */ |
|
| 297 |
-var lib_comm; |
|
| 298 |
-(function (lib_comm) {
|
|
| 299 |
- /** |
|
| 300 |
- * @author fenris |
|
| 301 |
- */ |
|
| 302 |
- lib_trait.attend("comm-server", "http", {
|
|
| 303 |
- "state": {
|
|
| 304 |
- "name": "any" |
|
| 305 |
- }, |
|
| 306 |
- "message_in": {
|
|
| 307 |
- "name": "string" |
|
| 308 |
- }, |
|
| 309 |
- "message_out": {
|
|
| 310 |
- "name": "any" // type_response_http |
|
| 311 |
- } |
|
| 312 |
- }, {
|
|
| 313 |
- "setup": () => (state) => (answering) => {
|
|
| 314 |
- return lib_comm.server_http_setup(state, answering).then(() => lib_call.promise_resolve(state)); |
|
| 315 |
- }, |
|
| 316 |
- "run": () => (state) => {
|
|
| 317 |
- return lib_comm.server_http_run(state); |
|
| 318 |
- } |
|
| 319 |
- }); |
|
| 320 |
-})(lib_comm || (lib_comm = {}));
|
|
| 321 |
-/* |
|
| 322 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 323 |
- |
|
| 324 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 325 |
-<info@greenscale.de> |
|
| 326 |
- |
|
| 327 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 328 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 329 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 330 |
-(at your option) any later version. |
|
| 331 |
- |
|
| 332 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 333 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 334 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 335 |
-GNU Lesser General Public License for more details. |
|
| 336 |
- |
|
| 337 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 338 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 339 |
- */ |
|
| 340 |
-var lib_comm; |
|
| 341 |
-(function (lib_comm) {
|
|
| 342 |
- /** |
|
| 343 |
- * @author fenris |
|
| 344 |
- */ |
|
| 345 |
- class class_server_http {
|
|
| 346 |
- /** |
|
| 347 |
- * @author fenris |
|
| 348 |
- */ |
|
| 349 |
- constructor(parameters = lib_comm.default_parameters_server_http) {
|
|
| 350 |
- this.subject = lib_comm.server_http_construct(parameters); |
|
| 351 |
- } |
|
| 352 |
- /** |
|
| 353 |
- * @author fenris |
|
| 354 |
- * @implementation |
|
| 355 |
- */ |
|
| 356 |
- setup(answering) {
|
|
| 357 |
- return lib_comm.server_http_setup(this.subject, answering); |
|
| 358 |
- } |
|
| 359 |
- /** |
|
| 360 |
- * @author fenris |
|
| 361 |
- * @implementation |
|
| 362 |
- */ |
|
| 363 |
- run() {
|
|
| 364 |
- return lib_comm.server_http_run(this.subject); |
|
| 365 |
- } |
|
| 366 |
- } |
|
| 367 |
- lib_comm.class_server_http = class_server_http; |
|
| 368 |
-})(lib_comm || (lib_comm = {}));
|
|
| 369 |
-/* |
|
| 370 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 371 |
- |
|
| 372 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 373 |
-<info@greenscale.de> |
|
| 374 |
- |
|
| 375 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 376 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 377 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 378 |
-(at your option) any later version. |
|
| 379 |
- |
|
| 380 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 381 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 382 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 383 |
-GNU Lesser General Public License for more details. |
|
| 384 |
- |
|
| 385 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 386 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 387 |
- */ |
|
| 388 |
-var lib_comm; |
|
| 389 |
-(function (lib_comm) {
|
|
| 390 |
- /** |
|
| 391 |
- * @author fenris |
|
| 392 |
- */ |
|
| 393 |
- class class_server_mhttp {
|
|
| 394 |
- /** |
|
| 395 |
- * @author fenris |
|
| 396 |
- */ |
|
| 397 |
- constructor(parameters = lib_comm.default_parameters_server_http) {
|
|
| 398 |
- this.core = new lib_comm.class_server_http(parameters); |
|
| 399 |
- } |
|
| 400 |
- /** |
|
| 401 |
- * @author fenris |
|
| 402 |
- * @implementation |
|
| 403 |
- */ |
|
| 404 |
- setup(answering) {
|
|
| 405 |
- return (this.core.setup((message) => (answering(message) |
|
| 406 |
- .then((text) => {
|
|
| 407 |
- let response = { "code": 200, "text": text };
|
|
| 408 |
- return lib_call.promise_resolve(response); |
|
| 409 |
- })))); |
|
| 410 |
- } |
|
| 411 |
- /** |
|
| 412 |
- * @author fenris |
|
| 413 |
- * @implementation |
|
| 414 |
- */ |
|
| 415 |
- run() {
|
|
| 416 |
- this.core.run(); |
|
| 417 |
- } |
|
| 418 |
- } |
|
| 419 |
- lib_comm.class_server_mhttp = class_server_mhttp; |
|
| 420 |
-})(lib_comm || (lib_comm = {}));
|
|
| 421 |
-/* |
|
| 422 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 423 |
- |
|
| 424 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 425 |
-<info@greenscale.de> |
|
| 426 |
- |
|
| 427 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 428 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 429 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 430 |
-(at your option) any later version. |
|
| 431 |
- |
|
| 432 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 433 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 434 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 435 |
-GNU Lesser General Public License for more details. |
|
| 436 |
- |
|
| 437 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 438 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 439 |
- */ |
|
| 440 |
-var lib_comm; |
|
| 441 |
-(function (lib_comm) {
|
|
| 442 |
- /** |
|
| 443 |
- * @desc wrapper for string-based servers |
|
| 444 |
- * @author fenris |
|
| 445 |
- */ |
|
| 446 |
- class class_server_complex {
|
|
| 447 |
- /** |
|
| 448 |
- * @author fenris |
|
| 449 |
- */ |
|
| 450 |
- constructor(core, code = new lib_code.class_code_pair(new lib_code.class_code_json(), new lib_code.class_code_uri())) {
|
|
| 451 |
- this.core = core; |
|
| 452 |
- this.code = code; |
|
| 453 |
- } |
|
| 454 |
- /** |
|
| 455 |
- * @author fenris |
|
| 456 |
- * @implementation |
|
| 457 |
- */ |
|
| 458 |
- setup(answering) {
|
|
| 459 |
- return (this.core.setup((message_in_raw) => {
|
|
| 460 |
- const message_in = ((message_in_raw == null) |
|
| 461 |
- ? null |
|
| 462 |
- : this.code.decode(message_in_raw)); |
|
| 463 |
- return (answering(message_in) |
|
| 464 |
- .then((message_out) => {
|
|
| 465 |
- const message_out_raw = this.code.encode(message_out); |
|
| 466 |
- return lib_call.promise_resolve(message_out_raw); |
|
| 467 |
- })); |
|
| 468 |
- })); |
|
| 469 |
- } |
|
| 470 |
- /** |
|
| 471 |
- * @author fenris |
|
| 472 |
- * @implementation |
|
| 473 |
- */ |
|
| 474 |
- run() {
|
|
| 475 |
- this.core.run(); |
|
| 476 |
- } |
|
| 477 |
- } |
|
| 478 |
- lib_comm.class_server_complex = class_server_complex; |
|
| 479 |
-})(lib_comm || (lib_comm = {}));
|
|
| 480 |
-/* |
|
| 481 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 482 |
- |
|
| 483 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 484 |
-<info@greenscale.de> |
|
| 485 |
- |
|
| 486 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 487 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 488 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 489 |
-(at your option) any later version. |
|
| 490 |
- |
|
| 491 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 492 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 493 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 494 |
-GNU Lesser General Public License for more details. |
|
| 495 |
- |
|
| 496 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 497 |
-along with »bacterio-plankton:comm-server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 498 |
- */ |
|
| 499 |
-var lib_comm; |
|
| 500 |
-(function (lib_comm) {
|
|
| 501 |
- /** |
|
| 502 |
- */ |
|
| 503 |
- function server_common_make(port, handle, verbosity = 1) {
|
|
| 504 |
- return {
|
|
| 505 |
- "port": port, |
|
| 506 |
- "handle": handle, |
|
| 507 |
- "verbosity": verbosity, |
|
| 508 |
- "server": undefined, |
|
| 509 |
- }; |
|
| 510 |
- } |
|
| 511 |
- lib_comm.server_common_make = server_common_make; |
|
| 512 |
- /** |
|
| 513 |
- */ |
|
| 514 |
- function log(subject, level, message) {
|
|
| 515 |
- if (subject.verbosity >= level) {
|
|
| 516 |
- console.log("[server]", message);
|
|
| 517 |
- } |
|
| 518 |
- else {
|
|
| 519 |
- // do nothing |
|
| 520 |
- } |
|
| 521 |
- } |
|
| 522 |
- /** |
|
| 523 |
- */ |
|
| 524 |
- function server_common_start(subject, finish = undefined) {
|
|
| 525 |
- const net = require("net");
|
|
| 526 |
- subject.server = net.createServer((socket) => {
|
|
| 527 |
- log(subject, 2, "client connected"); |
|
| 528 |
- socket.on("readable", () => {
|
|
| 529 |
- let chunk; |
|
| 530 |
- while (!((chunk = socket.read()) === null)) {
|
|
| 531 |
- const input = chunk.toString(); |
|
| 532 |
- log(subject, 3, "reading: " + input); |
|
| 533 |
- subject.handle(input) |
|
| 534 |
- .then((output) => {
|
|
| 535 |
- log(subject, 3, "writing: " + output); |
|
| 536 |
- socket.write(output); |
|
| 537 |
- socket.end(); |
|
| 538 |
- }) |
|
| 539 |
- .catch((error) => {
|
|
| 540 |
- log(subject, 1, "handle failed: " + error.toString()); |
|
| 541 |
- }); |
|
| 542 |
- } |
|
| 543 |
- }); |
|
| 544 |
- socket.on("end", () => {
|
|
| 545 |
- log(subject, 2, "client disconnected"); |
|
| 546 |
- }); |
|
| 547 |
- }); |
|
| 548 |
- subject.server.on("error", (error) => {
|
|
| 549 |
- throw error; |
|
| 550 |
- }); |
|
| 551 |
- subject.server.listen(subject.port, () => {
|
|
| 552 |
- log(subject, 1, "listening on port " + subject.port.toFixed(0)); |
|
| 553 |
- if (!(finish === undefined)) {
|
|
| 554 |
- finish(); |
|
| 555 |
- } |
|
| 556 |
- }); |
|
| 557 |
- } |
|
| 558 |
- lib_comm.server_common_start = server_common_start; |
|
| 559 |
- /** |
|
| 560 |
- */ |
|
| 561 |
- function server_common_kill(subject) {
|
|
| 562 |
- subject.server.close(); |
|
| 563 |
- } |
|
| 564 |
- lib_comm.server_common_kill = server_common_kill; |
|
| 565 |
-})(lib_comm || (lib_comm = {}));
|
|
| 566 |
-/* |
|
| 567 |
-This file is part of »bacterio-plankton:comm-server«. |
|
| 568 |
- |
|
| 569 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 570 |
-<info@greenscale.de> |
|
| 571 |
- |
|
| 572 |
-»bacterio-plankton:comm-server« is free software: you can redistribute it and/or modify |
|
| 573 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 574 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 575 |
-(at your option) any later version. |
|
| 576 |
- |
|
| 577 |
-»bacterio-plankton:comm-server« is distributed in the hope that it will be useful, |
|
| 578 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 579 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 580 |
-GNU Lesser General Public License for more details. |
|
| 581 |
- |
|
| 582 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 583 |
-along with »bacterio-plankton:comm-server«. If not, see <common://www.gnu.org/licenses/>. |
|
| 584 |
- */ |
|
| 585 |
-var lib_comm; |
|
| 586 |
-(function (lib_comm) {
|
|
| 587 |
- /** |
|
| 588 |
- * @author fenris |
|
| 589 |
- */ |
|
| 590 |
- class class_server_common {
|
|
| 591 |
- /** |
|
| 592 |
- * @author fenris |
|
| 593 |
- */ |
|
| 594 |
- constructor(port, handle, verbosity = undefined) {
|
|
| 595 |
- this.subject = lib_comm.server_common_make(port, handle, verbosity); |
|
| 596 |
- } |
|
| 597 |
- /** |
|
| 598 |
- * @author fenris |
|
| 599 |
- */ |
|
| 600 |
- start(finish = undefined) {
|
|
| 601 |
- return lib_comm.server_common_start(this.subject, finish); |
|
| 602 |
- } |
|
| 603 |
- /** |
|
| 604 |
- * @author fenris |
|
| 605 |
- */ |
|
| 606 |
- kill() {
|
|
| 607 |
- return lib_comm.server_common_kill(this.subject); |
|
| 608 |
- } |
|
| 609 |
- } |
|
| 610 |
- lib_comm.class_server_common = class_server_common; |
|
| 611 |
-})(lib_comm || (lib_comm = {}));
|
| ... | ... |
@@ -48,3 +48,45 @@ declare module lib_http {
|
| 48 | 48 |
*/ |
| 49 | 49 |
function decode_response(response_raw: string): type_response; |
| 50 | 50 |
} |
| 51 |
+declare module lib_http {
|
|
| 52 |
+ /** |
|
| 53 |
+ * @author fenris |
|
| 54 |
+ */ |
|
| 55 |
+ class class_http_request implements lib_code.interface_code<type_request, string> {
|
|
| 56 |
+ /** |
|
| 57 |
+ * @author fenris |
|
| 58 |
+ */ |
|
| 59 |
+ constructor(); |
|
| 60 |
+ /** |
|
| 61 |
+ * @implementation |
|
| 62 |
+ * @author fenris |
|
| 63 |
+ */ |
|
| 64 |
+ encode(x: type_request): string; |
|
| 65 |
+ /** |
|
| 66 |
+ * @implementation |
|
| 67 |
+ * @author fenris |
|
| 68 |
+ */ |
|
| 69 |
+ decode(x: string): type_request; |
|
| 70 |
+ } |
|
| 71 |
+ /** |
|
| 72 |
+ * @author fenris |
|
| 73 |
+ */ |
|
| 74 |
+ class class_http_response implements lib_code.interface_code<type_response, string> {
|
|
| 75 |
+ /** |
|
| 76 |
+ * @author fenris |
|
| 77 |
+ */ |
|
| 78 |
+ constructor(); |
|
| 79 |
+ /** |
|
| 80 |
+ * @implementation |
|
| 81 |
+ * @author fenris |
|
| 82 |
+ */ |
|
| 83 |
+ encode(x: type_response): string; |
|
| 84 |
+ /** |
|
| 85 |
+ * @implementation |
|
| 86 |
+ * @author fenris |
|
| 87 |
+ */ |
|
| 88 |
+ decode(x: string): type_response; |
|
| 89 |
+ } |
|
| 90 |
+} |
|
| 91 |
+declare module lib_http {
|
|
| 92 |
+} |
| ... | ... |
@@ -227,3 +227,133 @@ var lib_http; |
| 227 | 227 |
} |
| 228 | 228 |
lib_http.decode_response = decode_response; |
| 229 | 229 |
})(lib_http || (lib_http = {}));
|
| 230 |
+/* |
|
| 231 |
+This file is part of »bacterio-plankton:http«. |
|
| 232 |
+ |
|
| 233 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 234 |
+<info@greenscale.de> |
|
| 235 |
+ |
|
| 236 |
+»bacterio-plankton:http« is free software: you can redistribute it and/or modify |
|
| 237 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 238 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 239 |
+(at your option) any later version. |
|
| 240 |
+ |
|
| 241 |
+»bacterio-plankton:http« is distributed in the hope that it will be useful, |
|
| 242 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 243 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 244 |
+GNU Lesser General Public License for more details. |
|
| 245 |
+ |
|
| 246 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 247 |
+along with »bacterio-plankton:http«. If not, see <http://www.gnu.org/licenses/>. |
|
| 248 |
+ */ |
|
| 249 |
+var lib_http; |
|
| 250 |
+(function (lib_http) {
|
|
| 251 |
+ /** |
|
| 252 |
+ * @author fenris |
|
| 253 |
+ */ |
|
| 254 |
+ class class_http_request {
|
|
| 255 |
+ /** |
|
| 256 |
+ * @author fenris |
|
| 257 |
+ */ |
|
| 258 |
+ constructor() {
|
|
| 259 |
+ } |
|
| 260 |
+ /** |
|
| 261 |
+ * @implementation |
|
| 262 |
+ * @author fenris |
|
| 263 |
+ */ |
|
| 264 |
+ encode(x) {
|
|
| 265 |
+ return lib_http.encode_request(x); |
|
| 266 |
+ } |
|
| 267 |
+ /** |
|
| 268 |
+ * @implementation |
|
| 269 |
+ * @author fenris |
|
| 270 |
+ */ |
|
| 271 |
+ decode(x) {
|
|
| 272 |
+ return lib_http.decode_request(x); |
|
| 273 |
+ } |
|
| 274 |
+ } |
|
| 275 |
+ lib_http.class_http_request = class_http_request; |
|
| 276 |
+ /** |
|
| 277 |
+ * @author fenris |
|
| 278 |
+ */ |
|
| 279 |
+ class class_http_response {
|
|
| 280 |
+ /** |
|
| 281 |
+ * @author fenris |
|
| 282 |
+ */ |
|
| 283 |
+ constructor() {
|
|
| 284 |
+ } |
|
| 285 |
+ /** |
|
| 286 |
+ * @implementation |
|
| 287 |
+ * @author fenris |
|
| 288 |
+ */ |
|
| 289 |
+ encode(x) {
|
|
| 290 |
+ return lib_http.encode_response(x); |
|
| 291 |
+ } |
|
| 292 |
+ /** |
|
| 293 |
+ * @implementation |
|
| 294 |
+ * @author fenris |
|
| 295 |
+ */ |
|
| 296 |
+ decode(x) {
|
|
| 297 |
+ return lib_http.decode_response(x); |
|
| 298 |
+ } |
|
| 299 |
+ } |
|
| 300 |
+ lib_http.class_http_response = class_http_response; |
|
| 301 |
+})(lib_http || (lib_http = {}));
|
|
| 302 |
+/* |
|
| 303 |
+This file is part of »bacterio-plankton:http«. |
|
| 304 |
+ |
|
| 305 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 306 |
+<info@greenscale.de> |
|
| 307 |
+ |
|
| 308 |
+»bacterio-plankton:http« is free software: you can redistribute it and/or modify |
|
| 309 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 310 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 311 |
+(at your option) any later version. |
|
| 312 |
+ |
|
| 313 |
+»bacterio-plankton:http« is distributed in the hope that it will be useful, |
|
| 314 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 315 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 316 |
+GNU Lesser General Public License for more details. |
|
| 317 |
+ |
|
| 318 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 319 |
+along with »bacterio-plankton:http«. If not, see <http://www.gnu.org/licenses/>. |
|
| 320 |
+ */ |
|
| 321 |
+var lib_http; |
|
| 322 |
+(function (lib_http) {
|
|
| 323 |
+ /** |
|
| 324 |
+ * @author fenris |
|
| 325 |
+ */ |
|
| 326 |
+ lib_trait.attend("code", "http_request", {
|
|
| 327 |
+ "from": {
|
|
| 328 |
+ "name": "any" |
|
| 329 |
+ }, |
|
| 330 |
+ "to": {
|
|
| 331 |
+ "name": "string" |
|
| 332 |
+ } |
|
| 333 |
+ }, {
|
|
| 334 |
+ "encode": () => (x) => {
|
|
| 335 |
+ return lib_http.encode_request(x); |
|
| 336 |
+ }, |
|
| 337 |
+ "decode": () => (y) => {
|
|
| 338 |
+ return lib_http.decode_request(y); |
|
| 339 |
+ } |
|
| 340 |
+ }); |
|
| 341 |
+ /** |
|
| 342 |
+ * @author fenris |
|
| 343 |
+ */ |
|
| 344 |
+ lib_trait.attend("code", "http_response", {
|
|
| 345 |
+ "from": {
|
|
| 346 |
+ "name": "any" |
|
| 347 |
+ }, |
|
| 348 |
+ "to": {
|
|
| 349 |
+ "name": "string" |
|
| 350 |
+ } |
|
| 351 |
+ }, {
|
|
| 352 |
+ "encode": () => (x) => {
|
|
| 353 |
+ return lib_http.encode_response(x); |
|
| 354 |
+ }, |
|
| 355 |
+ "decode": () => (y) => {
|
|
| 356 |
+ return lib_http.decode_response(y); |
|
| 357 |
+ } |
|
| 358 |
+ }); |
|
| 359 |
+})(lib_http || (lib_http = {}));
|
| ... | ... |
@@ -1,18 +1,18 @@ |
| 1 | 1 |
Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
| 2 | 2 |
<info@greenscale.de> |
| 3 | 3 |
|
| 4 |
-»bacterio-plankton:call« is free software: you can redistribute it and/or modify |
|
| 4 |
+»bacterio-plankton:json« is free software: you can redistribute it and/or modify |
|
| 5 | 5 |
it under the terms of the GNU Lesser General Public License as published by |
| 6 | 6 |
the Free Software Foundation, either version 3 of the License, or |
| 7 | 7 |
(at your option) any later version. |
| 8 | 8 |
|
| 9 |
-»bacterio-plankton:call« is distributed in the hope that it will be useful, |
|
| 9 |
+»bacterio-plankton:json« is distributed in the hope that it will be useful, |
|
| 10 | 10 |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 | 11 |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 12 | 12 |
GNU Lesser General Public License for more details. |
| 13 | 13 |
|
| 14 | 14 |
You should have received a copy of the GNU Lesser General Public License |
| 15 |
-along with »bacterio-plankton:call«. If not, see <http://www.gnu.org/licenses/>. |
|
| 15 |
+along with »bacterio-plankton:json«. If not, see <http://www.gnu.org/licenses/>. |
|
| 16 | 16 |
|
| 17 | 17 |
|
| 18 | 18 |
|
| ... | ... |
@@ -0,0 +1,33 @@ |
| 1 |
+declare module lib_json {
|
|
| 2 |
+ /** |
|
| 3 |
+ * @author fenris |
|
| 4 |
+ */ |
|
| 5 |
+ function encode(x: any, formatted?: boolean): string; |
|
| 6 |
+ /** |
|
| 7 |
+ * @author fenris |
|
| 8 |
+ */ |
|
| 9 |
+ function decode(x: string): any; |
|
| 10 |
+} |
|
| 11 |
+declare module lib_json {
|
|
| 12 |
+} |
|
| 13 |
+declare module lib_json {
|
|
| 14 |
+ /** |
|
| 15 |
+ * @author fenris |
|
| 16 |
+ */ |
|
| 17 |
+ class class_json implements lib_code.interface_code<any, string> {
|
|
| 18 |
+ /** |
|
| 19 |
+ * @author fenris |
|
| 20 |
+ */ |
|
| 21 |
+ constructor(); |
|
| 22 |
+ /** |
|
| 23 |
+ * @implementation |
|
| 24 |
+ * @author fenris |
|
| 25 |
+ */ |
|
| 26 |
+ encode(x: any): string; |
|
| 27 |
+ /** |
|
| 28 |
+ * @implementation |
|
| 29 |
+ * @author fenris |
|
| 30 |
+ */ |
|
| 31 |
+ decode(x: string): any; |
|
| 32 |
+ } |
|
| 33 |
+} |
| ... | ... |
@@ -0,0 +1,123 @@ |
| 1 |
+/* |
|
| 2 |
+This file is part of »bacterio-plankton:json«. |
|
| 3 |
+ |
|
| 4 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 5 |
+<info@greenscale.de> |
|
| 6 |
+ |
|
| 7 |
+»bacterio-plankton:json« is free software: you can redistribute it and/or modify |
|
| 8 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 9 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 10 |
+(at your option) any later version. |
|
| 11 |
+ |
|
| 12 |
+»bacterio-plankton:json« is distributed in the hope that it will be useful, |
|
| 13 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 14 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 15 |
+GNU Lesser General Public License for more details. |
|
| 16 |
+ |
|
| 17 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 18 |
+along with »bacterio-plankton:json«. If not, see <http://www.gnu.org/licenses/>. |
|
| 19 |
+ */ |
|
| 20 |
+var lib_json; |
|
| 21 |
+(function (lib_json) {
|
|
| 22 |
+ /** |
|
| 23 |
+ * @author fenris |
|
| 24 |
+ */ |
|
| 25 |
+ function encode(x, formatted = false) {
|
|
| 26 |
+ return JSON.stringify(x, undefined, formatted ? "\t" : undefined); |
|
| 27 |
+ } |
|
| 28 |
+ lib_json.encode = encode; |
|
| 29 |
+ /** |
|
| 30 |
+ * @author fenris |
|
| 31 |
+ */ |
|
| 32 |
+ function decode(x) {
|
|
| 33 |
+ return JSON.parse(x); |
|
| 34 |
+ } |
|
| 35 |
+ lib_json.decode = decode; |
|
| 36 |
+})(lib_json || (lib_json = {}));
|
|
| 37 |
+/* |
|
| 38 |
+This file is part of »bacterio-plankton:json«. |
|
| 39 |
+ |
|
| 40 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 41 |
+<info@greenscale.de> |
|
| 42 |
+ |
|
| 43 |
+»bacterio-plankton:json« is free software: you can redistribute it and/or modify |
|
| 44 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 45 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 46 |
+(at your option) any later version. |
|
| 47 |
+ |
|
| 48 |
+»bacterio-plankton:json« is distributed in the hope that it will be useful, |
|
| 49 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 50 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 51 |
+GNU Lesser General Public License for more details. |
|
| 52 |
+ |
|
| 53 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 54 |
+along with »bacterio-plankton:json«. If not, see <http://www.gnu.org/licenses/>. |
|
| 55 |
+ */ |
|
| 56 |
+var lib_json; |
|
| 57 |
+(function (lib_json) {
|
|
| 58 |
+ /** |
|
| 59 |
+ * @author fenris |
|
| 60 |
+ */ |
|
| 61 |
+ lib_trait.attend("code", "json", {
|
|
| 62 |
+ "from": {
|
|
| 63 |
+ "name": "any" |
|
| 64 |
+ }, |
|
| 65 |
+ "to": {
|
|
| 66 |
+ "name": "string" |
|
| 67 |
+ } |
|
| 68 |
+ }, {
|
|
| 69 |
+ "encode": () => (x) => {
|
|
| 70 |
+ return lib_json.encode(x); |
|
| 71 |
+ }, |
|
| 72 |
+ "decode": () => (y) => {
|
|
| 73 |
+ return lib_json.decode(y); |
|
| 74 |
+ } |
|
| 75 |
+ }); |
|
| 76 |
+})(lib_json || (lib_json = {}));
|
|
| 77 |
+/* |
|
| 78 |
+This file is part of »bacterio-plankton:json«. |
|
| 79 |
+ |
|
| 80 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 81 |
+<info@greenscale.de> |
|
| 82 |
+ |
|
| 83 |
+»bacterio-plankton:json« is free software: you can redistribute it and/or modify |
|
| 84 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 85 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 86 |
+(at your option) any later version. |
|
| 87 |
+ |
|
| 88 |
+»bacterio-plankton:json« is distributed in the hope that it will be useful, |
|
| 89 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 90 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 91 |
+GNU Lesser General Public License for more details. |
|
| 92 |
+ |
|
| 93 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 94 |
+along with »bacterio-plankton:json«. If not, see <http://www.gnu.org/licenses/>. |
|
| 95 |
+ */ |
|
| 96 |
+var lib_json; |
|
| 97 |
+(function (lib_json) {
|
|
| 98 |
+ /** |
|
| 99 |
+ * @author fenris |
|
| 100 |
+ */ |
|
| 101 |
+ class class_json {
|
|
| 102 |
+ /** |
|
| 103 |
+ * @author fenris |
|
| 104 |
+ */ |
|
| 105 |
+ constructor() {
|
|
| 106 |
+ } |
|
| 107 |
+ /** |
|
| 108 |
+ * @implementation |
|
| 109 |
+ * @author fenris |
|
| 110 |
+ */ |
|
| 111 |
+ encode(x) {
|
|
| 112 |
+ return lib_json.encode(x); |
|
| 113 |
+ } |
|
| 114 |
+ /** |
|
| 115 |
+ * @implementation |
|
| 116 |
+ * @author fenris |
|
| 117 |
+ */ |
|
| 118 |
+ decode(x) {
|
|
| 119 |
+ return lib_json.decode(x); |
|
| 120 |
+ } |
|
| 121 |
+ } |
|
| 122 |
+ lib_json.class_json = class_json; |
|
| 123 |
+})(lib_json || (lib_json = {}));
|
| ... | ... |
@@ -1,861 +0,0 @@ |
| 1 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 2 |
-<info@greenscale.de> |
|
| 3 |
- |
|
| 4 |
-»bacterio-plankton:object« is free software: you can redistribute it and/or modify |
|
| 5 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 6 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 7 |
-(at your option) any later version. |
|
| 8 |
- |
|
| 9 |
-»bacterio-plankton:object« is distributed in the hope that it will be useful, |
|
| 10 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 11 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 12 |
-GNU Lesser General Public License for more details. |
|
| 13 |
- |
|
| 14 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 15 |
-along with »bacterio-plankton:object«. If not, see <http://www.gnu.org/licenses/>. |
|
| 16 |
- |
|
| 17 |
- |
|
| 18 |
- |
|
| 19 |
- GNU GENERAL PUBLIC LICENSE |
|
| 20 |
- Version 3, 29 June 2007 |
|
| 21 |
- |
|
| 22 |
- Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/> |
|
| 23 |
- Everyone is permitted to copy and distribute verbatim copies |
|
| 24 |
- of this license document, but changing it is not allowed. |
|
| 25 |
- |
|
| 26 |
- Preamble |
|
| 27 |
- |
|
| 28 |
- The GNU General Public License is a free, copyleft license for |
|
| 29 |
-software and other kinds of works. |
|
| 30 |
- |
|
| 31 |
- The licenses for most software and other practical works are designed |
|
| 32 |
-to take away your freedom to share and change the works. By contrast, |
|
| 33 |
-the GNU General Public License is intended to guarantee your freedom to |
|
| 34 |
-share and change all versions of a program--to make sure it remains free |
|
| 35 |
-software for all its users. We, the Free Software Foundation, use the |
|
| 36 |
-GNU General Public License for most of our software; it applies also to |
|
| 37 |
-any other work released this way by its authors. You can apply it to |
|
| 38 |
-your programs, too. |
|
| 39 |
- |
|
| 40 |
- When we speak of free software, we are referring to freedom, not |
|
| 41 |
-price. Our General Public Licenses are designed to make sure that you |
|
| 42 |
-have the freedom to distribute copies of free software (and charge for |
|
| 43 |
-them if you wish), that you receive source code or can get it if you |
|
| 44 |
-want it, that you can change the software or use pieces of it in new |
|
| 45 |
-free programs, and that you know you can do these things. |
|
| 46 |
- |
|
| 47 |
- To protect your rights, we need to prevent others from denying you |
|
| 48 |
-these rights or asking you to surrender the rights. Therefore, you have |
|
| 49 |
-certain responsibilities if you distribute copies of the software, or if |
|
| 50 |
-you modify it: responsibilities to respect the freedom of others. |
|
| 51 |
- |
|
| 52 |
- For example, if you distribute copies of such a program, whether |
|
| 53 |
-gratis or for a fee, you must pass on to the recipients the same |
|
| 54 |
-freedoms that you received. You must make sure that they, too, receive |
|
| 55 |
-or can get the source code. And you must show them these terms so they |
|
| 56 |
-know their rights. |
|
| 57 |
- |
|
| 58 |
- Developers that use the GNU GPL protect your rights with two steps: |
|
| 59 |
-(1) assert copyright on the software, and (2) offer you this License |
|
| 60 |
-giving you legal permission to copy, distribute and/or modify it. |
|
| 61 |
- |
|
| 62 |
- For the developers' and authors' protection, the GPL clearly explains |
|
| 63 |
-that there is no warranty for this free software. For both users' and |
|
| 64 |
-authors' sake, the GPL requires that modified versions be marked as |
|
| 65 |
-changed, so that their problems will not be attributed erroneously to |
|
| 66 |
-authors of previous versions. |
|
| 67 |
- |
|
| 68 |
- Some devices are designed to deny users access to install or run |
|
| 69 |
-modified versions of the software inside them, although the manufacturer |
|
| 70 |
-can do so. This is fundamentally incompatible with the aim of |
|
| 71 |
-protecting users' freedom to change the software. The systematic |
|
| 72 |
-pattern of such abuse occurs in the area of products for individuals to |
|
| 73 |
-use, which is precisely where it is most unacceptable. Therefore, we |
|
| 74 |
-have designed this version of the GPL to prohibit the practice for those |
|
| 75 |
-products. If such problems arise substantially in other domains, we |
|
| 76 |
-stand ready to extend this provision to those domains in future versions |
|
| 77 |
-of the GPL, as needed to protect the freedom of users. |
|
| 78 |
- |
|
| 79 |
- Finally, every program is threatened constantly by software patents. |
|
| 80 |
-States should not allow patents to restrict development and use of |
|
| 81 |
-software on general-purpose computers, but in those that do, we wish to |
|
| 82 |
-avoid the special danger that patents applied to a free program could |
|
| 83 |
-make it effectively proprietary. To prevent this, the GPL assures that |
|
| 84 |
-patents cannot be used to render the program non-free. |
|
| 85 |
- |
|
| 86 |
- The precise terms and conditions for copying, distribution and |
|
| 87 |
-modification follow. |
|
| 88 |
- |
|
| 89 |
- TERMS AND CONDITIONS |
|
| 90 |
- |
|
| 91 |
- 0. Definitions. |
|
| 92 |
- |
|
| 93 |
- "This License" refers to version 3 of the GNU General Public License. |
|
| 94 |
- |
|
| 95 |
- "Copyright" also means copyright-like laws that apply to other kinds of |
|
| 96 |
-works, such as semiconductor masks. |
|
| 97 |
- |
|
| 98 |
- "The Program" refers to any copyrightable work licensed under this |
|
| 99 |
-License. Each licensee is addressed as "you". "Licensees" and |
|
| 100 |
-"recipients" may be individuals or organizations. |
|
| 101 |
- |
|
| 102 |
- To "modify" a work means to copy from or adapt all or part of the work |
|
| 103 |
-in a fashion requiring copyright permission, other than the making of an |
|
| 104 |
-exact copy. The resulting work is called a "modified version" of the |
|
| 105 |
-earlier work or a work "based on" the earlier work. |
|
| 106 |
- |
|
| 107 |
- A "covered work" means either the unmodified Program or a work based |
|
| 108 |
-on the Program. |
|
| 109 |
- |
|
| 110 |
- To "propagate" a work means to do anything with it that, without |
|
| 111 |
-permission, would make you directly or secondarily liable for |
|
| 112 |
-infringement under applicable copyright law, except executing it on a |
|
| 113 |
-computer or modifying a private copy. Propagation includes copying, |
|
| 114 |
-distribution (with or without modification), making available to the |
|
| 115 |
-public, and in some countries other activities as well. |
|
| 116 |
- |
|
| 117 |
- To "convey" a work means any kind of propagation that enables other |
|
| 118 |
-parties to make or receive copies. Mere interaction with a user through |
|
| 119 |
-a computer network, with no transfer of a copy, is not conveying. |
|
| 120 |
- |
|
| 121 |
- An interactive user interface displays "Appropriate Legal Notices" |
|
| 122 |
-to the extent that it includes a convenient and prominently visible |
|
| 123 |
-feature that (1) displays an appropriate copyright notice, and (2) |
|
| 124 |
-tells the user that there is no warranty for the work (except to the |
|
| 125 |
-extent that warranties are provided), that licensees may convey the |
|
| 126 |
-work under this License, and how to view a copy of this License. If |
|
| 127 |
-the interface presents a list of user commands or options, such as a |
|
| 128 |
-menu, a prominent item in the list meets this criterion. |
|
| 129 |
- |
|
| 130 |
- 1. Source Code. |
|
| 131 |
- |
|
| 132 |
- The "source code" for a work means the preferred form of the work |
|
| 133 |
-for making modifications to it. "Object code" means any non-source |
|
| 134 |
-form of a work. |
|
| 135 |
- |
|
| 136 |
- A "Standard Interface" means an interface that either is an official |
|
| 137 |
-standard defined by a recognized standards body, or, in the case of |
|
| 138 |
-interfaces specified for a particular programming language, one that |
|
| 139 |
-is widely used among developers working in that language. |
|
| 140 |
- |
|
| 141 |
- The "System Libraries" of an executable work include anything, other |
|
| 142 |
-than the work as a whole, that (a) is included in the normal form of |
|
| 143 |
-packaging a Major Component, but which is not part of that Major |
|
| 144 |
-Component, and (b) serves only to enable use of the work with that |
|
| 145 |
-Major Component, or to implement a Standard Interface for which an |
|
| 146 |
-implementation is available to the public in source code form. A |
|
| 147 |
-"Major Component", in this context, means a major essential component |
|
| 148 |
-(kernel, window system, and so on) of the specific operating system |
|
| 149 |
-(if any) on which the executable work runs, or a compiler used to |
|
| 150 |
-produce the work, or an object code interpreter used to run it. |
|
| 151 |
- |
|
| 152 |
- The "Corresponding Source" for a work in object code form means all |
|
| 153 |
-the source code needed to generate, install, and (for an executable |
|
| 154 |
-work) run the object code and to modify the work, including scripts to |
|
| 155 |
-control those activities. However, it does not include the work's |
|
| 156 |
-System Libraries, or general-purpose tools or generally available free |
|
| 157 |
-programs which are used unmodified in performing those activities but |
|
| 158 |
-which are not part of the work. For example, Corresponding Source |
|
| 159 |
-includes interface definition files associated with source files for |
|
| 160 |
-the work, and the source code for shared libraries and dynamically |
|
| 161 |
-linked subprograms that the work is specifically designed to require, |
|
| 162 |
-such as by intimate data communication or control flow between those |
|
| 163 |
-subprograms and other parts of the work. |
|
| 164 |
- |
|
| 165 |
- The Corresponding Source need not include anything that users |
|
| 166 |
-can regenerate automatically from other parts of the Corresponding |
|
| 167 |
-Source. |
|
| 168 |
- |
|
| 169 |
- The Corresponding Source for a work in source code form is that |
|
| 170 |
-same work. |
|
| 171 |
- |
|
| 172 |
- 2. Basic Permissions. |
|
| 173 |
- |
|
| 174 |
- All rights granted under this License are granted for the term of |
|
| 175 |
-copyright on the Program, and are irrevocable provided the stated |
|
| 176 |
-conditions are met. This License explicitly affirms your unlimited |
|
| 177 |
-permission to run the unmodified Program. The output from running a |
|
| 178 |
-covered work is covered by this License only if the output, given its |
|
| 179 |
-content, constitutes a covered work. This License acknowledges your |
|
| 180 |
-rights of fair use or other equivalent, as provided by copyright law. |
|
| 181 |
- |
|
| 182 |
- You may make, run and propagate covered works that you do not |
|
| 183 |
-convey, without conditions so long as your license otherwise remains |
|
| 184 |
-in force. You may convey covered works to others for the sole purpose |
|
| 185 |
-of having them make modifications exclusively for you, or provide you |
|
| 186 |
-with facilities for running those works, provided that you comply with |
|
| 187 |
-the terms of this License in conveying all material for which you do |
|
| 188 |
-not control copyright. Those thus making or running the covered works |
|
| 189 |
-for you must do so exclusively on your behalf, under your direction |
|
| 190 |
-and control, on terms that prohibit them from making any copies of |
|
| 191 |
-your copyrighted material outside their relationship with you. |
|
| 192 |
- |
|
| 193 |
- Conveying under any other circumstances is permitted solely under |
|
| 194 |
-the conditions stated below. Sublicensing is not allowed; section 10 |
|
| 195 |
-makes it unnecessary. |
|
| 196 |
- |
|
| 197 |
- 3. Protecting Users' Legal Rights From Anti-Circumvention Law. |
|
| 198 |
- |
|
| 199 |
- No covered work shall be deemed part of an effective technological |
|
| 200 |
-measure under any applicable law fulfilling obligations under article |
|
| 201 |
-11 of the WIPO copyright treaty adopted on 20 December 1996, or |
|
| 202 |
-similar laws prohibiting or restricting circumvention of such |
|
| 203 |
-measures. |
|
| 204 |
- |
|
| 205 |
- When you convey a covered work, you waive any legal power to forbid |
|
| 206 |
-circumvention of technological measures to the extent such circumvention |
|
| 207 |
-is effected by exercising rights under this License with respect to |
|
| 208 |
-the covered work, and you disclaim any intention to limit operation or |
|
| 209 |
-modification of the work as a means of enforcing, against the work's |
|
| 210 |
-users, your or third parties' legal rights to forbid circumvention of |
|
| 211 |
-technological measures. |
|
| 212 |
- |
|
| 213 |
- 4. Conveying Verbatim Copies. |
|
| 214 |
- |
|
| 215 |
- You may convey verbatim copies of the Program's source code as you |
|
| 216 |
-receive it, in any medium, provided that you conspicuously and |
|
| 217 |
-appropriately publish on each copy an appropriate copyright notice; |
|
| 218 |
-keep intact all notices stating that this License and any |
|
| 219 |
-non-permissive terms added in accord with section 7 apply to the code; |
|
| 220 |
-keep intact all notices of the absence of any warranty; and give all |
|
| 221 |
-recipients a copy of this License along with the Program. |
|
| 222 |
- |
|
| 223 |
- You may charge any price or no price for each copy that you convey, |
|
| 224 |
-and you may offer support or warranty protection for a fee. |
|
| 225 |
- |
|
| 226 |
- 5. Conveying Modified Source Versions. |
|
| 227 |
- |
|
| 228 |
- You may convey a work based on the Program, or the modifications to |
|
| 229 |
-produce it from the Program, in the form of source code under the |
|
| 230 |
-terms of section 4, provided that you also meet all of these conditions: |
|
| 231 |
- |
|
| 232 |
- a) The work must carry prominent notices stating that you modified |
|
| 233 |
- it, and giving a relevant date. |
|
| 234 |
- |
|
| 235 |
- b) The work must carry prominent notices stating that it is |
|
| 236 |
- released under this License and any conditions added under section |
|
| 237 |
- 7. This requirement modifies the requirement in section 4 to |
|
| 238 |
- "keep intact all notices". |
|
| 239 |
- |
|
| 240 |
- c) You must license the entire work, as a whole, under this |
|
| 241 |
- License to anyone who comes into possession of a copy. This |
|
| 242 |
- License will therefore apply, along with any applicable section 7 |
|
| 243 |
- additional terms, to the whole of the work, and all its parts, |
|
| 244 |
- regardless of how they are packaged. This License gives no |
|
| 245 |
- permission to license the work in any other way, but it does not |
|
| 246 |
- invalidate such permission if you have separately received it. |
|
| 247 |
- |
|
| 248 |
- d) If the work has interactive user interfaces, each must display |
|
| 249 |
- Appropriate Legal Notices; however, if the Program has interactive |
|
| 250 |
- interfaces that do not display Appropriate Legal Notices, your |
|
| 251 |
- work need not make them do so. |
|
| 252 |
- |
|
| 253 |
- A compilation of a covered work with other separate and independent |
|
| 254 |
-works, which are not by their nature extensions of the covered work, |
|
| 255 |
-and which are not combined with it such as to form a larger program, |
|
| 256 |
-in or on a volume of a storage or distribution medium, is called an |
|
| 257 |
-"aggregate" if the compilation and its resulting copyright are not |
|
| 258 |
-used to limit the access or legal rights of the compilation's users |
|
| 259 |
-beyond what the individual works permit. Inclusion of a covered work |
|
| 260 |
-in an aggregate does not cause this License to apply to the other |
|
| 261 |
-parts of the aggregate. |
|
| 262 |
- |
|
| 263 |
- 6. Conveying Non-Source Forms. |
|
| 264 |
- |
|
| 265 |
- You may convey a covered work in object code form under the terms |
|
| 266 |
-of sections 4 and 5, provided that you also convey the |
|
| 267 |
-machine-readable Corresponding Source under the terms of this License, |
|
| 268 |
-in one of these ways: |
|
| 269 |
- |
|
| 270 |
- a) Convey the object code in, or embodied in, a physical product |
|
| 271 |
- (including a physical distribution medium), accompanied by the |
|
| 272 |
- Corresponding Source fixed on a durable physical medium |
|
| 273 |
- customarily used for software interchange. |
|
| 274 |
- |
|
| 275 |
- b) Convey the object code in, or embodied in, a physical product |
|
| 276 |
- (including a physical distribution medium), accompanied by a |
|
| 277 |
- written offer, valid for at least three years and valid for as |
|
| 278 |
- long as you offer spare parts or customer support for that product |
|
| 279 |
- model, to give anyone who possesses the object code either (1) a |
|
| 280 |
- copy of the Corresponding Source for all the software in the |
|
| 281 |
- product that is covered by this License, on a durable physical |
|
| 282 |
- medium customarily used for software interchange, for a price no |
|
| 283 |
- more than your reasonable cost of physically performing this |
|
| 284 |
- conveying of source, or (2) access to copy the |
|
| 285 |
- Corresponding Source from a network server at no charge. |
|
| 286 |
- |
|
| 287 |
- c) Convey individual copies of the object code with a copy of the |
|
| 288 |
- written offer to provide the Corresponding Source. This |
|
| 289 |
- alternative is allowed only occasionally and noncommercially, and |
|
| 290 |
- only if you received the object code with such an offer, in accord |
|
| 291 |
- with subsection 6b. |
|
| 292 |
- |
|
| 293 |
- d) Convey the object code by offering access from a designated |
|
| 294 |
- place (gratis or for a charge), and offer equivalent access to the |
|
| 295 |
- Corresponding Source in the same way through the same place at no |
|
| 296 |
- further charge. You need not require recipients to copy the |
|
| 297 |
- Corresponding Source along with the object code. If the place to |
|
| 298 |
- copy the object code is a network server, the Corresponding Source |
|
| 299 |
- may be on a different server (operated by you or a third party) |
|
| 300 |
- that supports equivalent copying facilities, provided you maintain |
|
| 301 |
- clear directions next to the object code saying where to find the |
|
| 302 |
- Corresponding Source. Regardless of what server hosts the |
|
| 303 |
- Corresponding Source, you remain obligated to ensure that it is |
|
| 304 |
- available for as long as needed to satisfy these requirements. |
|
| 305 |
- |
|
| 306 |
- e) Convey the object code using peer-to-peer transmission, provided |
|
| 307 |
- you inform other peers where the object code and Corresponding |
|
| 308 |
- Source of the work are being offered to the general public at no |
|
| 309 |
- charge under subsection 6d. |
|
| 310 |
- |
|
| 311 |
- A separable portion of the object code, whose source code is excluded |
|
| 312 |
-from the Corresponding Source as a System Library, need not be |
|
| 313 |
-included in conveying the object code work. |
|
| 314 |
- |
|
| 315 |
- A "User Product" is either (1) a "consumer product", which means any |
|
| 316 |
-tangible personal property which is normally used for personal, family, |
|
| 317 |
-or household purposes, or (2) anything designed or sold for incorporation |
|
| 318 |
-into a dwelling. In determining whether a product is a consumer product, |
|
| 319 |
-doubtful cases shall be resolved in favor of coverage. For a particular |
|
| 320 |
-product received by a particular user, "normally used" refers to a |
|
| 321 |
-typical or common use of that class of product, regardless of the status |
|
| 322 |
-of the particular user or of the way in which the particular user |
|
| 323 |
-actually uses, or expects or is expected to use, the product. A product |
|
| 324 |
-is a consumer product regardless of whether the product has substantial |
|
| 325 |
-commercial, industrial or non-consumer uses, unless such uses represent |
|
| 326 |
-the only significant mode of use of the product. |
|
| 327 |
- |
|
| 328 |
- "Installation Information" for a User Product means any methods, |
|
| 329 |
-procedures, authorization keys, or other information required to install |
|
| 330 |
-and execute modified versions of a covered work in that User Product from |
|
| 331 |
-a modified version of its Corresponding Source. The information must |
|
| 332 |
-suffice to ensure that the continued functioning of the modified object |
|
| 333 |
-code is in no case prevented or interfered with solely because |
|
| 334 |
-modification has been made. |
|
| 335 |
- |
|
| 336 |
- If you convey an object code work under this section in, or with, or |
|
| 337 |
-specifically for use in, a User Product, and the conveying occurs as |
|
| 338 |
-part of a transaction in which the right of possession and use of the |
|
| 339 |
-User Product is transferred to the recipient in perpetuity or for a |
|
| 340 |
-fixed term (regardless of how the transaction is characterized), the |
|
| 341 |
-Corresponding Source conveyed under this section must be accompanied |
|
| 342 |
-by the Installation Information. But this requirement does not apply |
|
| 343 |
-if neither you nor any third party retains the ability to install |
|
| 344 |
-modified object code on the User Product (for example, the work has |
|
| 345 |
-been installed in ROM). |
|
| 346 |
- |
|
| 347 |
- The requirement to provide Installation Information does not include a |
|
| 348 |
-requirement to continue to provide support service, warranty, or updates |
|
| 349 |
-for a work that has been modified or installed by the recipient, or for |
|
| 350 |
-the User Product in which it has been modified or installed. Access to a |
|
| 351 |
-network may be denied when the modification itself materially and |
|
| 352 |
-adversely affects the operation of the network or violates the rules and |
|
| 353 |
-protocols for communication across the network. |
|
| 354 |
- |
|
| 355 |
- Corresponding Source conveyed, and Installation Information provided, |
|
| 356 |
-in accord with this section must be in a format that is publicly |
|
| 357 |
-documented (and with an implementation available to the public in |
|
| 358 |
-source code form), and must require no special password or key for |
|
| 359 |
-unpacking, reading or copying. |
|
| 360 |
- |
|
| 361 |
- 7. Additional Terms. |
|
| 362 |
- |
|
| 363 |
- "Additional permissions" are terms that supplement the terms of this |
|
| 364 |
-License by making exceptions from one or more of its conditions. |
|
| 365 |
-Additional permissions that are applicable to the entire Program shall |
|
| 366 |
-be treated as though they were included in this License, to the extent |
|
| 367 |
-that they are valid under applicable law. If additional permissions |
|
| 368 |
-apply only to part of the Program, that part may be used separately |
|
| 369 |
-under those permissions, but the entire Program remains governed by |
|
| 370 |
-this License without regard to the additional permissions. |
|
| 371 |
- |
|
| 372 |
- When you convey a copy of a covered work, you may at your option |
|
| 373 |
-remove any additional permissions from that copy, or from any part of |
|
| 374 |
-it. (Additional permissions may be written to require their own |
|
| 375 |
-removal in certain cases when you modify the work.) You may place |
|
| 376 |
-additional permissions on material, added by you to a covered work, |
|
| 377 |
-for which you have or can give appropriate copyright permission. |
|
| 378 |
- |
|
| 379 |
- Notwithstanding any other provision of this License, for material you |
|
| 380 |
-add to a covered work, you may (if authorized by the copyright holders of |
|
| 381 |
-that material) supplement the terms of this License with terms: |
|
| 382 |
- |
|
| 383 |
- a) Disclaiming warranty or limiting liability differently from the |
|
| 384 |
- terms of sections 15 and 16 of this License; or |
|
| 385 |
- |
|
| 386 |
- b) Requiring preservation of specified reasonable legal notices or |
|
| 387 |
- author attributions in that material or in the Appropriate Legal |
|
| 388 |
- Notices displayed by works containing it; or |
|
| 389 |
- |
|
| 390 |
- c) Prohibiting misrepresentation of the origin of that material, or |
|
| 391 |
- requiring that modified versions of such material be marked in |
|
| 392 |
- reasonable ways as different from the original version; or |
|
| 393 |
- |
|
| 394 |
- d) Limiting the use for publicity purposes of names of licensors or |
|
| 395 |
- authors of the material; or |
|
| 396 |
- |
|
| 397 |
- e) Declining to grant rights under trademark law for use of some |
|
| 398 |
- trade names, trademarks, or service marks; or |
|
| 399 |
- |
|
| 400 |
- f) Requiring indemnification of licensors and authors of that |
|
| 401 |
- material by anyone who conveys the material (or modified versions of |
|
| 402 |
- it) with contractual assumptions of liability to the recipient, for |
|
| 403 |
- any liability that these contractual assumptions directly impose on |
|
| 404 |
- those licensors and authors. |
|
| 405 |
- |
|
| 406 |
- All other non-permissive additional terms are considered "further |
|
| 407 |
-restrictions" within the meaning of section 10. If the Program as you |
|
| 408 |
-received it, or any part of it, contains a notice stating that it is |
|
| 409 |
-governed by this License along with a term that is a further |
|
| 410 |
-restriction, you may remove that term. If a license document contains |
|
| 411 |
-a further restriction but permits relicensing or conveying under this |
|
| 412 |
-License, you may add to a covered work material governed by the terms |
|
| 413 |
-of that license document, provided that the further restriction does |
|
| 414 |
-not survive such relicensing or conveying. |
|
| 415 |
- |
|
| 416 |
- If you add terms to a covered work in accord with this section, you |
|
| 417 |
-must place, in the relevant source files, a statement of the |
|
| 418 |
-additional terms that apply to those files, or a notice indicating |
|
| 419 |
-where to find the applicable terms. |
|
| 420 |
- |
|
| 421 |
- Additional terms, permissive or non-permissive, may be stated in the |
|
| 422 |
-form of a separately written license, or stated as exceptions; |
|
| 423 |
-the above requirements apply either way. |
|
| 424 |
- |
|
| 425 |
- 8. Termination. |
|
| 426 |
- |
|
| 427 |
- You may not propagate or modify a covered work except as expressly |
|
| 428 |
-provided under this License. Any attempt otherwise to propagate or |
|
| 429 |
-modify it is void, and will automatically terminate your rights under |
|
| 430 |
-this License (including any patent licenses granted under the third |
|
| 431 |
-paragraph of section 11). |
|
| 432 |
- |
|
| 433 |
- However, if you cease all violation of this License, then your |
|
| 434 |
-license from a particular copyright holder is reinstated (a) |
|
| 435 |
-provisionally, unless and until the copyright holder explicitly and |
|
| 436 |
-finally terminates your license, and (b) permanently, if the copyright |
|
| 437 |
-holder fails to notify you of the violation by some reasonable means |
|
| 438 |
-prior to 60 days after the cessation. |
|
| 439 |
- |
|
| 440 |
- Moreover, your license from a particular copyright holder is |
|
| 441 |
-reinstated permanently if the copyright holder notifies you of the |
|
| 442 |
-violation by some reasonable means, this is the first time you have |
|
| 443 |
-received notice of violation of this License (for any work) from that |
|
| 444 |
-copyright holder, and you cure the violation prior to 30 days after |
|
| 445 |
-your receipt of the notice. |
|
| 446 |
- |
|
| 447 |
- Termination of your rights under this section does not terminate the |
|
| 448 |
-licenses of parties who have received copies or rights from you under |
|
| 449 |
-this License. If your rights have been terminated and not permanently |
|
| 450 |
-reinstated, you do not qualify to receive new licenses for the same |
|
| 451 |
-material under section 10. |
|
| 452 |
- |
|
| 453 |
- 9. Acceptance Not Required for Having Copies. |
|
| 454 |
- |
|
| 455 |
- You are not required to accept this License in order to receive or |
|
| 456 |
-run a copy of the Program. Ancillary propagation of a covered work |
|
| 457 |
-occurring solely as a consequence of using peer-to-peer transmission |
|
| 458 |
-to receive a copy likewise does not require acceptance. However, |
|
| 459 |
-nothing other than this License grants you permission to propagate or |
|
| 460 |
-modify any covered work. These actions infringe copyright if you do |
|
| 461 |
-not accept this License. Therefore, by modifying or propagating a |
|
| 462 |
-covered work, you indicate your acceptance of this License to do so. |
|
| 463 |
- |
|
| 464 |
- 10. Automatic Licensing of Downstream Recipients. |
|
| 465 |
- |
|
| 466 |
- Each time you convey a covered work, the recipient automatically |
|
| 467 |
-receives a license from the original licensors, to run, modify and |
|
| 468 |
-propagate that work, subject to this License. You are not responsible |
|
| 469 |
-for enforcing compliance by third parties with this License. |
|
| 470 |
- |
|
| 471 |
- An "entity transaction" is a transaction transferring control of an |
|
| 472 |
-organization, or substantially all assets of one, or subdividing an |
|
| 473 |
-organization, or merging organizations. If propagation of a covered |
|
| 474 |
-work results from an entity transaction, each party to that |
|
| 475 |
-transaction who receives a copy of the work also receives whatever |
|
| 476 |
-licenses to the work the party's predecessor in interest had or could |
|
| 477 |
-give under the previous paragraph, plus a right to possession of the |
|
| 478 |
-Corresponding Source of the work from the predecessor in interest, if |
|
| 479 |
-the predecessor has it or can get it with reasonable efforts. |
|
| 480 |
- |
|
| 481 |
- You may not impose any further restrictions on the exercise of the |
|
| 482 |
-rights granted or affirmed under this License. For example, you may |
|
| 483 |
-not impose a license fee, royalty, or other charge for exercise of |
|
| 484 |
-rights granted under this License, and you may not initiate litigation |
|
| 485 |
-(including a cross-claim or counterclaim in a lawsuit) alleging that |
|
| 486 |
-any patent claim is infringed by making, using, selling, offering for |
|
| 487 |
-sale, or importing the Program or any portion of it. |
|
| 488 |
- |
|
| 489 |
- 11. Patents. |
|
| 490 |
- |
|
| 491 |
- A "contributor" is a copyright holder who authorizes use under this |
|
| 492 |
-License of the Program or a work on which the Program is based. The |
|
| 493 |
-work thus licensed is called the contributor's "contributor version". |
|
| 494 |
- |
|
| 495 |
- A contributor's "essential patent claims" are all patent claims |
|
| 496 |
-owned or controlled by the contributor, whether already acquired or |
|
| 497 |
-hereafter acquired, that would be infringed by some manner, permitted |
|
| 498 |
-by this License, of making, using, or selling its contributor version, |
|
| 499 |
-but do not include claims that would be infringed only as a |
|
| 500 |
-consequence of further modification of the contributor version. For |
|
| 501 |
-purposes of this definition, "control" includes the right to grant |
|
| 502 |
-patent sublicenses in a manner consistent with the requirements of |
|
| 503 |
-this License. |
|
| 504 |
- |
|
| 505 |
- Each contributor grants you a non-exclusive, worldwide, royalty-free |
|
| 506 |
-patent license under the contributor's essential patent claims, to |
|
| 507 |
-make, use, sell, offer for sale, import and otherwise run, modify and |
|
| 508 |
-propagate the contents of its contributor version. |
|
| 509 |
- |
|
| 510 |
- In the following three paragraphs, a "patent license" is any express |
|
| 511 |
-agreement or commitment, however denominated, not to enforce a patent |
|
| 512 |
-(such as an express permission to practice a patent or covenant not to |
|
| 513 |
-sue for patent infringement). To "grant" such a patent license to a |
|
| 514 |
-party means to make such an agreement or commitment not to enforce a |
|
| 515 |
-patent against the party. |
|
| 516 |
- |
|
| 517 |
- If you convey a covered work, knowingly relying on a patent license, |
|
| 518 |
-and the Corresponding Source of the work is not available for anyone |
|
| 519 |
-to copy, free of charge and under the terms of this License, through a |
|
| 520 |
-publicly available network server or other readily accessible means, |
|
| 521 |
-then you must either (1) cause the Corresponding Source to be so |
|
| 522 |
-available, or (2) arrange to deprive yourself of the benefit of the |
|
| 523 |
-patent license for this particular work, or (3) arrange, in a manner |
|
| 524 |
-consistent with the requirements of this License, to extend the patent |
|
| 525 |
-license to downstream recipients. "Knowingly relying" means you have |
|
| 526 |
-actual knowledge that, but for the patent license, your conveying the |
|
| 527 |
-covered work in a country, or your recipient's use of the covered work |
|
| 528 |
-in a country, would infringe one or more identifiable patents in that |
|
| 529 |
-country that you have reason to believe are valid. |
|
| 530 |
- |
|
| 531 |
- If, pursuant to or in connection with a single transaction or |
|
| 532 |
-arrangement, you convey, or propagate by procuring conveyance of, a |
|
| 533 |
-covered work, and grant a patent license to some of the parties |
|
| 534 |
-receiving the covered work authorizing them to use, propagate, modify |
|
| 535 |
-or convey a specific copy of the covered work, then the patent license |
|
| 536 |
-you grant is automatically extended to all recipients of the covered |
|
| 537 |
-work and works based on it. |
|
| 538 |
- |
|
| 539 |
- A patent license is "discriminatory" if it does not include within |
|
| 540 |
-the scope of its coverage, prohibits the exercise of, or is |
|
| 541 |
-conditioned on the non-exercise of one or more of the rights that are |
|
| 542 |
-specifically granted under this License. You may not convey a covered |
|
| 543 |
-work if you are a party to an arrangement with a third party that is |
|
| 544 |
-in the business of distributing software, under which you make payment |
|
| 545 |
-to the third party based on the extent of your activity of conveying |
|
| 546 |
-the work, and under which the third party grants, to any of the |
|
| 547 |
-parties who would receive the covered work from you, a discriminatory |
|
| 548 |
-patent license (a) in connection with copies of the covered work |
|
| 549 |
-conveyed by you (or copies made from those copies), or (b) primarily |
|
| 550 |
-for and in connection with specific products or compilations that |
|
| 551 |
-contain the covered work, unless you entered into that arrangement, |
|
| 552 |
-or that patent license was granted, prior to 28 March 2007. |
|
| 553 |
- |
|
| 554 |
- Nothing in this License shall be construed as excluding or limiting |
|
| 555 |
-any implied license or other defenses to infringement that may |
|
| 556 |
-otherwise be available to you under applicable patent law. |
|
| 557 |
- |
|
| 558 |
- 12. No Surrender of Others' Freedom. |
|
| 559 |
- |
|
| 560 |
- If conditions are imposed on you (whether by court order, agreement or |
|
| 561 |
-otherwise) that contradict the conditions of this License, they do not |
|
| 562 |
-excuse you from the conditions of this License. If you cannot convey a |
|
| 563 |
-covered work so as to satisfy simultaneously your obligations under this |
|
| 564 |
-License and any other pertinent obligations, then as a consequence you may |
|
| 565 |
-not convey it at all. For example, if you agree to terms that obligate you |
|
| 566 |
-to collect a royalty for further conveying from those to whom you convey |
|
| 567 |
-the Program, the only way you could satisfy both those terms and this |
|
| 568 |
-License would be to refrain entirely from conveying the Program. |
|
| 569 |
- |
|
| 570 |
- 13. Use with the GNU Affero General Public License. |
|
| 571 |
- |
|
| 572 |
- Notwithstanding any other provision of this License, you have |
|
| 573 |
-permission to link or combine any covered work with a work licensed |
|
| 574 |
-under version 3 of the GNU Affero General Public License into a single |
|
| 575 |
-combined work, and to convey the resulting work. The terms of this |
|
| 576 |
-License will continue to apply to the part which is the covered work, |
|
| 577 |
-but the special requirements of the GNU Affero General Public License, |
|
| 578 |
-section 13, concerning interaction through a network will apply to the |
|
| 579 |
-combination as such. |
|
| 580 |
- |
|
| 581 |
- 14. Revised Versions of this License. |
|
| 582 |
- |
|
| 583 |
- The Free Software Foundation may publish revised and/or new versions of |
|
| 584 |
-the GNU General Public License from time to time. Such new versions will |
|
| 585 |
-be similar in spirit to the present version, but may differ in detail to |
|
| 586 |
-address new problems or concerns. |
|
| 587 |
- |
|
| 588 |
- Each version is given a distinguishing version number. If the |
|
| 589 |
-Program specifies that a certain numbered version of the GNU General |
|
| 590 |
-Public License "or any later version" applies to it, you have the |
|
| 591 |
-option of following the terms and conditions either of that numbered |
|
| 592 |
-version or of any later version published by the Free Software |
|
| 593 |
-Foundation. If the Program does not specify a version number of the |
|
| 594 |
-GNU General Public License, you may choose any version ever published |
|
| 595 |
-by the Free Software Foundation. |
|
| 596 |
- |
|
| 597 |
- If the Program specifies that a proxy can decide which future |
|
| 598 |
-versions of the GNU General Public License can be used, that proxy's |
|
| 599 |
-public statement of acceptance of a version permanently authorizes you |
|
| 600 |
-to choose that version for the Program. |
|
| 601 |
- |
|
| 602 |
- Later license versions may give you additional or different |
|
| 603 |
-permissions. However, no additional obligations are imposed on any |
|
| 604 |
-author or copyright holder as a result of your choosing to follow a |
|
| 605 |
-later version. |
|
| 606 |
- |
|
| 607 |
- 15. Disclaimer of Warranty. |
|
| 608 |
- |
|
| 609 |
- THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY |
|
| 610 |
-APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT |
|
| 611 |
-HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY |
|
| 612 |
-OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, |
|
| 613 |
-THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
| 614 |
-PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM |
|
| 615 |
-IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF |
|
| 616 |
-ALL NECESSARY SERVICING, REPAIR OR CORRECTION. |
|
| 617 |
- |
|
| 618 |
- 16. Limitation of Liability. |
|
| 619 |
- |
|
| 620 |
- IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING |
|
| 621 |
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS |
|
| 622 |
-THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY |
|
| 623 |
-GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE |
|
| 624 |
-USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF |
|
| 625 |
-DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD |
|
| 626 |
-PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), |
|
| 627 |
-EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF |
|
| 628 |
-SUCH DAMAGES. |
|
| 629 |
- |
|
| 630 |
- 17. Interpretation of Sections 15 and 16. |
|
| 631 |
- |
|
| 632 |
- If the disclaimer of warranty and limitation of liability provided |
|
| 633 |
-above cannot be given local legal effect according to their terms, |
|
| 634 |
-reviewing courts shall apply local law that most closely approximates |
|
| 635 |
-an absolute waiver of all civil liability in connection with the |
|
| 636 |
-Program, unless a warranty or assumption of liability accompanies a |
|
| 637 |
-copy of the Program in return for a fee. |
|
| 638 |
- |
|
| 639 |
- END OF TERMS AND CONDITIONS |
|
| 640 |
- |
|
| 641 |
- How to Apply These Terms to Your New Programs |
|
| 642 |
- |
|
| 643 |
- If you develop a new program, and you want it to be of the greatest |
|
| 644 |
-possible use to the public, the best way to achieve this is to make it |
|
| 645 |
-free software which everyone can redistribute and change under these terms. |
|
| 646 |
- |
|
| 647 |
- To do so, attach the following notices to the program. It is safest |
|
| 648 |
-to attach them to the start of each source file to most effectively |
|
| 649 |
-state the exclusion of warranty; and each file should have at least |
|
| 650 |
-the "copyright" line and a pointer to where the full notice is found. |
|
| 651 |
- |
|
| 652 |
- <one line to give the program's name and a brief idea of what it does.> |
|
| 653 |
- Copyright (C) <year> <name of author> |
|
| 654 |
- |
|
| 655 |
- This program is free software: you can redistribute it and/or modify |
|
| 656 |
- it under the terms of the GNU General Public License as published by |
|
| 657 |
- the Free Software Foundation, either version 3 of the License, or |
|
| 658 |
- (at your option) any later version. |
|
| 659 |
- |
|
| 660 |
- This program is distributed in the hope that it will be useful, |
|
| 661 |
- but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 662 |
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 663 |
- GNU General Public License for more details. |
|
| 664 |
- |
|
| 665 |
- You should have received a copy of the GNU General Public License |
|
| 666 |
- along with this program. If not, see <https://www.gnu.org/licenses/>. |
|
| 667 |
- |
|
| 668 |
-Also add information on how to contact you by electronic and paper mail. |
|
| 669 |
- |
|
| 670 |
- If the program does terminal interaction, make it output a short |
|
| 671 |
-notice like this when it starts in an interactive mode: |
|
| 672 |
- |
|
| 673 |
- <program> Copyright (C) <year> <name of author> |
|
| 674 |
- This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. |
|
| 675 |
- This is free software, and you are welcome to redistribute it |
|
| 676 |
- under certain conditions; type `show c' for details. |
|
| 677 |
- |
|
| 678 |
-The hypothetical commands `show w' and `show c' should show the appropriate |
|
| 679 |
-parts of the General Public License. Of course, your program's commands |
|
| 680 |
-might be different; for a GUI interface, you would use an "about box". |
|
| 681 |
- |
|
| 682 |
- You should also get your employer (if you work as a programmer) or school, |
|
| 683 |
-if any, to sign a "copyright disclaimer" for the program, if necessary. |
|
| 684 |
-For more information on this, and how to apply and follow the GNU GPL, see |
|
| 685 |
-<https://www.gnu.org/licenses/>. |
|
| 686 |
- |
|
| 687 |
- The GNU General Public License does not permit incorporating your program |
|
| 688 |
-into proprietary programs. If your program is a subroutine library, you |
|
| 689 |
-may consider it more useful to permit linking proprietary applications with |
|
| 690 |
-the library. If this is what you want to do, use the GNU Lesser General |
|
| 691 |
-Public License instead of this License. But first, please read |
|
| 692 |
-<https://www.gnu.org/licenses/why-not-lgpl.html>. |
|
| 693 |
- |
|
| 694 |
- |
|
| 695 |
- |
|
| 696 |
- GNU LESSER GENERAL PUBLIC LICENSE |
|
| 697 |
- Version 3, 29 June 2007 |
|
| 698 |
- |
|
| 699 |
- Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/> |
|
| 700 |
- Everyone is permitted to copy and distribute verbatim copies |
|
| 701 |
- of this license document, but changing it is not allowed. |
|
| 702 |
- |
|
| 703 |
- |
|
| 704 |
- This version of the GNU Lesser General Public License incorporates |
|
| 705 |
-the terms and conditions of version 3 of the GNU General Public |
|
| 706 |
-License, supplemented by the additional permissions listed below. |
|
| 707 |
- |
|
| 708 |
- 0. Additional Definitions. |
|
| 709 |
- |
|
| 710 |
- As used herein, "this License" refers to version 3 of the GNU Lesser |
|
| 711 |
-General Public License, and the "GNU GPL" refers to version 3 of the GNU |
|
| 712 |
-General Public License. |
|
| 713 |
- |
|
| 714 |
- "The Library" refers to a covered work governed by this License, |
|
| 715 |
-other than an Application or a Combined Work as defined below. |
|
| 716 |
- |
|
| 717 |
- An "Application" is any work that makes use of an interface provided |
|
| 718 |
-by the Library, but which is not otherwise based on the Library. |
|
| 719 |
-Defining a subclass of a class defined by the Library is deemed a mode |
|
| 720 |
-of using an interface provided by the Library. |
|
| 721 |
- |
|
| 722 |
- A "Combined Work" is a work produced by combining or linking an |
|
| 723 |
-Application with the Library. The particular version of the Library |
|
| 724 |
-with which the Combined Work was made is also called the "Linked |
|
| 725 |
-Version". |
|
| 726 |
- |
|
| 727 |
- The "Minimal Corresponding Source" for a Combined Work means the |
|
| 728 |
-Corresponding Source for the Combined Work, excluding any source code |
|
| 729 |
-for portions of the Combined Work that, considered in isolation, are |
|
| 730 |
-based on the Application, and not on the Linked Version. |
|
| 731 |
- |
|
| 732 |
- The "Corresponding Application Code" for a Combined Work means the |
|
| 733 |
-object code and/or source code for the Application, including any data |
|
| 734 |
-and utility programs needed for reproducing the Combined Work from the |
|
| 735 |
-Application, but excluding the System Libraries of the Combined Work. |
|
| 736 |
- |
|
| 737 |
- 1. Exception to Section 3 of the GNU GPL. |
|
| 738 |
- |
|
| 739 |
- You may convey a covered work under sections 3 and 4 of this License |
|
| 740 |
-without being bound by section 3 of the GNU GPL. |
|
| 741 |
- |
|
| 742 |
- 2. Conveying Modified Versions. |
|
| 743 |
- |
|
| 744 |
- If you modify a copy of the Library, and, in your modifications, a |
|
| 745 |
-facility refers to a function or data to be supplied by an Application |
|
| 746 |
-that uses the facility (other than as an argument passed when the |
|
| 747 |
-facility is invoked), then you may convey a copy of the modified |
|
| 748 |
-version: |
|
| 749 |
- |
|
| 750 |
- a) under this License, provided that you make a good faith effort to |
|
| 751 |
- ensure that, in the event an Application does not supply the |
|
| 752 |
- function or data, the facility still operates, and performs |
|
| 753 |
- whatever part of its purpose remains meaningful, or |
|
| 754 |
- |
|
| 755 |
- b) under the GNU GPL, with none of the additional permissions of |
|
| 756 |
- this License applicable to that copy. |
|
| 757 |
- |
|
| 758 |
- 3. Object Code Incorporating Material from Library Header Files. |
|
| 759 |
- |
|
| 760 |
- The object code form of an Application may incorporate material from |
|
| 761 |
-a header file that is part of the Library. You may convey such object |
|
| 762 |
-code under terms of your choice, provided that, if the incorporated |
|
| 763 |
-material is not limited to numerical parameters, data structure |
|
| 764 |
-layouts and accessors, or small macros, inline functions and templates |
|
| 765 |
-(ten or fewer lines in length), you do both of the following: |
|
| 766 |
- |
|
| 767 |
- a) Give prominent notice with each copy of the object code that the |
|
| 768 |
- Library is used in it and that the Library and its use are |
|
| 769 |
- covered by this License. |
|
| 770 |
- |
|
| 771 |
- b) Accompany the object code with a copy of the GNU GPL and this license |
|
| 772 |
- document. |
|
| 773 |
- |
|
| 774 |
- 4. Combined Works. |
|
| 775 |
- |
|
| 776 |
- You may convey a Combined Work under terms of your choice that, |
|
| 777 |
-taken together, effectively do not restrict modification of the |
|
| 778 |
-portions of the Library contained in the Combined Work and reverse |
|
| 779 |
-engineering for debugging such modifications, if you also do each of |
|
| 780 |
-the following: |
|
| 781 |
- |
|
| 782 |
- a) Give prominent notice with each copy of the Combined Work that |
|
| 783 |
- the Library is used in it and that the Library and its use are |
|
| 784 |
- covered by this License. |
|
| 785 |
- |
|
| 786 |
- b) Accompany the Combined Work with a copy of the GNU GPL and this license |
|
| 787 |
- document. |
|
| 788 |
- |
|
| 789 |
- c) For a Combined Work that displays copyright notices during |
|
| 790 |
- execution, include the copyright notice for the Library among |
|
| 791 |
- these notices, as well as a reference directing the user to the |
|
| 792 |
- copies of the GNU GPL and this license document. |
|
| 793 |
- |
|
| 794 |
- d) Do one of the following: |
|
| 795 |
- |
|
| 796 |
- 0) Convey the Minimal Corresponding Source under the terms of this |
|
| 797 |
- License, and the Corresponding Application Code in a form |
|
| 798 |
- suitable for, and under terms that permit, the user to |
|
| 799 |
- recombine or relink the Application with a modified version of |
|
| 800 |
- the Linked Version to produce a modified Combined Work, in the |
|
| 801 |
- manner specified by section 6 of the GNU GPL for conveying |
|
| 802 |
- Corresponding Source. |
|
| 803 |
- |
|
| 804 |
- 1) Use a suitable shared library mechanism for linking with the |
|
| 805 |
- Library. A suitable mechanism is one that (a) uses at run time |
|
| 806 |
- a copy of the Library already present on the user's computer |
|
| 807 |
- system, and (b) will operate properly with a modified version |
|
| 808 |
- of the Library that is interface-compatible with the Linked |
|
| 809 |
- Version. |
|
| 810 |
- |
|
| 811 |
- e) Provide Installation Information, but only if you would otherwise |
|
| 812 |
- be required to provide such information under section 6 of the |
|
| 813 |
- GNU GPL, and only to the extent that such information is |
|
| 814 |
- necessary to install and execute a modified version of the |
|
| 815 |
- Combined Work produced by recombining or relinking the |
|
| 816 |
- Application with a modified version of the Linked Version. (If |
|
| 817 |
- you use option 4d0, the Installation Information must accompany |
|
| 818 |
- the Minimal Corresponding Source and Corresponding Application |
|
| 819 |
- Code. If you use option 4d1, you must provide the Installation |
|
| 820 |
- Information in the manner specified by section 6 of the GNU GPL |
|
| 821 |
- for conveying Corresponding Source.) |
|
| 822 |
- |
|
| 823 |
- 5. Combined Libraries. |
|
| 824 |
- |
|
| 825 |
- You may place library facilities that are a work based on the |
|
| 826 |
-Library side by side in a single library together with other library |
|
| 827 |
-facilities that are not Applications and are not covered by this |
|
| 828 |
-License, and convey such a combined library under terms of your |
|
| 829 |
-choice, if you do both of the following: |
|
| 830 |
- |
|
| 831 |
- a) Accompany the combined library with a copy of the same work based |
|
| 832 |
- on the Library, uncombined with any other library facilities, |
|
| 833 |
- conveyed under the terms of this License. |
|
| 834 |
- |
|
| 835 |
- b) Give prominent notice with the combined library that part of it |
|
| 836 |
- is a work based on the Library, and explaining where to find the |
|
| 837 |
- accompanying uncombined form of the same work. |
|
| 838 |
- |
|
| 839 |
- 6. Revised Versions of the GNU Lesser General Public License. |
|
| 840 |
- |
|
| 841 |
- The Free Software Foundation may publish revised and/or new versions |
|
| 842 |
-of the GNU Lesser General Public License from time to time. Such new |
|
| 843 |
-versions will be similar in spirit to the present version, but may |
|
| 844 |
-differ in detail to address new problems or concerns. |
|
| 845 |
- |
|
| 846 |
- Each version is given a distinguishing version number. If the |
|
| 847 |
-Library as you received it specifies that a certain numbered version |
|
| 848 |
-of the GNU Lesser General Public License "or any later version" |
|
| 849 |
-applies to it, you have the option of following the terms and |
|
| 850 |
-conditions either of that published version or of any later version |
|
| 851 |
-published by the Free Software Foundation. If the Library as you |
|
| 852 |
-received it does not specify a version number of the GNU Lesser |
|
| 853 |
-General Public License, you may choose any version of the GNU Lesser |
|
| 854 |
-General Public License ever published by the Free Software Foundation. |
|
| 855 |
- |
|
| 856 |
- If the Library as you received it specifies that a proxy can decide |
|
| 857 |
-whether future versions of the GNU Lesser General Public License shall |
|
| 858 |
-apply, that proxy's public statement of acceptance of any version is |
|
| 859 |
-permanent authorization for you to choose that version for the |
|
| 860 |
-Library. |
|
| 861 |
- |
| ... | ... |
@@ -1,122 +0,0 @@ |
| 1 |
-declare module lib_object {
|
|
| 2 |
- /** |
|
| 3 |
- * @author fenris |
|
| 4 |
- */ |
|
| 5 |
- function fetch<type_value>(object: Object, fieldname: string, fallback?: type_value, escalation?: int): type_value; |
|
| 6 |
- /** |
|
| 7 |
- * @author fenris |
|
| 8 |
- */ |
|
| 9 |
- function map<type_from, type_to>(object_from: {
|
|
| 10 |
- [key: string]: type_from; |
|
| 11 |
- }, transformator: (value_from: type_from, key?: string) => type_to): {
|
|
| 12 |
- [key: string]: type_to; |
|
| 13 |
- }; |
|
| 14 |
- /** |
|
| 15 |
- * @desc gibt ein Objekt mit bestimmten Einträgen des Eingabe-Objekts zurück |
|
| 16 |
- * @author fenris |
|
| 17 |
- */ |
|
| 18 |
- function filter<type_value>(object_from: {
|
|
| 19 |
- [key: string]: type_value; |
|
| 20 |
- }, predicate: (value_from: type_value, key?: string) => boolean): {
|
|
| 21 |
- [key: string]: type_value; |
|
| 22 |
- }; |
|
| 23 |
- /** |
|
| 24 |
- * @desc wandelt ein Array mit Einträgen der Form {key,value} in ein entsprechendes Objekt um
|
|
| 25 |
- * @author fenris |
|
| 26 |
- */ |
|
| 27 |
- function from_array<type_value>(array: Array<{
|
|
| 28 |
- key: string; |
|
| 29 |
- value: type_value; |
|
| 30 |
- }>): {
|
|
| 31 |
- [key: string]: type_value; |
|
| 32 |
- }; |
|
| 33 |
- /** |
|
| 34 |
- * @desc wandelt ein Objekt in ein entsprechendes Array mit Einträgen der Form {key,value} um
|
|
| 35 |
- * @author fenris |
|
| 36 |
- */ |
|
| 37 |
- function to_array<type_value>(object: {
|
|
| 38 |
- [key: string]: type_value; |
|
| 39 |
- }): Array<{
|
|
| 40 |
- key: string; |
|
| 41 |
- value: type_value; |
|
| 42 |
- }>; |
|
| 43 |
- /** |
|
| 44 |
- * @desc gibt eine Liste von Schlüsseln eines Objekts zurück |
|
| 45 |
- * @author fenris |
|
| 46 |
- */ |
|
| 47 |
- function keys(object: {
|
|
| 48 |
- [key: string]: any; |
|
| 49 |
- }): Array<string>; |
|
| 50 |
- /** |
|
| 51 |
- * @desc gibt eine Liste von Werten eines Objekts zurück |
|
| 52 |
- * @author fenris |
|
| 53 |
- */ |
|
| 54 |
- function values<type_value>(object: {
|
|
| 55 |
- [key: string]: type_value; |
|
| 56 |
- }): Array<type_value>; |
|
| 57 |
- /** |
|
| 58 |
- * @desc liest ein Baum-artiges Objekt an einer bestimmten Stelle aus |
|
| 59 |
- * @author fenris |
|
| 60 |
- */ |
|
| 61 |
- function path_read<type_value>(object: Object, path: string, fallback?: type_value, escalation?: int): type_value; |
|
| 62 |
- /** |
|
| 63 |
- * @desc schreibt einen Wert an eine bestimmte Stelle in einem Baum-artigen Objekt |
|
| 64 |
- * @author fenris |
|
| 65 |
- */ |
|
| 66 |
- function path_write<type_value>(object: Object, path: string, value: type_value, construct?: boolean): void; |
|
| 67 |
- /** |
|
| 68 |
- * @desc prüft ob ein Objekt einem bestimmten Muster entspricht |
|
| 69 |
- * @param {Object} object das zu prüfende Objekt
|
|
| 70 |
- * @param {Object} pattern das einzuhaltende Muster
|
|
| 71 |
- * @param {Function} connlate eine Funktion zum Feststellen der Gleichheit von Einzelwerten
|
|
| 72 |
- * @author fenris |
|
| 73 |
- */ |
|
| 74 |
- function matches(object: Object, pattern: Object, collate?: typeof instance_collate): boolean; |
|
| 75 |
- /** |
|
| 76 |
- * @desc erzeugt eine Projektion eines Baum-artigen Objekts in ein Listen-artiges Objekt |
|
| 77 |
- * @param {string} [separator] welches Zeichen als Trenner zwischen zwei Pfad-Schritten verwendet werden soll
|
|
| 78 |
- * @author fenris |
|
| 79 |
- */ |
|
| 80 |
- function flatten(value: any, separator?: string, key_for_element?: (index: int) => string): Object; |
|
| 81 |
- /** |
|
| 82 |
- * @author fenris |
|
| 83 |
- */ |
|
| 84 |
- function clash(x: {
|
|
| 85 |
- [key: string]: any; |
|
| 86 |
- }, y: {
|
|
| 87 |
- [key: string]: any; |
|
| 88 |
- }, { "overwrite": overwrite, "hooks": { "existing": hook_existing, }, }?: {
|
|
| 89 |
- overwrite?: boolean; |
|
| 90 |
- hooks?: {
|
|
| 91 |
- existing?: (key?: string, value_old?: any, value_new?: any) => void; |
|
| 92 |
- }; |
|
| 93 |
- }): {
|
|
| 94 |
- [key: string]: any; |
|
| 95 |
- }; |
|
| 96 |
- /** |
|
| 97 |
- * @author fenris |
|
| 98 |
- */ |
|
| 99 |
- function patch(core: Object, mantle: Object, deep?: boolean, path?: string): void; |
|
| 100 |
- /** |
|
| 101 |
- * @author fenris |
|
| 102 |
- */ |
|
| 103 |
- function patched(core: Object, mantle: Object, deep?: boolean): Object; |
|
| 104 |
- /** |
|
| 105 |
- * @author fenris |
|
| 106 |
- */ |
|
| 107 |
- function attached(object: Object, key: string, value: any): Object; |
|
| 108 |
- /** |
|
| 109 |
- * @author fenris |
|
| 110 |
- */ |
|
| 111 |
- function copy(object: Object): Object; |
|
| 112 |
-} |
|
| 113 |
-/** |
|
| 114 |
- * @desc adapters for old syntax |
|
| 115 |
- * @author fenris |
|
| 116 |
- */ |
|
| 117 |
-declare var object_fetch: typeof lib_object.fetch; |
|
| 118 |
-declare var object_map: typeof lib_object.map; |
|
| 119 |
-declare var object_a2o: typeof lib_object.from_array; |
|
| 120 |
-declare var object_o2a: typeof lib_object.to_array; |
|
| 121 |
-declare var object_matches: typeof lib_object.matches; |
|
| 122 |
-declare var object_clash: typeof lib_object.clash; |
| ... | ... |
@@ -1,376 +0,0 @@ |
| 1 |
-/* |
|
| 2 |
-This file is part of »bacterio-plankton:object«. |
|
| 3 |
- |
|
| 4 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 5 |
-<info@greenscale.de> |
|
| 6 |
- |
|
| 7 |
-»bacterio-plankton:object« is free software: you can redistribute it and/or modify |
|
| 8 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 9 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 10 |
-(at your option) any later version. |
|
| 11 |
- |
|
| 12 |
-»bacterio-plankton:object« is distributed in the hope that it will be useful, |
|
| 13 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 14 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 15 |
-GNU Lesser General Public License for more details. |
|
| 16 |
- |
|
| 17 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 18 |
-along with »bacterio-plankton:object«. If not, see <http://www.gnu.org/licenses/>. |
|
| 19 |
- */ |
|
| 20 |
-var lib_object; |
|
| 21 |
-(function (lib_object) {
|
|
| 22 |
- /** |
|
| 23 |
- * @author fenris |
|
| 24 |
- */ |
|
| 25 |
- function fetch(object, fieldname, fallback, escalation) {
|
|
| 26 |
- if (fallback === void 0) { fallback = null; }
|
|
| 27 |
- if (escalation === void 0) { escalation = 1; }
|
|
| 28 |
- if ((fieldname in object) && (object[fieldname] !== undefined)) {
|
|
| 29 |
- return object[fieldname]; |
|
| 30 |
- } |
|
| 31 |
- else {
|
|
| 32 |
- switch (escalation) {
|
|
| 33 |
- case 0: {
|
|
| 34 |
- return fallback; |
|
| 35 |
- break; |
|
| 36 |
- } |
|
| 37 |
- case 1: {
|
|
| 38 |
- var message = ("field '" + fieldname + "' not in structure");
|
|
| 39 |
- message += ("; using fallback value '" + String(fallback) + "'");
|
|
| 40 |
- // console.warn(message); |
|
| 41 |
- return fallback; |
|
| 42 |
- break; |
|
| 43 |
- } |
|
| 44 |
- case 2: {
|
|
| 45 |
- var message = ("field '" + fieldname + "' not in structure");
|
|
| 46 |
- throw (new Error(message)); |
|
| 47 |
- break; |
|
| 48 |
- } |
|
| 49 |
- default: {
|
|
| 50 |
- throw (new Error("invalid escalation level " + escalation));
|
|
| 51 |
- break; |
|
| 52 |
- } |
|
| 53 |
- } |
|
| 54 |
- } |
|
| 55 |
- } |
|
| 56 |
- lib_object.fetch = fetch; |
|
| 57 |
- /** |
|
| 58 |
- * @author fenris |
|
| 59 |
- */ |
|
| 60 |
- function map(object_from, transformator) {
|
|
| 61 |
- var object_to = {};
|
|
| 62 |
- Object.keys(object_from).forEach(function (key) { return (object_to[key] = transformator(object_from[key], key)); });
|
|
| 63 |
- return object_to; |
|
| 64 |
- } |
|
| 65 |
- lib_object.map = map; |
|
| 66 |
- /** |
|
| 67 |
- * @desc gibt ein Objekt mit bestimmten Einträgen des Eingabe-Objekts zurück |
|
| 68 |
- * @author fenris |
|
| 69 |
- */ |
|
| 70 |
- function filter(object_from, predicate) {
|
|
| 71 |
- var object_to = {};
|
|
| 72 |
- Object.keys(object_from).forEach(function (key) {
|
|
| 73 |
- var value = object_from[key]; |
|
| 74 |
- if (predicate(value, key)) {
|
|
| 75 |
- object_to[key] = value; |
|
| 76 |
- } |
|
| 77 |
- }); |
|
| 78 |
- return object_to; |
|
| 79 |
- } |
|
| 80 |
- lib_object.filter = filter; |
|
| 81 |
- /** |
|
| 82 |
- * @desc wandelt ein Array mit Einträgen der Form {key,value} in ein entsprechendes Objekt um
|
|
| 83 |
- * @author fenris |
|
| 84 |
- */ |
|
| 85 |
- function from_array(array) {
|
|
| 86 |
- var object = {};
|
|
| 87 |
- array.forEach(function (entry) { return (object[entry.key] = entry.value); });
|
|
| 88 |
- return object; |
|
| 89 |
- } |
|
| 90 |
- lib_object.from_array = from_array; |
|
| 91 |
- /** |
|
| 92 |
- * @desc wandelt ein Objekt in ein entsprechendes Array mit Einträgen der Form {key,value} um
|
|
| 93 |
- * @author fenris |
|
| 94 |
- */ |
|
| 95 |
- function to_array(object) {
|
|
| 96 |
- var array = []; |
|
| 97 |
- Object.keys(object).forEach(function (key) { return array.push({ "key": key, "value": object[key] }); });
|
|
| 98 |
- return array; |
|
| 99 |
- } |
|
| 100 |
- lib_object.to_array = to_array; |
|
| 101 |
- /** |
|
| 102 |
- * @desc gibt eine Liste von Schlüsseln eines Objekts zurück |
|
| 103 |
- * @author fenris |
|
| 104 |
- */ |
|
| 105 |
- function keys(object) {
|
|
| 106 |
- return Object.keys(object); |
|
| 107 |
- } |
|
| 108 |
- lib_object.keys = keys; |
|
| 109 |
- /** |
|
| 110 |
- * @desc gibt eine Liste von Werten eines Objekts zurück |
|
| 111 |
- * @author fenris |
|
| 112 |
- */ |
|
| 113 |
- function values(object) {
|
|
| 114 |
- return to_array(object).map(function (entry) { return entry.value; });
|
|
| 115 |
- } |
|
| 116 |
- lib_object.values = values; |
|
| 117 |
- /** |
|
| 118 |
- * @desc liest ein Baum-artiges Objekt an einer bestimmten Stelle aus |
|
| 119 |
- * @author fenris |
|
| 120 |
- */ |
|
| 121 |
- function path_read(object, path, fallback, escalation) {
|
|
| 122 |
- if (fallback === void 0) { fallback = null; }
|
|
| 123 |
- if (escalation === void 0) { escalation = 1; }
|
|
| 124 |
- var steps = ((path.length == 0) ? [] : path.split("."));
|
|
| 125 |
- if (steps.length == 0) {
|
|
| 126 |
- throw (new Error("empty path"));
|
|
| 127 |
- } |
|
| 128 |
- else {
|
|
| 129 |
- var position_1 = object; |
|
| 130 |
- var reachable = (position_1 != null) && steps.slice(0, steps.length - 1).every(function (step) {
|
|
| 131 |
- position_1 = object_fetch(position_1, step, null, 0); |
|
| 132 |
- return (position_1 != null); |
|
| 133 |
- }); |
|
| 134 |
- if (reachable) {
|
|
| 135 |
- return object_fetch(position_1, steps[steps.length - 1], fallback, escalation); |
|
| 136 |
- } |
|
| 137 |
- else {
|
|
| 138 |
- return object_fetch({}, "_dummy_", fallback, escalation);
|
|
| 139 |
- } |
|
| 140 |
- } |
|
| 141 |
- } |
|
| 142 |
- lib_object.path_read = path_read; |
|
| 143 |
- /** |
|
| 144 |
- * @desc schreibt einen Wert an eine bestimmte Stelle in einem Baum-artigen Objekt |
|
| 145 |
- * @author fenris |
|
| 146 |
- */ |
|
| 147 |
- function path_write(object, path, value, construct) {
|
|
| 148 |
- if (construct === void 0) { construct = true; }
|
|
| 149 |
- var steps = ((path.length == 0) ? [] : path.split("."));
|
|
| 150 |
- if (steps.length == 0) {
|
|
| 151 |
- throw (new Error("empty path"));
|
|
| 152 |
- } |
|
| 153 |
- else {
|
|
| 154 |
- var position_2 = object; |
|
| 155 |
- var reachable = steps.slice(0, steps.length - 1).every(function (step) {
|
|
| 156 |
- var position_ = object_fetch(position_2, step, null, 0); |
|
| 157 |
- if (position_ == null) {
|
|
| 158 |
- if (construct) {
|
|
| 159 |
- position_2[step] = {};
|
|
| 160 |
- position_2 = position_2[step]; |
|
| 161 |
- return true; |
|
| 162 |
- } |
|
| 163 |
- else {
|
|
| 164 |
- return false; |
|
| 165 |
- } |
|
| 166 |
- } |
|
| 167 |
- else {
|
|
| 168 |
- position_2 = position_; |
|
| 169 |
- return true; |
|
| 170 |
- } |
|
| 171 |
- }); |
|
| 172 |
- if (reachable) {
|
|
| 173 |
- position_2[steps[steps.length - 1]] = value; |
|
| 174 |
- } |
|
| 175 |
- else {
|
|
| 176 |
- var message = ("path '" + path + "' does not exist and may not be constructed");
|
|
| 177 |
- throw (new Error(message)); |
|
| 178 |
- } |
|
| 179 |
- } |
|
| 180 |
- } |
|
| 181 |
- lib_object.path_write = path_write; |
|
| 182 |
- /** |
|
| 183 |
- * @desc prüft ob ein Objekt einem bestimmten Muster entspricht |
|
| 184 |
- * @param {Object} object das zu prüfende Objekt
|
|
| 185 |
- * @param {Object} pattern das einzuhaltende Muster
|
|
| 186 |
- * @param {Function} connlate eine Funktion zum Feststellen der Gleichheit von Einzelwerten
|
|
| 187 |
- * @author fenris |
|
| 188 |
- */ |
|
| 189 |
- function matches(object, pattern, collate) {
|
|
| 190 |
- if (collate === void 0) { collate = instance_collate; }
|
|
| 191 |
- return Object.keys(pattern).every(function (key) { return collate(pattern[key], object[key]); });
|
|
| 192 |
- } |
|
| 193 |
- lib_object.matches = matches; |
|
| 194 |
- /** |
|
| 195 |
- * @desc erzeugt eine Projektion eines Baum-artigen Objekts in ein Listen-artiges Objekt |
|
| 196 |
- * @param {string} [separator] welches Zeichen als Trenner zwischen zwei Pfad-Schritten verwendet werden soll
|
|
| 197 |
- * @author fenris |
|
| 198 |
- */ |
|
| 199 |
- function flatten(value, separator, key_for_element) {
|
|
| 200 |
- if (separator === void 0) { separator = "."; }
|
|
| 201 |
- if (key_for_element === void 0) { key_for_element = (function (index) { return ("element_" + index.toFixed(0)); }); }
|
|
| 202 |
- var integrate = function (result, key_, value_) {
|
|
| 203 |
- if (value_ == null) {
|
|
| 204 |
- result[key_] = value_; |
|
| 205 |
- } |
|
| 206 |
- else {
|
|
| 207 |
- // primitive Werte direkt übernehmen |
|
| 208 |
- if (typeof (value_) != "object") {
|
|
| 209 |
- result[key_] = value_; |
|
| 210 |
- } |
|
| 211 |
- // sonst durch rekursiven Aufruf die flache Variante des Wertes ermitteln und einarbeiten |
|
| 212 |
- else {
|
|
| 213 |
- var result_1 = flatten(value_); |
|
| 214 |
- Object.keys(result_1) |
|
| 215 |
- .forEach(function (key__) {
|
|
| 216 |
- var value__ = result_1[key__]; |
|
| 217 |
- var key_new = (key_ + separator + key__); |
|
| 218 |
- result[key_new] = value__; |
|
| 219 |
- }); |
|
| 220 |
- } |
|
| 221 |
- } |
|
| 222 |
- }; |
|
| 223 |
- if ((value === null) || (value === undefined)) {
|
|
| 224 |
- return null; |
|
| 225 |
- } |
|
| 226 |
- else {
|
|
| 227 |
- var result_2 = {};
|
|
| 228 |
- if (typeof (value) != "object") {
|
|
| 229 |
- result_2["value"] = value; |
|
| 230 |
- } |
|
| 231 |
- else {
|
|
| 232 |
- if (value instanceof Array) {
|
|
| 233 |
- var array = (value); |
|
| 234 |
- array |
|
| 235 |
- .forEach(function (element, index) {
|
|
| 236 |
- integrate(result_2, key_for_element(index), element); |
|
| 237 |
- }); |
|
| 238 |
- } |
|
| 239 |
- else {
|
|
| 240 |
- var object_1 = (value); |
|
| 241 |
- Object.keys(object_1) |
|
| 242 |
- .forEach(function (key) {
|
|
| 243 |
- integrate(result_2, key, object_1[key]); |
|
| 244 |
- }); |
|
| 245 |
- } |
|
| 246 |
- } |
|
| 247 |
- return result_2; |
|
| 248 |
- } |
|
| 249 |
- } |
|
| 250 |
- lib_object.flatten = flatten; |
|
| 251 |
- /** |
|
| 252 |
- * @author fenris |
|
| 253 |
- */ |
|
| 254 |
- function clash(x, y, _a) {
|
|
| 255 |
- var _b = _a === void 0 ? {} : _a, _c = _b["overwrite"], overwrite = _c === void 0 ? true : _c, _d = _b["hooks"], _e = (_d === void 0 ? {} : _d)["existing"], hook_existing = _e === void 0 ? null : _e;
|
|
| 256 |
- if (hook_existing == null) {
|
|
| 257 |
- (function (key, value_old, value_new) { return console.warn("field " + key + " already defined"); });
|
|
| 258 |
- } |
|
| 259 |
- var z = {};
|
|
| 260 |
- Object.keys(x).forEach(function (key) {
|
|
| 261 |
- z[key] = x[key]; |
|
| 262 |
- }); |
|
| 263 |
- Object.keys(y).forEach(function (key) {
|
|
| 264 |
- if (key in z) {
|
|
| 265 |
- if (hook_existing != null) {
|
|
| 266 |
- hook_existing(key, z[key], y[key]); |
|
| 267 |
- } |
|
| 268 |
- if (overwrite) {
|
|
| 269 |
- z[key] = y[key]; |
|
| 270 |
- } |
|
| 271 |
- } |
|
| 272 |
- else {
|
|
| 273 |
- z[key] = y[key]; |
|
| 274 |
- } |
|
| 275 |
- }); |
|
| 276 |
- return z; |
|
| 277 |
- } |
|
| 278 |
- lib_object.clash = clash; |
|
| 279 |
- /** |
|
| 280 |
- * @author fenris |
|
| 281 |
- */ |
|
| 282 |
- function patch(core, mantle, deep, path) {
|
|
| 283 |
- if (deep === void 0) { deep = true; }
|
|
| 284 |
- if (path === void 0) { path = null; }
|
|
| 285 |
- if (mantle == null) {
|
|
| 286 |
- console.warn("mantle is null; core was", core);
|
|
| 287 |
- } |
|
| 288 |
- else {
|
|
| 289 |
- Object.keys(mantle).forEach(function (key) {
|
|
| 290 |
- var path_ = ((path == null) ? key : path + "." + key); |
|
| 291 |
- var value_mantle = mantle[key]; |
|
| 292 |
- if (!(key in core)) {
|
|
| 293 |
- if ((typeof (value_mantle) == "object") && (value_mantle != null) && deep) {
|
|
| 294 |
- if (value_mantle instanceof Array) {
|
|
| 295 |
- core[key] = []; |
|
| 296 |
- value_mantle.forEach(function (element) {
|
|
| 297 |
- if ((typeof (element) == "object") && (element != null)) {
|
|
| 298 |
- var element_ = {};
|
|
| 299 |
- patch(element_, element); |
|
| 300 |
- core[key].push(element_); |
|
| 301 |
- } |
|
| 302 |
- else {
|
|
| 303 |
- core[key].push(element); |
|
| 304 |
- } |
|
| 305 |
- }); |
|
| 306 |
- } |
|
| 307 |
- else {
|
|
| 308 |
- core[key] = {};
|
|
| 309 |
- patch(core[key], value_mantle, deep, path_); |
|
| 310 |
- } |
|
| 311 |
- } |
|
| 312 |
- else {
|
|
| 313 |
- core[key] = value_mantle; |
|
| 314 |
- } |
|
| 315 |
- } |
|
| 316 |
- else {
|
|
| 317 |
- var value_core = core[key]; |
|
| 318 |
- if (typeof (value_core) == typeof (value_mantle)) {
|
|
| 319 |
- if ((typeof (value_mantle) == "object") && (value_mantle != null) && deep) {
|
|
| 320 |
- patch(core[key], value_mantle, deep, path_); |
|
| 321 |
- } |
|
| 322 |
- else {
|
|
| 323 |
- core[key] = value_mantle; |
|
| 324 |
- } |
|
| 325 |
- } |
|
| 326 |
- else {
|
|
| 327 |
- if ((value_core != null) && (value_mantle != null)) {
|
|
| 328 |
- var message = "objects have different shapes at path '" + path_ + "'; core has type '" + typeof (value_core) + "' and mantle has type '" + typeof (value_mantle) + "'"; |
|
| 329 |
- console.warn(message); |
|
| 330 |
- } |
|
| 331 |
- core[key] = value_mantle; |
|
| 332 |
- // throw (new Error(message)); |
|
| 333 |
- } |
|
| 334 |
- } |
|
| 335 |
- }); |
|
| 336 |
- } |
|
| 337 |
- } |
|
| 338 |
- lib_object.patch = patch; |
|
| 339 |
- /** |
|
| 340 |
- * @author fenris |
|
| 341 |
- */ |
|
| 342 |
- function patched(core, mantle, deep) {
|
|
| 343 |
- if (deep === void 0) { deep = undefined; }
|
|
| 344 |
- var result = {};
|
|
| 345 |
- patch(result, core, deep); |
|
| 346 |
- patch(result, mantle, deep); |
|
| 347 |
- return result; |
|
| 348 |
- } |
|
| 349 |
- lib_object.patched = patched; |
|
| 350 |
- /** |
|
| 351 |
- * @author fenris |
|
| 352 |
- */ |
|
| 353 |
- function attached(object, key, value) {
|
|
| 354 |
- var mantle = {};
|
|
| 355 |
- mantle[key] = value; |
|
| 356 |
- return patched(object, mantle, false); |
|
| 357 |
- } |
|
| 358 |
- lib_object.attached = attached; |
|
| 359 |
- /** |
|
| 360 |
- * @author fenris |
|
| 361 |
- */ |
|
| 362 |
- function copy(object) {
|
|
| 363 |
- return patched({}, object);
|
|
| 364 |
- } |
|
| 365 |
- lib_object.copy = copy; |
|
| 366 |
-})(lib_object || (lib_object = {}));
|
|
| 367 |
-/** |
|
| 368 |
- * @desc adapters for old syntax |
|
| 369 |
- * @author fenris |
|
| 370 |
- */ |
|
| 371 |
-var object_fetch = lib_object.fetch; |
|
| 372 |
-var object_map = lib_object.map; |
|
| 373 |
-var object_a2o = lib_object.from_array; |
|
| 374 |
-var object_o2a = lib_object.to_array; |
|
| 375 |
-var object_matches = lib_object.matches; |
|
| 376 |
-var object_clash = lib_object.clash; |
| ... | ... |
@@ -4,21 +4,17 @@ |
| 4 | 4 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./shape/logic-decl.d.ts", |
| 5 | 5 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./trait/logic-decl.d.ts", |
| 6 | 6 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./code/logic-decl.d.ts", |
| 7 |
+ "/home/fenris/projekte/folksprak/words/server/lib/plankton/./json/logic-decl.d.ts", |
|
| 7 | 8 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./http/logic-decl.d.ts", |
| 8 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./call/logic-decl.d.ts", |
|
| 9 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./string/logic-decl.d.ts", |
|
| 10 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./object/logic-decl.d.ts", |
|
| 11 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./comm-server/logic-decl.d.ts" |
|
| 9 |
+ "/home/fenris/projekte/folksprak/words/server/lib/plankton/./server/logic-decl.d.ts" |
|
| 12 | 10 |
], |
| 13 | 11 |
"logic-impl": [ |
| 14 | 12 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./base/logic-impl.js", |
| 15 | 13 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./shape/logic-impl.js", |
| 16 | 14 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./trait/logic-impl.js", |
| 17 | 15 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./code/logic-impl.js", |
| 16 |
+ "/home/fenris/projekte/folksprak/words/server/lib/plankton/./json/logic-impl.js", |
|
| 18 | 17 |
"/home/fenris/projekte/folksprak/words/server/lib/plankton/./http/logic-impl.js", |
| 19 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./call/logic-impl.js", |
|
| 20 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./string/logic-impl.js", |
|
| 21 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./object/logic-impl.js", |
|
| 22 |
- "/home/fenris/projekte/folksprak/words/server/lib/plankton/./comm-server/logic-impl.js" |
|
| 18 |
+ "/home/fenris/projekte/folksprak/words/server/lib/plankton/./server/logic-impl.js" |
|
| 23 | 19 |
] |
| 24 | 20 |
} |
| ... | ... |
@@ -1,18 +1,18 @@ |
| 1 | 1 |
Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
| 2 | 2 |
<info@greenscale.de> |
| 3 | 3 |
|
| 4 |
-»bacterio-plankton:string« is free software: you can redistribute it and/or modify |
|
| 4 |
+»bacterio-plankton:server« is free software: you can redistribute it and/or modify |
|
| 5 | 5 |
it under the terms of the GNU Lesser General Public License as published by |
| 6 | 6 |
the Free Software Foundation, either version 3 of the License, or |
| 7 | 7 |
(at your option) any later version. |
| 8 | 8 |
|
| 9 |
-»bacterio-plankton:string« is distributed in the hope that it will be useful, |
|
| 9 |
+»bacterio-plankton:server« is distributed in the hope that it will be useful, |
|
| 10 | 10 |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 | 11 |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 12 | 12 |
GNU Lesser General Public License for more details. |
| 13 | 13 |
|
| 14 | 14 |
You should have received a copy of the GNU Lesser General Public License |
| 15 |
-along with »bacterio-plankton:string«. If not, see <http://www.gnu.org/licenses/>. |
|
| 15 |
+along with »bacterio-plankton:server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 16 | 16 |
|
| 17 | 17 |
|
| 18 | 18 |
|
| ... | ... |
@@ -0,0 +1,46 @@ |
| 1 |
+declare module lib_server {
|
|
| 2 |
+ /** |
|
| 3 |
+ * @author fenris |
|
| 4 |
+ */ |
|
| 5 |
+ type type_subject = {
|
|
| 6 |
+ port: int; |
|
| 7 |
+ handle: (input: string) => Promise<string>; |
|
| 8 |
+ verbosity: int; |
|
| 9 |
+ serverobj: any; |
|
| 10 |
+ }; |
|
| 11 |
+ /** |
|
| 12 |
+ * @author fenris |
|
| 13 |
+ */ |
|
| 14 |
+ function make(port: int, handle: (input: string) => Promise<string>, verbosity?: int): type_subject; |
|
| 15 |
+ /** |
|
| 16 |
+ * @author fenris |
|
| 17 |
+ */ |
|
| 18 |
+ function start(subject: type_subject): Promise<void>; |
|
| 19 |
+ /** |
|
| 20 |
+ * @author fenris |
|
| 21 |
+ */ |
|
| 22 |
+ function kill(subject: type_subject): void; |
|
| 23 |
+} |
|
| 24 |
+declare module lib_server {
|
|
| 25 |
+ /** |
|
| 26 |
+ * @author fenris |
|
| 27 |
+ */ |
|
| 28 |
+ class class_server {
|
|
| 29 |
+ /** |
|
| 30 |
+ * @author fenris |
|
| 31 |
+ */ |
|
| 32 |
+ protected subject: type_subject; |
|
| 33 |
+ /** |
|
| 34 |
+ * @author fenris |
|
| 35 |
+ */ |
|
| 36 |
+ constructor(port: int, handle: (input: string) => Promise<string>, verbosity?: int); |
|
| 37 |
+ /** |
|
| 38 |
+ * @author fenris |
|
| 39 |
+ */ |
|
| 40 |
+ start(): Promise<void>; |
|
| 41 |
+ /** |
|
| 42 |
+ * @author fenris |
|
| 43 |
+ */ |
|
| 44 |
+ kill(): void; |
|
| 45 |
+ } |
|
| 46 |
+} |
| ... | ... |
@@ -0,0 +1,133 @@ |
| 1 |
+/* |
|
| 2 |
+This file is part of »bacterio-plankton:server«. |
|
| 3 |
+ |
|
| 4 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 5 |
+<info@greenscale.de> |
|
| 6 |
+ |
|
| 7 |
+»bacterio-plankton:server« is free software: you can redistribute it and/or modify |
|
| 8 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 9 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 10 |
+(at your option) any later version. |
|
| 11 |
+ |
|
| 12 |
+»bacterio-plankton:server« is distributed in the hope that it will be useful, |
|
| 13 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 14 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 15 |
+GNU Lesser General Public License for more details. |
|
| 16 |
+ |
|
| 17 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 18 |
+along with »bacterio-plankton:server«. If not, see <http://www.gnu.org/licenses/>. |
|
| 19 |
+ */ |
|
| 20 |
+var lib_server; |
|
| 21 |
+(function (lib_server) {
|
|
| 22 |
+ /** |
|
| 23 |
+ * @author fenris |
|
| 24 |
+ */ |
|
| 25 |
+ function make(port, handle, verbosity = 1) {
|
|
| 26 |
+ return {
|
|
| 27 |
+ "port": port, |
|
| 28 |
+ "handle": handle, |
|
| 29 |
+ "verbosity": verbosity, |
|
| 30 |
+ "serverobj": undefined, |
|
| 31 |
+ }; |
|
| 32 |
+ } |
|
| 33 |
+ lib_server.make = make; |
|
| 34 |
+ /** |
|
| 35 |
+ * @author fenris |
|
| 36 |
+ */ |
|
| 37 |
+ function log(subject, level, message) {
|
|
| 38 |
+ if (subject.verbosity >= level) {
|
|
| 39 |
+ console.log("[server]", message);
|
|
| 40 |
+ } |
|
| 41 |
+ else {
|
|
| 42 |
+ // do nothing |
|
| 43 |
+ } |
|
| 44 |
+ } |
|
| 45 |
+ /** |
|
| 46 |
+ * @author fenris |
|
| 47 |
+ */ |
|
| 48 |
+ function start(subject) {
|
|
| 49 |
+ const net = require("net");
|
|
| 50 |
+ return (new Promise((resolve, reject) => {
|
|
| 51 |
+ subject.serverobj = net.createServer((socket) => {
|
|
| 52 |
+ log(subject, 2, "client connected"); |
|
| 53 |
+ socket.on("readable", () => {
|
|
| 54 |
+ let chunk; |
|
| 55 |
+ while (!((chunk = socket.read()) === null)) {
|
|
| 56 |
+ const input = chunk.toString(); |
|
| 57 |
+ log(subject, 3, "reading: " + input); |
|
| 58 |
+ subject.handle(input) |
|
| 59 |
+ .then((output) => {
|
|
| 60 |
+ log(subject, 3, "writing: " + output); |
|
| 61 |
+ socket.write(output); |
|
| 62 |
+ socket.end(); |
|
| 63 |
+ }); |
|
| 64 |
+ } |
|
| 65 |
+ }); |
|
| 66 |
+ socket.on("end", () => {
|
|
| 67 |
+ log(subject, 2, "client disconnected"); |
|
| 68 |
+ }); |
|
| 69 |
+ }); |
|
| 70 |
+ subject.serverobj.on("error", (error) => {
|
|
| 71 |
+ throw error; |
|
| 72 |
+ }); |
|
| 73 |
+ subject.serverobj.listen(subject.port, () => {
|
|
| 74 |
+ log(subject, 1, "listening on port " + subject.port.toFixed(0)); |
|
| 75 |
+ resolve(undefined); |
|
| 76 |
+ }); |
|
| 77 |
+ })); |
|
| 78 |
+ } |
|
| 79 |
+ lib_server.start = start; |
|
| 80 |
+ /** |
|
| 81 |
+ * @author fenris |
|
| 82 |
+ */ |
|
| 83 |
+ function kill(subject) {
|
|
| 84 |
+ subject.serverobj.close(); |
|
| 85 |
+ } |
|
| 86 |
+ lib_server.kill = kill; |
|
| 87 |
+})(lib_server || (lib_server = {}));
|
|
| 88 |
+/* |
|
| 89 |
+This file is part of »bacterio-plankton:server«. |
|
| 90 |
+ |
|
| 91 |
+Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 92 |
+<info@greenscale.de> |
|
| 93 |
+ |
|
| 94 |
+»bacterio-plankton:server« is free software: you can redistribute it and/or modify |
|
| 95 |
+it under the terms of the GNU Lesser General Public License as published by |
|
| 96 |
+the Free Software Foundation, either version 3 of the License, or |
|
| 97 |
+(at your option) any later version. |
|
| 98 |
+ |
|
| 99 |
+»bacterio-plankton:server« is distributed in the hope that it will be useful, |
|
| 100 |
+but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 101 |
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 102 |
+GNU Lesser General Public License for more details. |
|
| 103 |
+ |
|
| 104 |
+You should have received a copy of the GNU Lesser General Public License |
|
| 105 |
+along with »bacterio-plankton:server«. If not, see <common://www.gnu.org/licenses/>. |
|
| 106 |
+ */ |
|
| 107 |
+var lib_server; |
|
| 108 |
+(function (lib_server) {
|
|
| 109 |
+ /** |
|
| 110 |
+ * @author fenris |
|
| 111 |
+ */ |
|
| 112 |
+ class class_server {
|
|
| 113 |
+ /** |
|
| 114 |
+ * @author fenris |
|
| 115 |
+ */ |
|
| 116 |
+ constructor(port, handle, verbosity = undefined) {
|
|
| 117 |
+ this.subject = lib_server.make(port, handle, verbosity); |
|
| 118 |
+ } |
|
| 119 |
+ /** |
|
| 120 |
+ * @author fenris |
|
| 121 |
+ */ |
|
| 122 |
+ start() {
|
|
| 123 |
+ return lib_server.start(this.subject); |
|
| 124 |
+ } |
|
| 125 |
+ /** |
|
| 126 |
+ * @author fenris |
|
| 127 |
+ */ |
|
| 128 |
+ kill() {
|
|
| 129 |
+ return lib_server.kill(this.subject); |
|
| 130 |
+ } |
|
| 131 |
+ } |
|
| 132 |
+ lib_server.class_server = class_server; |
|
| 133 |
+})(lib_server || (lib_server = {}));
|
| ... | ... |
@@ -1,144 +0,0 @@ |
| 1 |
-declare var plain_text_to_html: (text: string) => string; |
|
| 2 |
-/** |
|
| 3 |
- * @desc makes a valid |
|
| 4 |
- */ |
|
| 5 |
-declare var format_sentence: (str: string, rtl?: boolean, caseSense?: boolean) => string; |
|
| 6 |
-declare var fill_string_template: (template_string: string, object: any, fabric: Function, delimiter: string, default_string: string, sloppy: boolean) => string; |
|
| 7 |
-declare var make_string_template: (_template: string, _fabrics?: Object) => (object: {
|
|
| 8 |
- [key: string]: string; |
|
| 9 |
-}) => string; |
|
| 10 |
-declare var make_eml_header: (object: {
|
|
| 11 |
- [key: string]: string; |
|
| 12 |
-}) => string; |
|
| 13 |
-declare var make_eml_body: Object; |
|
| 14 |
-declare module lib_string {
|
|
| 15 |
- /** |
|
| 16 |
- * @author neuc,frac |
|
| 17 |
- */ |
|
| 18 |
- function empty(str: string): boolean; |
|
| 19 |
- /** |
|
| 20 |
- * @desc returns a unique string |
|
| 21 |
- * @param {string} prefix an optional prefix for the generated string
|
|
| 22 |
- * @return {string}
|
|
| 23 |
- * @author fenris |
|
| 24 |
- */ |
|
| 25 |
- function generate(prefix?: string): string; |
|
| 26 |
- /** |
|
| 27 |
- * @desc splits a string, but returns an empty list, if the string is empty |
|
| 28 |
- * @param {string} chain
|
|
| 29 |
- * @param {string} separator
|
|
| 30 |
- * @return {Array<string>}
|
|
| 31 |
- * @author fenris |
|
| 32 |
- */ |
|
| 33 |
- function split(chain: string, separator?: string): Array<string>; |
|
| 34 |
- /** |
|
| 35 |
- * @author neu3no |
|
| 36 |
- */ |
|
| 37 |
- function explode(str: string, needle: string, max: int): Array<string>; |
|
| 38 |
- /** |
|
| 39 |
- * @desc concats a given word with itself n times |
|
| 40 |
- * @param {string} word
|
|
| 41 |
- * @param {int}
|
|
| 42 |
- * @return {string}
|
|
| 43 |
- * @author fenris |
|
| 44 |
- */ |
|
| 45 |
- function repeat(word: string, count: int): string; |
|
| 46 |
- /** |
|
| 47 |
- * @desc lengthens a string by repeatedly appending or prepending another string |
|
| 48 |
- * @param {string} word the string to pad
|
|
| 49 |
- * @param {int} length the length, which the result shall have
|
|
| 50 |
- * @param {string} symbol the string, which will be added (multiple times)
|
|
| 51 |
- * @param {boolean} [prepend]; whether to prepend (~true) or append (~false); default: false
|
|
| 52 |
- * @return {string} the padded string
|
|
| 53 |
- * @author fenris |
|
| 54 |
- */ |
|
| 55 |
- function pad(word: string, length: int, symbol?: string, mode?: string): string; |
|
| 56 |
- /** |
|
| 57 |
- * @desc checks if a given string conttains a certain substring |
|
| 58 |
- * @param {string} string
|
|
| 59 |
- * @param {string} part
|
|
| 60 |
- * @return {boolean}
|
|
| 61 |
- * @author fenris |
|
| 62 |
- */ |
|
| 63 |
- function contains(chain: string, part: string): boolean; |
|
| 64 |
- /** |
|
| 65 |
- * @desc checks if a given string starts with a certain substring |
|
| 66 |
- * @param {string} string
|
|
| 67 |
- * @param {string} part
|
|
| 68 |
- * @return {boolean}
|
|
| 69 |
- * @author fenris |
|
| 70 |
- */ |
|
| 71 |
- function startsWith(chain: string, part: string): boolean; |
|
| 72 |
- /** |
|
| 73 |
- * @desc checks if a given string ends with a certain substring |
|
| 74 |
- * @param {string} string
|
|
| 75 |
- * @param {string} part
|
|
| 76 |
- * @return {boolean}
|
|
| 77 |
- * @author fenris |
|
| 78 |
- */ |
|
| 79 |
- function endsWith(chain: string, part: string): boolean; |
|
| 80 |
- /** |
|
| 81 |
- * @desc count the occourrences of a string in a string |
|
| 82 |
- * @param string haystack_string the string wich should be examined |
|
| 83 |
- * @param string needle_string the string which should be counted |
|
| 84 |
- * @author neuc |
|
| 85 |
- */ |
|
| 86 |
- function count_occourrences(haystack_string: string, needle_string: string, check_escape: boolean): int; |
|
| 87 |
- /** |
|
| 88 |
- * @desc replaces occurences of "${name}" in a string by the corresponding values of an argument object
|
|
| 89 |
- * @author fenris |
|
| 90 |
- */ |
|
| 91 |
- function coin(str: string, args: {
|
|
| 92 |
- [id: string]: string; |
|
| 93 |
- }): string; |
|
| 94 |
- /** |
|
| 95 |
- * @author fenris |
|
| 96 |
- */ |
|
| 97 |
- var stance: typeof coin; |
|
| 98 |
- /** |
|
| 99 |
- * @author fenris |
|
| 100 |
- */ |
|
| 101 |
- function url_encode({ "protocol": protocol, "host": host, "port": port, "path": path, "arguments": arguments_, }?: {
|
|
| 102 |
- protocol?: string; |
|
| 103 |
- host?: string; |
|
| 104 |
- port?: int; |
|
| 105 |
- path?: string; |
|
| 106 |
- arguments?: {
|
|
| 107 |
- [key: string]: string; |
|
| 108 |
- }; |
|
| 109 |
- }): string; |
|
| 110 |
- /** |
|
| 111 |
- * @author fenris |
|
| 112 |
- */ |
|
| 113 |
- var make_url: typeof url_encode; |
|
| 114 |
- /** |
|
| 115 |
- * @author fenris |
|
| 116 |
- * @todo arguments |
|
| 117 |
- */ |
|
| 118 |
- function url_decode(url: string): Object; |
|
| 119 |
- /** |
|
| 120 |
- * @author fenris |
|
| 121 |
- */ |
|
| 122 |
- function cut(str: string, length: int, delimiter?: string): string; |
|
| 123 |
-} |
|
| 124 |
-declare module lib_string {
|
|
| 125 |
- /** |
|
| 126 |
- * an implementation of c sprintf |
|
| 127 |
- * @param {string} string format string
|
|
| 128 |
- * @param {array} args arguments which should be filled into
|
|
| 129 |
- * @returns {string}
|
|
| 130 |
- */ |
|
| 131 |
- var sprintf: (input: string, args?: any[], original?: any) => string; |
|
| 132 |
- /** |
|
| 133 |
- * an implementation of c printf |
|
| 134 |
- * @param {string} string format string
|
|
| 135 |
- * @param {array} args arguments which should be filled into
|
|
| 136 |
- * @returns {string}
|
|
| 137 |
- */ |
|
| 138 |
- function printf(format: any, args: any): void; |
|
| 139 |
-} |
|
| 140 |
-declare var sprintf: (input: string, args?: any[], original?: any) => string; |
|
| 141 |
-declare var printf: typeof lib_string.printf; |
|
| 142 |
-declare var eml_log: any; |
|
| 143 |
-declare var track_exports: any; |
|
| 144 |
-declare var make_logger: (prefix: any, current_loglevel: any) => (obj: any, lvl: any) => void; |
| ... | ... |
@@ -1,906 +0,0 @@ |
| 1 |
-/* |
|
| 2 |
-This file is part of »bacterio-plankton:string«. |
|
| 3 |
- |
|
| 4 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 5 |
-<info@greenscale.de> |
|
| 6 |
- |
|
| 7 |
-»bacterio-plankton:string« is free software: you can redistribute it and/or modify |
|
| 8 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 9 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 10 |
-(at your option) any later version. |
|
| 11 |
- |
|
| 12 |
-»bacterio-plankton:string« is distributed in the hope that it will be useful, |
|
| 13 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 14 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 15 |
-GNU Lesser General Public License for more details. |
|
| 16 |
- |
|
| 17 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 18 |
-along with »bacterio-plankton:string«. If not, see <http://www.gnu.org/licenses/>. |
|
| 19 |
- */ |
|
| 20 |
-var plain_text_to_html = function (text) {
|
|
| 21 |
- var ret = text; |
|
| 22 |
- ret = ret.replace(/ /g, " "); // convert multiple whitespace to forced ones |
|
| 23 |
- ret = ret.split("\n").join("<br/>");
|
|
| 24 |
- return ret; |
|
| 25 |
-}; |
|
| 26 |
-/** |
|
| 27 |
- * @desc makes a valid |
|
| 28 |
- */ |
|
| 29 |
-var format_sentence = function (str, rtl, caseSense) {
|
|
| 30 |
- if (rtl === void 0) { rtl = false; }
|
|
| 31 |
- if (caseSense === void 0) { caseSense = true; }
|
|
| 32 |
- if (str === "") {
|
|
| 33 |
- return str; |
|
| 34 |
- } |
|
| 35 |
- else {
|
|
| 36 |
- var marks = {
|
|
| 37 |
- ".": true, |
|
| 38 |
- "?": true, |
|
| 39 |
- "!": true |
|
| 40 |
- }; |
|
| 41 |
- var default_mark = "."; |
|
| 42 |
- var ret = str.split("");
|
|
| 43 |
- if (!rtl) {
|
|
| 44 |
- ret[0] = ret[0].toLocaleUpperCase(); |
|
| 45 |
- if (!(ret[ret.length - 1] in marks)) {
|
|
| 46 |
- ret.push(default_mark); |
|
| 47 |
- } |
|
| 48 |
- } |
|
| 49 |
- else {
|
|
| 50 |
- ret[ret.length - 1] = ret[ret.length - 1].toLocaleUpperCase(); |
|
| 51 |
- if (!(ret[0] in marks)) {
|
|
| 52 |
- ret.unshift(default_mark); |
|
| 53 |
- } |
|
| 54 |
- } |
|
| 55 |
- return ret.join("");
|
|
| 56 |
- } |
|
| 57 |
-}; |
|
| 58 |
-var fill_string_template = function (template_string, object, fabric, delimiter, default_string, sloppy) {
|
|
| 59 |
- if (fabric === void 0) { fabric = function (object, key) { return object[key]; }; }
|
|
| 60 |
- if (delimiter === void 0) { delimiter = "%"; }
|
|
| 61 |
- if (default_string === void 0) { default_string = null; }
|
|
| 62 |
- function get_tags(str) {
|
|
| 63 |
- var r = new RegExp(delimiter + "[^\\s^" + delimiter + "]+" + delimiter, "gi"); |
|
| 64 |
- return ((str.match(r) || []).map(function (e) {
|
|
| 65 |
- return e.slice(delimiter.length, e.length - delimiter.length); |
|
| 66 |
- })); |
|
| 67 |
- } |
|
| 68 |
- function replace_tag(str, tag, value) {
|
|
| 69 |
- var r = new RegExp(delimiter + tag + delimiter, "gi"); |
|
| 70 |
- return str.replace(r, value); |
|
| 71 |
- } |
|
| 72 |
- function replace_tags(str, obj) {
|
|
| 73 |
- return (get_tags(str).reduce(function (ret, key) {
|
|
| 74 |
- var value = ""; |
|
| 75 |
- try {
|
|
| 76 |
- value = fabric(obj, key); |
|
| 77 |
- if ((!sloppy && (value === void 0)) || (sloppy && (value == void 0))) {
|
|
| 78 |
- value = default_string; |
|
| 79 |
- } |
|
| 80 |
- } |
|
| 81 |
- catch (e) {
|
|
| 82 |
- console.warn("invalid placeholder " + key);
|
|
| 83 |
- value = default_string; |
|
| 84 |
- } |
|
| 85 |
- return replace_tag(ret, key, value); |
|
| 86 |
- }, str)); |
|
| 87 |
- } |
|
| 88 |
- return replace_tags(template_string, object); |
|
| 89 |
-}; |
|
| 90 |
-var make_string_template = function (_template, _fabrics) {
|
|
| 91 |
- if (_fabrics === void 0) { _fabrics = {}; }
|
|
| 92 |
- function replace_tag(str, tag, value) {
|
|
| 93 |
- var r = new RegExp("%" + tag + "%", "gi");
|
|
| 94 |
- return str.replace(r, value); |
|
| 95 |
- } |
|
| 96 |
- function replace_tags(str, obj) {
|
|
| 97 |
- return (Object.keys(obj).reduce(function (ret, key) {
|
|
| 98 |
- return replace_tag(ret, key, _fabrics[key] || obj[key]); |
|
| 99 |
- }, str)); |
|
| 100 |
- } |
|
| 101 |
- return (function (tags) {
|
|
| 102 |
- return replace_tags(_template, tags); |
|
| 103 |
- }); |
|
| 104 |
-}; |
|
| 105 |
-var make_eml_header = (function () {
|
|
| 106 |
- var _template = ""; |
|
| 107 |
- _template += "From: %from%\n"; |
|
| 108 |
- _template += "To: %recipient%\n"; |
|
| 109 |
- _template += "Subject: %subject%\n"; |
|
| 110 |
- _template += "X-Mailer: greenscale-plankton.emlgen\n"; |
|
| 111 |
- return make_string_template(_template); |
|
| 112 |
-})(); |
|
| 113 |
-var make_eml_body = (function () {
|
|
| 114 |
- var exports = {};
|
|
| 115 |
- exports["simple_body"] = make_string_template("Content-Type: %contenttype%\n\n%body%\n\n");
|
|
| 116 |
- // very basic implementation |
|
| 117 |
- // parts = [{contenttype:"text/html; charset=UTF-8", body: "<h1>foo</h1>" }, {...}]
|
|
| 118 |
- exports["body_boundrary"] = function (parts, boundrary) {
|
|
| 119 |
- var _template = ""; |
|
| 120 |
- _template += "--%boundrary%\n"; |
|
| 121 |
- _template += "Content-Type: %contenttype%\n\n%body%\n\n"; |
|
| 122 |
- //_template += "--%boundrary%--\n\n"; |
|
| 123 |
- var maker = make_string_template(_template); |
|
| 124 |
- return (parts.reduce(function (prev, curr) {
|
|
| 125 |
- curr.boundrary = boundrary; |
|
| 126 |
- return [prev, maker(curr)].join("");
|
|
| 127 |
- }, "")); |
|
| 128 |
- }; |
|
| 129 |
- // body must be base64 encoded! |
|
| 130 |
- exports["attachment_boundrary"] = function (parts, boundrary) {
|
|
| 131 |
- var _template = ""; |
|
| 132 |
- _template += "--%boundrary%\n"; |
|
| 133 |
- _template += "Content-Type: %contenttype%\n"; |
|
| 134 |
- _template += "Content-Transfer-Encoding: base64\n"; |
|
| 135 |
- _template += "Content-Disposition: %disposition%; filename=\"%name%\"\n\n"; |
|
| 136 |
- _template += "%body%\n\n"; |
|
| 137 |
- //_template += "--%boundrary%--\n\n"; |
|
| 138 |
- var maker = make_string_template(_template); |
|
| 139 |
- return (parts.reduce(function (prev, curr) {
|
|
| 140 |
- curr.boundrary = boundrary; |
|
| 141 |
- if (curr.disposition === void 0) |
|
| 142 |
- curr.disposition = "inline"; |
|
| 143 |
- return [prev, maker(curr)].join("");
|
|
| 144 |
- }, "")); |
|
| 145 |
- }; |
|
| 146 |
- exports["gen_boundrary"] = function () {
|
|
| 147 |
- return ("xxxxxxxxxxxxxxxxxxxxxx".replace(/[xy]/g, function (c) {
|
|
| 148 |
- var r = crypto.getRandomValues(new Uint8Array(1))[0] % 16 | 0, v = c == "x" ? r : (r & 0x3 | 0x8); |
|
| 149 |
- return v.toString(16); |
|
| 150 |
- })); |
|
| 151 |
- }; |
|
| 152 |
- // simple implementation without alternatives (old rfc) |
|
| 153 |
- exports["complete_boundrary"] = function (bodyparts, attachments) {
|
|
| 154 |
- var ret = ""; |
|
| 155 |
- var boundrary = exports["gen_boundrary"](); |
|
| 156 |
- ret += exports["body_boundrary"](bodyparts, boundrary); |
|
| 157 |
- ret += exports["attachment_boundrary"](attachments, boundrary); |
|
| 158 |
- ret += "--" + boundrary + "--\n\nINVISIBLE!!!!"; |
|
| 159 |
- return (exports["simple_body"]({
|
|
| 160 |
- "contenttype": sprintf("multipart/mixed; boundary=%s", [boundrary]),
|
|
| 161 |
- "body": ret |
|
| 162 |
- })); |
|
| 163 |
- }; |
|
| 164 |
- return exports; |
|
| 165 |
-})(); |
|
| 166 |
-/* |
|
| 167 |
-This file is part of »bacterio-plankton:string«. |
|
| 168 |
- |
|
| 169 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 170 |
-<info@greenscale.de> |
|
| 171 |
- |
|
| 172 |
-»bacterio-plankton:string« is free software: you can redistribute it and/or modify |
|
| 173 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 174 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 175 |
-(at your option) any later version. |
|
| 176 |
- |
|
| 177 |
-»bacterio-plankton:string« is distributed in the hope that it will be useful, |
|
| 178 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 179 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 180 |
-GNU Lesser General Public License for more details. |
|
| 181 |
- |
|
| 182 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 183 |
-along with »bacterio-plankton:string«. If not, see <http://www.gnu.org/licenses/>. |
|
| 184 |
- */ |
|
| 185 |
-var lib_string; |
|
| 186 |
-(function (lib_string) {
|
|
| 187 |
- /** |
|
| 188 |
- * @author fenris |
|
| 189 |
- */ |
|
| 190 |
- var hexdigits = 4; |
|
| 191 |
- /** |
|
| 192 |
- * @author fenris |
|
| 193 |
- */ |
|
| 194 |
- var index_max = (1 << (4 * hexdigits)); |
|
| 195 |
- /** |
|
| 196 |
- * @author fenris |
|
| 197 |
- */ |
|
| 198 |
- var index_is = 0; |
|
| 199 |
- /** |
|
| 200 |
- * @author neuc,frac |
|
| 201 |
- */ |
|
| 202 |
- function empty(str) {
|
|
| 203 |
- return (str.trim() === ""); |
|
| 204 |
- } |
|
| 205 |
- lib_string.empty = empty; |
|
| 206 |
- /** |
|
| 207 |
- * @desc returns a unique string |
|
| 208 |
- * @param {string} prefix an optional prefix for the generated string
|
|
| 209 |
- * @return {string}
|
|
| 210 |
- * @author fenris |
|
| 211 |
- */ |
|
| 212 |
- function generate(prefix) {
|
|
| 213 |
- if (prefix === void 0) { prefix = "string_"; }
|
|
| 214 |
- if (index_is > index_max) {
|
|
| 215 |
- throw (new Error("[string_generate] out of valid indices"));
|
|
| 216 |
- } |
|
| 217 |
- else {
|
|
| 218 |
- return lib_string.sprintf(prefix + "%0" + hexdigits.toString() + "X", [index_is++]); |
|
| 219 |
- } |
|
| 220 |
- } |
|
| 221 |
- lib_string.generate = generate; |
|
| 222 |
- /** |
|
| 223 |
- * @desc splits a string, but returns an empty list, if the string is empty |
|
| 224 |
- * @param {string} chain
|
|
| 225 |
- * @param {string} separator
|
|
| 226 |
- * @return {Array<string>}
|
|
| 227 |
- * @author fenris |
|
| 228 |
- */ |
|
| 229 |
- function split(chain, separator) {
|
|
| 230 |
- if (separator === void 0) { separator = " "; }
|
|
| 231 |
- if (chain.length == 0) {
|
|
| 232 |
- return []; |
|
| 233 |
- } |
|
| 234 |
- else {
|
|
| 235 |
- return chain.split(separator); |
|
| 236 |
- } |
|
| 237 |
- } |
|
| 238 |
- lib_string.split = split; |
|
| 239 |
- /** |
|
| 240 |
- * @author neu3no |
|
| 241 |
- */ |
|
| 242 |
- function explode(str, needle, max) {
|
|
| 243 |
- var temp = str.split(needle); |
|
| 244 |
- var right = temp.splice(max - 1); |
|
| 245 |
- temp.push(right.join(needle)); |
|
| 246 |
- return temp; |
|
| 247 |
- } |
|
| 248 |
- lib_string.explode = explode; |
|
| 249 |
- /** |
|
| 250 |
- * @desc concats a given word with itself n times |
|
| 251 |
- * @param {string} word
|
|
| 252 |
- * @param {int}
|
|
| 253 |
- * @return {string}
|
|
| 254 |
- * @author fenris |
|
| 255 |
- */ |
|
| 256 |
- function repeat(word, count) {
|
|
| 257 |
- // return ((count == 0) ? "" : (word + repeat(word, count-1))); |
|
| 258 |
- var result = ""; |
|
| 259 |
- for (var n = 0; n < count; n += 1) {
|
|
| 260 |
- result += word; |
|
| 261 |
- } |
|
| 262 |
- return result; |
|
| 263 |
- } |
|
| 264 |
- lib_string.repeat = repeat; |
|
| 265 |
- /** |
|
| 266 |
- * @desc lengthens a string by repeatedly appending or prepending another string |
|
| 267 |
- * @param {string} word the string to pad
|
|
| 268 |
- * @param {int} length the length, which the result shall have
|
|
| 269 |
- * @param {string} symbol the string, which will be added (multiple times)
|
|
| 270 |
- * @param {boolean} [prepend]; whether to prepend (~true) or append (~false); default: false
|
|
| 271 |
- * @return {string} the padded string
|
|
| 272 |
- * @author fenris |
|
| 273 |
- */ |
|
| 274 |
- function pad(word, length, symbol, mode) {
|
|
| 275 |
- if (symbol === void 0) { symbol = " "; }
|
|
| 276 |
- if (mode === void 0) { mode = "append"; }
|
|
| 277 |
- switch (mode) {
|
|
| 278 |
- case "prepend": {
|
|
| 279 |
- // insert symbols only at the beginning |
|
| 280 |
- while (word.length < length) |
|
| 281 |
- word = symbol + word; |
|
| 282 |
- return word.substring(word.length - length); |
|
| 283 |
- break; |
|
| 284 |
- } |
|
| 285 |
- case "append": {
|
|
| 286 |
- // insert symbols only at the end |
|
| 287 |
- while (word.length < length) |
|
| 288 |
- word = word + symbol; |
|
| 289 |
- return word.substring(0, length); |
|
| 290 |
- break; |
|
| 291 |
- } |
|
| 292 |
- case "widen": {
|
|
| 293 |
- // insert symbols at both sides |
|
| 294 |
- var left = (((length - word.length) & 1) === 0); |
|
| 295 |
- while (word.length < length) {
|
|
| 296 |
- word = (left |
|
| 297 |
- ? (symbol + word) |
|
| 298 |
- : (word + symbol)); |
|
| 299 |
- left = (!left); |
|
| 300 |
- } |
|
| 301 |
- return word.substring(0, length); |
|
| 302 |
- break; |
|
| 303 |
- } |
|
| 304 |
- default: {
|
|
| 305 |
- var message = ("unhandled mode '" + mode + "'");
|
|
| 306 |
- console.warn(message); |
|
| 307 |
- return word; |
|
| 308 |
- break; |
|
| 309 |
- } |
|
| 310 |
- } |
|
| 311 |
- } |
|
| 312 |
- lib_string.pad = pad; |
|
| 313 |
- /** |
|
| 314 |
- * @desc checks if a given string conttains a certain substring |
|
| 315 |
- * @param {string} string
|
|
| 316 |
- * @param {string} part
|
|
| 317 |
- * @return {boolean}
|
|
| 318 |
- * @author fenris |
|
| 319 |
- */ |
|
| 320 |
- function contains(chain, part) {
|
|
| 321 |
- if (typeof (chain) !== "string") {
|
|
| 322 |
- return false; |
|
| 323 |
- } |
|
| 324 |
- return (chain.indexOf(part) >= 0); |
|
| 325 |
- } |
|
| 326 |
- lib_string.contains = contains; |
|
| 327 |
- /** |
|
| 328 |
- * @desc checks if a given string starts with a certain substring |
|
| 329 |
- * @param {string} string
|
|
| 330 |
- * @param {string} part
|
|
| 331 |
- * @return {boolean}
|
|
| 332 |
- * @author fenris |
|
| 333 |
- */ |
|
| 334 |
- function startsWith(chain, part) {
|
|
| 335 |
- if (typeof (chain) !== "string") {
|
|
| 336 |
- return false; |
|
| 337 |
- } |
|
| 338 |
- // return (string.indexOf(part) === 0); |
|
| 339 |
- return ((function (m, n) {
|
|
| 340 |
- if (n === 0) {
|
|
| 341 |
- return true; |
|
| 342 |
- } |
|
| 343 |
- else {
|
|
| 344 |
- if (m === 0) {
|
|
| 345 |
- return false; |
|
| 346 |
- } |
|
| 347 |
- else {
|
|
| 348 |
- return ((chain[0] == part[0]) |
|
| 349 |
- && |
|
| 350 |
- startsWith(chain.substring(1), part.substring(1))); |
|
| 351 |
- } |
|
| 352 |
- } |
|
| 353 |
- })(chain.length, part.length)); |
|
| 354 |
- } |
|
| 355 |
- lib_string.startsWith = startsWith; |
|
| 356 |
- /** |
|
| 357 |
- * @desc checks if a given string ends with a certain substring |
|
| 358 |
- * @param {string} string
|
|
| 359 |
- * @param {string} part
|
|
| 360 |
- * @return {boolean}
|
|
| 361 |
- * @author fenris |
|
| 362 |
- */ |
|
| 363 |
- function endsWith(chain, part) {
|
|
| 364 |
- if (typeof (chain) !== "string") {
|
|
| 365 |
- return false; |
|
| 366 |
- } |
|
| 367 |
- // return (string.lastIndexOf(part) === string.length-part.length); |
|
| 368 |
- return ((function (m, n) {
|
|
| 369 |
- if (n === 0) {
|
|
| 370 |
- return true; |
|
| 371 |
- } |
|
| 372 |
- else {
|
|
| 373 |
- if (m === 0) {
|
|
| 374 |
- return false; |
|
| 375 |
- } |
|
| 376 |
- else {
|
|
| 377 |
- // console.info(("(" + string[m-1] + " == " + part[n-1] + ")") + " = " + String(string[m-1] == part[n-1]));
|
|
| 378 |
- return ((chain[m - 1] === part[n - 1]) |
|
| 379 |
- && |
|
| 380 |
- endsWith(chain.substring(0, m - 1), part.substring(0, n - 1))); |
|
| 381 |
- } |
|
| 382 |
- } |
|
| 383 |
- })(chain.length, part.length)); |
|
| 384 |
- } |
|
| 385 |
- lib_string.endsWith = endsWith; |
|
| 386 |
- /** |
|
| 387 |
- * @desc count the occourrences of a string in a string |
|
| 388 |
- * @param string haystack_string the string wich should be examined |
|
| 389 |
- * @param string needle_string the string which should be counted |
|
| 390 |
- * @author neuc |
|
| 391 |
- */ |
|
| 392 |
- function count_occourrences(haystack_string, needle_string, check_escape) {
|
|
| 393 |
- var cnt = 0; |
|
| 394 |
- var pos = -1; |
|
| 395 |
- do {
|
|
| 396 |
- pos = haystack_string.indexOf(needle_string, pos + 1); |
|
| 397 |
- if ((!check_escape) || (haystack_string[pos - 1] != "\\")) {
|
|
| 398 |
- cnt++; |
|
| 399 |
- } |
|
| 400 |
- } while (pos >= 0); |
|
| 401 |
- return (cnt - 1); |
|
| 402 |
- } |
|
| 403 |
- lib_string.count_occourrences = count_occourrences; |
|
| 404 |
- /** |
|
| 405 |
- * @desc replaces occurences of "${name}" in a string by the corresponding values of an argument object
|
|
| 406 |
- * @author fenris |
|
| 407 |
- */ |
|
| 408 |
- function coin(str, args) {
|
|
| 409 |
- Object.keys(args).forEach(function (key) {
|
|
| 410 |
- // old syntax |
|
| 411 |
- {
|
|
| 412 |
- var value = args[key]; |
|
| 413 |
- var regexp_argument = new RegExp("\\${" + key + "}");
|
|
| 414 |
- str = str.replace(regexp_argument, value); |
|
| 415 |
- } |
|
| 416 |
- // new syntax |
|
| 417 |
- {
|
|
| 418 |
- var value = args[key]; |
|
| 419 |
- var regexp_argument = new RegExp("{{" + key + "}}");
|
|
| 420 |
- str = str.replace(regexp_argument, value); |
|
| 421 |
- } |
|
| 422 |
- }); |
|
| 423 |
- return str; |
|
| 424 |
- } |
|
| 425 |
- lib_string.coin = coin; |
|
| 426 |
- /** |
|
| 427 |
- * @author fenris |
|
| 428 |
- */ |
|
| 429 |
- lib_string.stance = coin; |
|
| 430 |
- /** |
|
| 431 |
- * @author fenris |
|
| 432 |
- */ |
|
| 433 |
- function url_encode(_a) {
|
|
| 434 |
- var _b = _a === void 0 ? {} : _a, _c = _b["protocol"], protocol = _c === void 0 ? null : _c, _d = _b["host"], host = _d === void 0 ? null : _d, _e = _b["port"], port = _e === void 0 ? null : _e, _f = _b["path"], path = _f === void 0 ? null : _f, _g = _b["arguments"], arguments_ = _g === void 0 ? null : _g;
|
|
| 435 |
- var url = ""; |
|
| 436 |
- // protocol |
|
| 437 |
- {
|
|
| 438 |
- if (protocol != null) {
|
|
| 439 |
- url = protocol + ":" + url; |
|
| 440 |
- } |
|
| 441 |
- } |
|
| 442 |
- // host |
|
| 443 |
- {
|
|
| 444 |
- if (host != null) {
|
|
| 445 |
- url = url + "//" + host; |
|
| 446 |
- } |
|
| 447 |
- } |
|
| 448 |
- // port |
|
| 449 |
- {
|
|
| 450 |
- if (port != null) {
|
|
| 451 |
- url = url + ":" + port.toString(); |
|
| 452 |
- } |
|
| 453 |
- } |
|
| 454 |
- // path |
|
| 455 |
- {
|
|
| 456 |
- if (path != null) {
|
|
| 457 |
- var path_ = encodeURI(path); |
|
| 458 |
- url = "" + url + path_; |
|
| 459 |
- } |
|
| 460 |
- } |
|
| 461 |
- // arguments |
|
| 462 |
- {
|
|
| 463 |
- if (arguments_ != null) {
|
|
| 464 |
- var suffix = Object.keys(arguments_).map(function (key) { return key + "=" + arguments_[key]; }).join("&");
|
|
| 465 |
- var suffix_ = encodeURI(suffix); |
|
| 466 |
- url = url + "?" + suffix_; |
|
| 467 |
- } |
|
| 468 |
- } |
|
| 469 |
- return url; |
|
| 470 |
- } |
|
| 471 |
- lib_string.url_encode = url_encode; |
|
| 472 |
- /** |
|
| 473 |
- * @author fenris |
|
| 474 |
- */ |
|
| 475 |
- lib_string.make_url = url_encode; |
|
| 476 |
- /** |
|
| 477 |
- * @author fenris |
|
| 478 |
- * @todo arguments |
|
| 479 |
- */ |
|
| 480 |
- function url_decode(url) {
|
|
| 481 |
- var regexp = new RegExp("^([^:]*)://([^:]*):([^/]*)/(.*)$");
|
|
| 482 |
- var matching = regexp.exec(url); |
|
| 483 |
- if (matching === null) {
|
|
| 484 |
- return null; |
|
| 485 |
- } |
|
| 486 |
- else {
|
|
| 487 |
- var components = {
|
|
| 488 |
- "protocol": matching[1], |
|
| 489 |
- "host": matching[2], |
|
| 490 |
- "port": parseInt(matching[3]), |
|
| 491 |
- "path": ("/" + matching[4])
|
|
| 492 |
- }; |
|
| 493 |
- return components; |
|
| 494 |
- } |
|
| 495 |
- } |
|
| 496 |
- lib_string.url_decode = url_decode; |
|
| 497 |
- /** |
|
| 498 |
- * @author fenris |
|
| 499 |
- */ |
|
| 500 |
- function cut(str, length, delimiter) {
|
|
| 501 |
- if (delimiter === void 0) { delimiter = "…"; }
|
|
| 502 |
- if (str.length <= length) {
|
|
| 503 |
- return str; |
|
| 504 |
- } |
|
| 505 |
- else {
|
|
| 506 |
- return (str.slice(0, length - delimiter.length) + delimiter); |
|
| 507 |
- } |
|
| 508 |
- } |
|
| 509 |
- lib_string.cut = cut; |
|
| 510 |
-})(lib_string || (lib_string = {}));
|
|
| 511 |
-/* |
|
| 512 |
-This file is part of »bacterio-plankton:string«. |
|
| 513 |
- |
|
| 514 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 515 |
-<info@greenscale.de> |
|
| 516 |
- |
|
| 517 |
-»bacterio-plankton:string« is free software: you can redistribute it and/or modify |
|
| 518 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 519 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 520 |
-(at your option) any later version. |
|
| 521 |
- |
|
| 522 |
-»bacterio-plankton:string« is distributed in the hope that it will be useful, |
|
| 523 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 524 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 525 |
-GNU Lesser General Public License for more details. |
|
| 526 |
- |
|
| 527 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 528 |
-along with »bacterio-plankton:string«. If not, see <http://www.gnu.org/licenses/>. |
|
| 529 |
- */ |
|
| 530 |
-var lib_string; |
|
| 531 |
-(function (lib_string) {
|
|
| 532 |
- var pattern = /%([-+#0 ]*)([0-9]*)[\.]{0,1}([0-9]*)([\w]{1})/;
|
|
| 533 |
- var gpattern = /%([-+#0 ]*)([0-9]*)[\.]{0,1}([0-9]*)([\w]{1})/g;
|
|
| 534 |
- function split_format(format) {
|
|
| 535 |
- var tmp = format.match(pattern); |
|
| 536 |
- if (tmp === null) |
|
| 537 |
- return null; |
|
| 538 |
- return {
|
|
| 539 |
- 'flags': tmp[1].split(""),
|
|
| 540 |
- 'width': Number(tmp[2]), |
|
| 541 |
- 'precision': tmp[3] === '' ? null : Number(tmp[3]), |
|
| 542 |
- 'specifier': tmp[4], |
|
| 543 |
- 'string': format |
|
| 544 |
- }; |
|
| 545 |
- } |
|
| 546 |
- function make_err(format, arg, should) {
|
|
| 547 |
- return ("[sprintf]" + " " + "argument for '" + format.string + "' has to be '" + should + "' but '" + arg + "' is '" + typeof arg + "'!");
|
|
| 548 |
- } |
|
| 549 |
- function test_arg(format, arg, should) {
|
|
| 550 |
- if (typeof arg !== should) {
|
|
| 551 |
- console.warn(make_err(format, arg, should)); |
|
| 552 |
- return false; |
|
| 553 |
- } |
|
| 554 |
- return true; |
|
| 555 |
- } |
|
| 556 |
- function string_fill(str, char, len, left) {
|
|
| 557 |
- while (str.length < len) {
|
|
| 558 |
- if (left) {
|
|
| 559 |
- str += char; |
|
| 560 |
- } |
|
| 561 |
- else {
|
|
| 562 |
- str = char + str; |
|
| 563 |
- } |
|
| 564 |
- } |
|
| 565 |
- return str; |
|
| 566 |
- } |
|
| 567 |
- /** |
|
| 568 |
- * the known_parameters are used to parse the different identifiers for the welln known syntax: |
|
| 569 |
- * flag width precision identifier |
|
| 570 |
- * %{[0#+- ]}{[0-9]*}.{[0-9]*}[fFdiueEgGsoxXaAsn]
|
|
| 571 |
- * flags: |
|
| 572 |
- * 0 - fill with '0' instead of ' ' if the string length < width |
|
| 573 |
- * # - not implemented |
|
| 574 |
- * - - left-justified -> fill on the right side to reach width |
|
| 575 |
- * + - force using '+' on positive numbers |
|
| 576 |
- * ' ' - add a single space before positive numbers |
|
| 577 |
- * |
|
| 578 |
- * identifiers |
|
| 579 |
- * %f, %F - interpret given number as float, width: the minimal total width (fill with ' ' or '0' if the |
|
| 580 |
- * resulting string is too short, precision: cut more then given decimal places |
|
| 581 |
- * %d, %i, %u - interpret number as integer, decimal places will be cut. width: like float, precision: |
|
| 582 |
- * fill with '0' on right side until length given in precision is reached |
|
| 583 |
- * %e - interpret as float and write as scientifical number, width & precision like in float |
|
| 584 |
- * %E - same es %e but uppercase 'E' |
|
| 585 |
- * %g - use the shortest string of %f or %e |
|
| 586 |
- * %G - use the shortest string of %E or %E |
|
| 587 |
- * %s - simply print a string |
|
| 588 |
- * %o - print the given number in octal notation |
|
| 589 |
- * %x - print the given number in hex notation |
|
| 590 |
- * %X - same as %x but with uppercase characters |
|
| 591 |
- * %a - alias to %x |
|
| 592 |
- * %A - alias to %X |
|
| 593 |
- * %n - just print nothing |
|
| 594 |
- * @type {{}}
|
|
| 595 |
- */ |
|
| 596 |
- var known_params = {};
|
|
| 597 |
- known_params["f"] = function (format, arg) {
|
|
| 598 |
- if (!test_arg(format, arg, "number")) |
|
| 599 |
- return "Ø"; |
|
| 600 |
- var tmp = Math.abs(arg); |
|
| 601 |
- var sign = (arg < 0) ? -1 : 1; |
|
| 602 |
- var tmp_result = null; |
|
| 603 |
- if (format.precision !== null) {
|
|
| 604 |
- tmp = Math.floor(Math.pow(10, format.precision) * tmp) / Math.pow(10, format.precision); |
|
| 605 |
- var tmp_ = (tmp * sign).toString().split(".");
|
|
| 606 |
- if (tmp_.length === 1) |
|
| 607 |
- tmp_.push("");
|
|
| 608 |
- tmp_[1] = string_fill(tmp_[1], "0", format.precision, true); |
|
| 609 |
- tmp_result = tmp_.join(".");
|
|
| 610 |
- } |
|
| 611 |
- else {
|
|
| 612 |
- tmp_result = (sign * tmp).toString(); |
|
| 613 |
- } |
|
| 614 |
- if ((format.flags.indexOf(" ") >= 0) && (arg >= 0)) {
|
|
| 615 |
- tmp_result = " " + tmp; |
|
| 616 |
- } |
|
| 617 |
- else if ((format.flags.indexOf("+") >= 0) && (arg >= 0)) {
|
|
| 618 |
- tmp_result = "+" + tmp; |
|
| 619 |
- } |
|
| 620 |
- tmp_result = string_fill(tmp, (format.flags.indexOf("0") >= 0) ? "0" : " ", format.width, (format.flags.indexOf("-") >= 0));
|
|
| 621 |
- return tmp_result; |
|
| 622 |
- }; |
|
| 623 |
- known_params["F"] = known_params["f"]; |
|
| 624 |
- known_params["d"] = function (format, arg) {
|
|
| 625 |
- if (!test_arg(format, arg, 'number')) |
|
| 626 |
- return 'Ø'; |
|
| 627 |
- var tmp = (((arg < 0 && format.specifier !== 'u') ? -1 : 1) * Math.floor(Math.abs(arg))).toString(); |
|
| 628 |
- if ((format.specifier === 'd' || format.specifier === 'i') && format.flags.indexOf(' ') >= 0 && arg >= 0) {
|
|
| 629 |
- tmp = ' ' + tmp; |
|
| 630 |
- } |
|
| 631 |
- else if ((format.specifier === 'd' || format.specifier === 'i') && format.flags.indexOf('+') >= 0 && arg >= 0) {
|
|
| 632 |
- tmp = '+' + tmp; |
|
| 633 |
- } |
|
| 634 |
- tmp = string_fill(tmp, format.flags.indexOf('0') >= 0 ? '0' : ' ', format.width, format.flags.indexOf('-') >= 0);
|
|
| 635 |
- tmp = string_fill(tmp, '0', format.precision === null ? 0 : format.precision, false); |
|
| 636 |
- return tmp; |
|
| 637 |
- }; |
|
| 638 |
- known_params["i"] = known_params["d"]; |
|
| 639 |
- known_params["u"] = known_params["d"]; |
|
| 640 |
- known_params["e"] = function (format, arg) {
|
|
| 641 |
- if (!test_arg(format, arg, 'number')) |
|
| 642 |
- return 'Ø'; |
|
| 643 |
- var tmp = arg.toExponential(format.precision === null ? undefined : format.precision).toString(); |
|
| 644 |
- if (format.flags.indexOf(' ') >= 0 && arg >= 0) {
|
|
| 645 |
- tmp = ' ' + tmp; |
|
| 646 |
- } |
|
| 647 |
- else if (format.flags.indexOf('+') >= 0 && arg >= 0) {
|
|
| 648 |
- tmp = '+' + tmp; |
|
| 649 |
- } |
|
| 650 |
- tmp = string_fill(tmp, format.flags.indexOf('0') >= 0 ? '0' : ' ', format.width, format.flags.indexOf('-') >= 0);
|
|
| 651 |
- return tmp; |
|
| 652 |
- }; |
|
| 653 |
- known_params["E"] = function (format, arg) {
|
|
| 654 |
- return known_params["e"](format, arg).toUpperCase(); |
|
| 655 |
- }; |
|
| 656 |
- known_params["g"] = function (format, arg) {
|
|
| 657 |
- if (!test_arg(format, arg, 'number')) |
|
| 658 |
- return 'Ø'; |
|
| 659 |
- var tmpf = known_params["f"](format, arg); |
|
| 660 |
- var tmpe = known_params["e"](format, arg); |
|
| 661 |
- if (tmpf.length < tmpe.length) {
|
|
| 662 |
- return tmpf; |
|
| 663 |
- } |
|
| 664 |
- else {
|
|
| 665 |
- return tmpe; |
|
| 666 |
- } |
|
| 667 |
- }; |
|
| 668 |
- known_params["G"] = function (format, arg) {
|
|
| 669 |
- return known_params["g"](format, arg).toUpperCase(); |
|
| 670 |
- }; |
|
| 671 |
- known_params["s"] = function (format, arg) {
|
|
| 672 |
- if (!test_arg(format, arg, 'string')) |
|
| 673 |
- return 'o.O'; |
|
| 674 |
- var tmp = format.precision !== null ? arg.substr(0, format.precision) : arg; |
|
| 675 |
- tmp = string_fill(tmp, format.flags.indexOf('0') >= 0 ? '0' : ' ', format.width, format.flags.indexOf('-') >= 0);
|
|
| 676 |
- return tmp; |
|
| 677 |
- }; |
|
| 678 |
- known_params["o"] = function (format, arg) {
|
|
| 679 |
- if (!test_arg(format, arg, 'number')) |
|
| 680 |
- return 'Ø'; |
|
| 681 |
- var tmp = Math.floor(Math.round(Math.abs(arg))) * ((arg < 0) ? -1 : 1); |
|
| 682 |
- return known_params["s"](format, tmp.toString(8)); |
|
| 683 |
- }; |
|
| 684 |
- known_params["x"] = function (format, arg) {
|
|
| 685 |
- if (!test_arg(format, arg, 'number')) |
|
| 686 |
- return 'Ø'; |
|
| 687 |
- var tmp = Math.floor(Math.round(Math.abs(arg))) * ((arg < 0) ? -1 : 1); |
|
| 688 |
- return known_params["s"](format, tmp.toString(16)); |
|
| 689 |
- }; |
|
| 690 |
- known_params["a"] = known_params["x"]; |
|
| 691 |
- known_params["X"] = function (format, arg) {
|
|
| 692 |
- if (!test_arg(format, arg, 'number')) |
|
| 693 |
- return 'Ø'; |
|
| 694 |
- return known_params["x"](format, arg).toUpperCase(); |
|
| 695 |
- }; |
|
| 696 |
- known_params["A"] = known_params["X"]; |
|
| 697 |
- known_params["c"] = function (format, arg) {
|
|
| 698 |
- var tmp = ""; |
|
| 699 |
- if (typeof arg === "number") {
|
|
| 700 |
- tmp = String.fromCharCode(arg); |
|
| 701 |
- } |
|
| 702 |
- else if ((typeof arg === "string") && (arg.length === 1)) {
|
|
| 703 |
- tmp = arg[0]; |
|
| 704 |
- } |
|
| 705 |
- else {
|
|
| 706 |
- console.warn(make_err(format, arg, "number|string") + " and if string it needs to have the length of 1!"); |
|
| 707 |
- } |
|
| 708 |
- return known_params["s"](format, tmp); |
|
| 709 |
- }; |
|
| 710 |
- known_params["n"] = function () {
|
|
| 711 |
- return ""; |
|
| 712 |
- }; |
|
| 713 |
- var decompose = function (chain, regexp) {
|
|
| 714 |
- var result = regexp.exec(chain); |
|
| 715 |
- if (result == null) {
|
|
| 716 |
- return null; |
|
| 717 |
- } |
|
| 718 |
- else {
|
|
| 719 |
- var front = chain.substring(0, result.index); |
|
| 720 |
- var back = chain.substring(result.index + result[0].length); |
|
| 721 |
- return { "front": front, "match": result[0], "back": back };
|
|
| 722 |
- } |
|
| 723 |
- }; |
|
| 724 |
- /** |
|
| 725 |
- * an implementation of c sprintf |
|
| 726 |
- * @param {string} string format string
|
|
| 727 |
- * @param {array} args arguments which should be filled into
|
|
| 728 |
- * @returns {string}
|
|
| 729 |
- */ |
|
| 730 |
- lib_string.sprintf = function (input, args, original) {
|
|
| 731 |
- if (args === void 0) { args = []; }
|
|
| 732 |
- if (original === void 0) { original = null; }
|
|
| 733 |
- if (original == null) |
|
| 734 |
- original = input; |
|
| 735 |
- var components = decompose(input, pattern); |
|
| 736 |
- if (components == null) {
|
|
| 737 |
- if (args.length > 0) {
|
|
| 738 |
- console.warn("[sprintf] superfluous arguments while formatting '" + original + "': ", args);
|
|
| 739 |
- } |
|
| 740 |
- return input; |
|
| 741 |
- } |
|
| 742 |
- else {
|
|
| 743 |
- var arg; |
|
| 744 |
- var rest; |
|
| 745 |
- if (args.length > 0) {
|
|
| 746 |
- arg = args[0]; |
|
| 747 |
- rest = args.slice(1); |
|
| 748 |
- } |
|
| 749 |
- else {
|
|
| 750 |
- console.warn("[sprintf] out of arguments while formatting '" + original + "'");
|
|
| 751 |
- arg = null; |
|
| 752 |
- rest = []; |
|
| 753 |
- return input; |
|
| 754 |
- } |
|
| 755 |
- var fmt = split_format(components["match"]); |
|
| 756 |
- return (components["front"] |
|
| 757 |
- + known_params[fmt.specifier](fmt, arg) |
|
| 758 |
- + lib_string.sprintf(components["back"], rest, original)); |
|
| 759 |
- } |
|
| 760 |
- }; |
|
| 761 |
- /** |
|
| 762 |
- * an implementation of c printf |
|
| 763 |
- * @param {string} string format string
|
|
| 764 |
- * @param {array} args arguments which should be filled into
|
|
| 765 |
- * @returns {string}
|
|
| 766 |
- */ |
|
| 767 |
- function printf(format, args) {
|
|
| 768 |
- console.log(lib_string.sprintf(format, args)); |
|
| 769 |
- } |
|
| 770 |
- lib_string.printf = printf; |
|
| 771 |
-})(lib_string || (lib_string = {}));
|
|
| 772 |
-var sprintf = lib_string.sprintf; |
|
| 773 |
-var printf = lib_string.printf; |
|
| 774 |
-/* |
|
| 775 |
-This file is part of »bacterio-plankton:string«. |
|
| 776 |
- |
|
| 777 |
-Copyright 2016-2021 'Christian Fraß, Christian Neubauer, Martin Springwald GbR' |
|
| 778 |
-<info@greenscale.de> |
|
| 779 |
- |
|
| 780 |
-»bacterio-plankton:string« is free software: you can redistribute it and/or modify |
|
| 781 |
-it under the terms of the GNU Lesser General Public License as published by |
|
| 782 |
-the Free Software Foundation, either version 3 of the License, or |
|
| 783 |
-(at your option) any later version. |
|
| 784 |
- |
|
| 785 |
-»bacterio-plankton:string« is distributed in the hope that it will be useful, |
|
| 786 |
-but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 787 |
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
| 788 |
-GNU Lesser General Public License for more details. |
|
| 789 |
- |
|
| 790 |
-You should have received a copy of the GNU Lesser General Public License |
|
| 791 |
-along with »bacterio-plankton:string«. If not, see <http://www.gnu.org/licenses/>. |
|
| 792 |
- */ |
|
| 793 |
-var make_logger = (function () {
|
|
| 794 |
- var _loggers = {};
|
|
| 795 |
- var make_logger = function (prefix, current_loglevel) {
|
|
| 796 |
- var log = []; |
|
| 797 |
- var level = [ |
|
| 798 |
- "LOG", "INFO", "WARNING", "DEBUG" |
|
| 799 |
- ]; |
|
| 800 |
- var logger = function (obj, lvl) {
|
|
| 801 |
- var txt = obj.txt || obj; |
|
| 802 |
- if (lvl == void 0) |
|
| 803 |
- lvl = 0; |
|
| 804 |
- var date = new Date(); |
|
| 805 |
- log.push({
|
|
| 806 |
- "message": sprintf("%s [%s:%s] %s", [date.toString(), level[lvl], prefix, txt]),
|
|
| 807 |
- "timeStamp": +(date) |
|
| 808 |
- }); |
|
| 809 |
- if (lvl <= current_loglevel) {
|
|
| 810 |
- var msg = ["[" + prefix + "]", txt]; |
|
| 811 |
- if (obj.arg) |
|
| 812 |
- msg = ["[" + prefix + "]"].concat(Array.prototype.slice.call(obj.arg)); |
|
| 813 |
- if (lvl === 0) |
|
| 814 |
- console["_log"].apply(console, msg); |
|
| 815 |
- else if (lvl === 1) |
|
| 816 |
- console["_info"].apply(console, msg); |
|
| 817 |
- else if (lvl === 2) |
|
| 818 |
- console["_warn"].apply(console, msg); |
|
| 819 |
- else if (lvl >= 3) |
|
| 820 |
- console["_log"].apply(console, msg); |
|
| 821 |
- } |
|
| 822 |
- }; |
|
| 823 |
- _loggers[prefix] = {
|
|
| 824 |
- "logger": logger, |
|
| 825 |
- "log": log |
|
| 826 |
- }; |
|
| 827 |
- return logger; |
|
| 828 |
- }; |
|
| 829 |
- make_logger["loggers"] = _loggers; |
|
| 830 |
- make_logger["complete_log"] = function () {
|
|
| 831 |
- var logs = Object.keys(_loggers) |
|
| 832 |
- .reduce(function (p, c) {
|
|
| 833 |
- return [].concat(p, _loggers[c].log); |
|
| 834 |
- }, []); |
|
| 835 |
- logs.sort(function (x, y) {
|
|
| 836 |
- return ((x.timeStamp > y.timeStamp) ? -1 : +1); |
|
| 837 |
- }); |
|
| 838 |
- return logs.map(function (x, i, a) {
|
|
| 839 |
- return x.message; |
|
| 840 |
- }); |
|
| 841 |
- }; |
|
| 842 |
- if ( /*!track_exports*/true) {
|
|
| 843 |
- var _log_all = function (log, lvl, next) {
|
|
| 844 |
- if (next === void 0) { next = function () { }; }
|
|
| 845 |
- return function () {
|
|
| 846 |
- var msg = []; |
|
| 847 |
- for (var i = 0; i < arguments.length; i++) {
|
|
| 848 |
- if (typeof arguments[i] === "string") {
|
|
| 849 |
- msg.push(arguments[i]); |
|
| 850 |
- } |
|
| 851 |
- else {
|
|
| 852 |
- msg.push(JSON.stringify(arguments[i])); |
|
| 853 |
- } |
|
| 854 |
- } |
|
| 855 |
- var obj = {
|
|
| 856 |
- txt: msg.join("\t"),
|
|
| 857 |
- arg: arguments |
|
| 858 |
- }; |
|
| 859 |
- log(obj, lvl); |
|
| 860 |
- next(); |
|
| 861 |
- }; |
|
| 862 |
- }; |
|
| 863 |
- {
|
|
| 864 |
- var __warn = make_logger("deprecated console.warn", 99);
|
|
| 865 |
- var __error = make_logger("deprecated console.error", 99);
|
|
| 866 |
- var __log = make_logger("deprecated console.log", 99);
|
|
| 867 |
- var __info = make_logger("deprecated console.info", 99);
|
|
| 868 |
- // bad ass |
|
| 869 |
- console["_log"] = console.log; |
|
| 870 |
- console["_error"] = console.error; |
|
| 871 |
- console["_warn"] = console.warn; |
|
| 872 |
- console["_info"] = console.info; |
|
| 873 |
- /* |
|
| 874 |
- console["log"] = _log_all(__log, 0); |
|
| 875 |
- console["error"] = _log_all(__error, 2); |
|
| 876 |
- console["warn"] = _log_all(__warn, 2); |
|
| 877 |
- console["info"] = _log_all(__info, 0); |
|
| 878 |
- */ |
|
| 879 |
- } |
|
| 880 |
- /* |
|
| 881 |
- {
|
|
| 882 |
- make_logger["send_log"] = function(){
|
|
| 883 |
- eml_log( |
|
| 884 |
- function () {
|
|
| 885 |
- alert("fehlerbericht wurde gesendet!");
|
|
| 886 |
- } |
|
| 887 |
- ); |
|
| 888 |
- }; |
|
| 889 |
- var error_log = make_logger("global.error", 99);
|
|
| 890 |
- window.onerror = _log_all( |
|
| 891 |
- error_log, |
|
| 892 |
- 1, |
|
| 893 |
- function(){
|
|
| 894 |
- if (global_config == undefined) {
|
|
| 895 |
- return false; |
|
| 896 |
- } |
|
| 897 |
- if (global_config.report_error) {
|
|
| 898 |
- make_logger["send_log"](); |
|
| 899 |
- } |
|
| 900 |
- } |
|
| 901 |
- ); |
|
| 902 |
- } |
|
| 903 |
- */ |
|
| 904 |
- } |
|
| 905 |
- return make_logger; |
|
| 906 |
-})(); |
|
| 907 | 0 |