This repository has been archived by the owner on Jun 10, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathStorage.js
84 lines (77 loc) · 2.42 KB
/
Storage.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/**
* The {@codelink Storage} is an unordered collection of named values of any
* type. Values in the storage are named using {@code string} keys. The storage
* can be therefore thought of as a {@code Map<string, *>}.
*
* @interface
*/
export default class Storage {
/**
* This method is used to finalize the initialization of the storage after
* the dependencies provided through the constructor have been prepared for
* use.
*
* This method must be invoked only once and it must be the first method
* invoked on this instance.
*
* @return {Storage} This storage.
*/
init() {}
/**
* Returns {@code true} if the entry identified by the specified key exists
* in this storage.
*
* @param {string} key The key identifying the storage entry.
* @return {boolean} {@code true} if the storage entry exists.
*/
has() {}
/**
* Retrieves the value of the entry identified by the specified . The
* method returns {@code undefined} if the entry does not exists.
*
* Entries set to the {@code undefined} value can be tested for existence
* using the {@codelink has} method.
*
* @param {string} key The key identifying the storage entry.
* @return {*} The value of the storage entry.
*/
get() {}
/**
* Sets the storage entry identified by the specified key to the provided
* value. The method creates the entry if it does not exist already.
*
* @param {string} key The key identifying the storage entry.
* @param {*} value The storage entry value.
* @return {Storage} This storage.
*/
set() {}
/**
* Deletes the entry identified by the specified key from this storage.
*
* @param {string} key The key identifying the storage entry.
* @return {Storage} This storage.
*/
delete() {}
/**
* Clears the storage of all entries.
*
* @return {Storage} This storage.
*/
clear() {}
/**
* Returns an iterator for traversing the keys in this storage. The order
* in which the keys are traversed is undefined.
*
* @return {Iterator<string>} An iterator for traversing the keys in this
* storage. The iterator also implements the iterable protocol,
* returning itself as its own iterator, allowing it to be used in
* a {@code for..of} loop.
*/
keys() {}
/**
* Returns the number of entries in this storage.
*
* @return {number} The number of entries in this storage.
*/
size() {}
}