Age | Commit message (Collapse) | Author | Files | Lines | |
---|---|---|---|---|---|
2017-01-15 | Merge pull request #1573 | Riccardo Spagni | 1 | -2/+4 | |
dea53962 fix timeout in check_connection (Jaquee) | |||||
2017-01-15 | Merge pull request #1564 | Riccardo Spagni | 2 | -6/+52 | |
1d317981 Wallet API: add key image import/export functions (Jaquee) | |||||
2017-01-15 | Merge pull request #1560 | Riccardo Spagni | 2 | -1/+19 | |
46550c0b Wallet API: add rescanSpent() (Jaquee) | |||||
2017-01-14 | fix timeout in check_connection | Jaquee | 1 | -2/+4 | |
2017-01-14 | make struct/class declarations consistent (mismatched-tags warning) | Chris Vickio | 3 | -4/+2 | |
2017-01-13 | Wallet API: add key image import/export functions | Jaquee | 2 | -6/+52 | |
2017-01-13 | Wallet API: support integrated addresses in address book. | Jaquee | 1 | -12/+42 | |
2017-01-13 | Wallet API: add rescanSpent() | Jaquee | 2 | -1/+19 | |
2017-01-13 | Merge pull request #1559 | Riccardo Spagni | 4 | -5/+54 | |
db56a03f Wallet2 + API: Callbacks for unconfirmed transfers (Jaquee) | |||||
2017-01-13 | Merge pull request #1541 | Riccardo Spagni | 6 | -4/+440 | |
0d3918e1 Wallet api: Update trustedDaemon when daemon is changed (Jaquee) dbb838f4 GUI cold signing (Jaquee) afb85a02 Wallet API: functions for supporting/creating view only wallets (Jaquee) | |||||
2017-01-13 | Merge pull request #1526 | Riccardo Spagni | 2 | -5/+66 | |
5eed5b05 Wallet API: functions for supporting/creating view only wallets (Jaquee) | |||||
2017-01-12 | Wallet2 + API: Callbacks for unconfirmed transfers | Jaquee | 4 | -5/+54 | |
2017-01-10 | Wallet api: Update trustedDaemon when daemon is changed | Jaquee | 1 | -0/+6 | |
2017-01-10 | GUI cold signing | Jaquee | 6 | -4/+434 | |
fix conflict | |||||
2017-01-10 | Wallet API: functions for supporting/creating view only wallets | Jaquee | 2 | -5/+66 | |
2017-01-10 | Wallet API: functions for supporting/creating view only wallets | Jaquee | 2 | -5/+66 | |
2017-01-09 | wallet2_api: add solo mining API | moneromooo-monero | 2 | -1/+40 | |
2017-01-08 | Merge pull request #1542 | Riccardo Spagni | 2 | -0/+6 | |
60fe1b61 Add parse_uri to wallet2_api (MoroccanMalinois) | |||||
2017-01-08 | Merge pull request #1521 | Riccardo Spagni | 2 | -0/+24 | |
21c5af5a wallet2_api: add an address book payment id lookup API (moneromooo-monero) | |||||
2017-01-08 | Merge pull request #1509 | Riccardo Spagni | 1 | -4/+2 | |
29333c41 wallet api: prevent setting refresh height too high (Jaquee) | |||||
2017-01-08 | Merge pull request #1500 | Riccardo Spagni | 2 | -2/+35 | |
c0a0fcaf wallet2_api: some new APIs to access daemon state (moneromooo-monero) | |||||
2017-01-08 | Add parse_uri to wallet2_api | MoroccanMalinois | 2 | -0/+6 | |
2017-01-01 | wallet2_api: add an address book payment id lookup API | moneromooo-monero | 2 | -0/+24 | |
2016-12-27 | wallet api: prevent setting refresh height too high | Jaquee | 1 | -4/+2 | |
2016-12-25 | wallet2_api: some new APIs to access daemon state | moneromooo-monero | 2 | -2/+35 | |
2016-12-21 | make openalias also available for solo miner; introduce namespace ↵ | kenshi84 | 1 | -1/+2 | |
tools::dns_utils; support integrated address with dns lookup | |||||
2016-12-17 | wallet2_api: add an API to the OpenAlias resolver | moneromooo-monero | 2 | -0/+9 | |
2016-12-15 | Merge pull request #1455 | Riccardo Spagni | 2 | -2/+2 | |
4bb0bff2 AddressBook: use unsigned type for row ID's (anonimal) | |||||
2016-12-15 | Wallet API: Do not refresh while daemon is syncing | Jaquee | 2 | -22/+56 | |
+ fixed fast refresh when creating wallet offline + improved close wallet logic (make sure refresh thread is stopped) | |||||
2016-12-14 | AddressBook: use unsigned type for row ID's | anonimal | 2 | -2/+2 | |
Fixes build warnings and may also prevent future headaches. | |||||
2016-12-13 | Bitmonero namespace renamed Monero. Bitmonero namespace alias added so that ↵ | Randi Joseph | 13 | -14/+40 | |
third party uses of the wallet api can transition. | |||||
2016-12-12 | addressbook updates | Jaquee | 2 | -17/+23 | |
2016-12-12 | GUI address book | Jaquee | 5 | -4/+211 | |
2016-12-04 | Merge pull request #1398 | Riccardo Spagni | 1 | -1/+1 | |
f4772bae Fix a few minor typos (Pierre Boyer) | |||||
2016-12-04 | Merge pull request #1388 | Riccardo Spagni | 2 | -2/+71 | |
fcd178ef wallet_api: add a few daemon related getters (moneromooo-monero) | |||||
2016-12-04 | Merge pull request #1380 | Riccardo Spagni | 2 | -0/+6 | |
657a70e0 wallet: add a getter for the filename path (moneromooo-monero) | |||||
2016-12-04 | Fix a few minor typos | Pierre Boyer | 1 | -1/+1 | |
2016-11-29 | wallet_api: add a few daemon related getters | moneromooo-monero | 2 | -2/+71 | |
Blockchain height, version, Mining hash rate... | |||||
2016-11-26 | wallet: add a getter for the filename path | moneromooo-monero | 2 | -0/+6 | |
2016-11-26 | Improve daemon RPC version handling | moneromooo-monero | 1 | -3/+3 | |
Daemon RPC version is now composed of a major and minor number, so that incompatible changes bump the major version, while compatible changes can still bump the minor version without causing clients to unnecessarily complain. | |||||
2016-11-24 | Merge pull request #1372 | Riccardo Spagni | 1 | -1/+1 | |
17b6bd6 Fix DNS failures in offline mode preventing daemon startup (moneromooo-monero) | |||||
2016-11-24 | Merge pull request #1357 | Riccardo Spagni | 1 | -1/+2 | |
5fc36f9 wallet2_api: fix history leak on destruction (moneromooo-monero) | |||||
2016-11-23 | Fix DNS failures in offline mode preventing daemon startup | moneromooo-monero | 1 | -1/+1 | |
2016-11-18 | wallet2_api: fix history leak on destruction | moneromooo-monero | 1 | -1/+2 | |
2016-11-18 | wallet2_api: fix payment ids from integrated addresses being ignored | moneromooo-monero | 1 | -0/+11 | |
2016-11-13 | Wallet2: calculate approximate blockchain height on offline creation | Jacob Brydolf | 2 | -1/+5 | |
Wallet API: add approximateBlockChainHeight() | |||||
2016-11-11 | Merge pull request #1315 | Riccardo Spagni | 2 | -2/+13 | |
9150a16 Wallet API: use stored refresh height when rebuilding cache (Jacob Brydolf) | |||||
2016-11-09 | wallet2_api: support for sweeping all | moneromooo-monero | 2 | -10/+18 | |
2016-11-09 | Wallet API: use stored refresh height when rebuilding cache | Jacob Brydolf | 2 | -2/+13 | |
2016-11-09 | Merge pull request #1310 | Riccardo Spagni | 2 | -0/+93 | |
40a68e2 wallet2_api: add API for create_unmixable_sweep_transactions (moneromooo-monero) | |||||
2016-11-09 | Merge pull request #1309 | Riccardo Spagni | 2 | -0/+20 | |
c441a61 wallet2_api: API to sign and verify a message (moneromooo-monero) | |||||
2016-11-08 | wallet2_api: API to sign and verify a message | moneromooo-monero | 2 | -0/+20 | |
2016-11-09 | wallet_api: PendingTransaction::txCount - number of split transactions | Ilya Kitaev | 2 | -2/+8 | |
2016-11-08 | Merge pull request #1308 | Riccardo Spagni | 1 | -0/+6 | |
0c530de Wallet API: Pause refresh while creating transaction (Jacob Brydolf) | |||||
2016-11-08 | Merge pull request #1302 | Riccardo Spagni | 2 | -4/+10 | |
63fe6fd wallet2_api: allow connection to return "yes, but wrong version" (moneromooo-monero) | |||||
2016-11-08 | Merge pull request #1301 | Riccardo Spagni | 2 | -0/+21 | |
35da3cb Wallet API: added getTxKey() (Jacob Brydolf) | |||||
2016-11-08 | Wallet API: added getTxKey() | Jacob Brydolf | 2 | -0/+21 | |
2016-11-08 | Merge pull request #1300 | Riccardo Spagni | 1 | -1/+1 | |
eb19492 wallet2_api: do not copy the whole pending tx when iterating (moneromooo-monero) | |||||
2016-11-08 | Merge pull request #1298 | Riccardo Spagni | 4 | -0/+31 | |
97288a5 wallet2_api: add API for tx notes (moneromooo-monero) | |||||
2016-11-08 | Merge pull request #1297 | Riccardo Spagni | 2 | -0/+154 | |
af8a260 wallet_api: txkey checking functions for the GUI (moneromooo.monero) | |||||
2016-11-08 | wallet2_api: add API for create_unmixable_sweep_transactions | moneromooo-monero | 2 | -0/+93 | |
2016-11-08 | Wallet API: Pause refresh while creating transaction | Jacob Brydolf | 1 | -0/+6 | |
2016-11-07 | wallet2_api: allow connection to return "yes, but wrong version" | moneromooo-monero | 2 | -4/+10 | |
2016-11-06 | wallet2_api: do not copy the whole pending tx when iterating | moneromooo-monero | 1 | -1/+1 | |
2016-11-05 | wallet2_api: add API for tx notes | moneromooo-monero | 4 | -0/+31 | |
2016-11-05 | wallet_api: txkey checking functions for the GUI | moneromooo.monero | 2 | -0/+154 | |
2016-11-02 | wallet: fix bad amounts/fees again | moneromooo-monero | 1 | -1/+1 | |
m_amount_out was sometimes getting initialized with the sum of an transaction's outputs, and sometimes with the sum of outputs that were not change. This caused confusion and bugs. We now always set it to the sum of outputs. This reverts an earlier fix for bad amounts as this used the other semantics. The wallet data should be converted automatically in a percentage of cases that I'm hesitant to estimate. In any case, restoring from seed or keys or rebuilding the cache will get it right. | |||||
2016-10-30 | Wallet API: added walletExists logic | Jacob Brydolf | 1 | -1/+7 | |
2016-10-28 | Wallet API: make sure path exists before searching for wallets | Jacob Brydolf | 1 | -2/+5 | |
2016-10-23 | Merge pull request #1230 | Riccardo Spagni | 1 | -0/+20 | |
06b642d wallet_api: add address validation functions (moneromooo-monero) | |||||
2016-10-22 | Merge pull request #1229 | Riccardo Spagni | 1 | -2/+7 | |
b6b86ab wallet2_api: recognize full size payment ids as valid (moneromooo-monero) | |||||
2016-10-22 | Merge pull request #1228 | Riccardo Spagni | 1 | -1/+1 | |
2bf65df wallet_api: do not override invalid payment id (moneromooo-monero) | |||||
2016-10-22 | Merge pull request #1220 | Riccardo Spagni | 1 | -0/+9 | |
e76dcdd wallet: improve error messages when not enough money for transfer (moneromooo-monero) | |||||
2016-10-16 | wallet_api: add address validation functions | moneromooo-monero | 1 | -0/+20 | |
The payment id from integrated addresses is also parsed | |||||
2016-10-16 | wallet2_api: recognize full size payment ids as valid | moneromooo-monero | 1 | -2/+7 | |
2016-10-16 | wallet_api: do not override invalid payment id | moneromooo-monero | 1 | -1/+1 | |
Instead, return an empty string to mark the error | |||||
2016-10-15 | wallet: improve error messages when not enough money for transfer | moneromooo-monero | 1 | -0/+9 | |
2016-10-15 | wallet_api: fix wrong amount in tx history | moneromooo-monero | 1 | -1/+1 | |
2016-10-10 | Wallet API: added setRecoveringFromSeed(); | Jacob Brydolf | 2 | -0/+5 | |
2016-10-09 | Merge pull request #1195 | Riccardo Spagni | 4 | -19/+62 | |
697ce1d libwallet_api: reverted deleted curly brace (Ilya Kitaev) bb9094f libwallet_api: fixes for transaction history (Ilya Kitaev) 62b3708 libwallet_api: do not signal on sent/received tx until wallet completely synchronized (Ilya Kitaev) 11fab41 libwallet_api: TransactionHistory: read/write syncchronization (Ilya Kitaev) 559f379 libwallet_api: test: adjusted mixin_count=4 as it's minumum allowed (Ilya Kitaev) 8b0cb8c libwallet_api: some renamings (Ilya Kitaev) db3282c Initialize transaction history if empty (Ilya Kitaev) 85f5e73 libwallet_api: fixes for transaction history (Ilya Kitaev) | |||||
2016-10-08 | libwallet_api: Added option to restore from specific height | Jacob Brydolf | 4 | -2/+10 | |
2016-10-07 | libwallet_api: reverted deleted curly brace | Ilya Kitaev | 1 | -0/+1 | |
2016-10-07 | resolved conflict with 'develop' of https://github.com/mbg033/monero | Ilya Kitaev | 1 | -3/+0 | |
2016-10-07 | libwallet_api: do not signal on sent/received tx until wallet completely | Ilya Kitaev | 2 | -6/+25 | |
synchronized | |||||
2016-10-06 | libwallet_api: TransactionHistory: read/write syncchronization | Ilya Kitaev | 2 | -14/+21 | |
2016-10-06 | libwallet_api: some renamings | Ilya Kitaev | 3 | -3/+3 | |
2016-10-06 | Initialize transaction history if empty | Ilya Kitaev | 3 | -2/+11 | |
2016-10-06 | libwallet_api: fixes for transaction history | Ilya Kitaev | 1 | -3/+13 | |
2016-10-04 | libwallet_api: fixes for transaction history | Ilya Kitaev | 1 | -3/+13 | |
2016-10-04 | Merge pull request #1173 | Riccardo Spagni | 2 | -0/+18 | |
65ea836 wallet2_api: added Wallet::daemonBlockChainTargetHeight() libwallet_api: Wallet::blockChainTargetHeight (Jacob Brydolf) | |||||
2016-10-03 | wallet2_api: added Wallet::daemonBlockChainTargetHeight() | Jacob Brydolf | 2 | -0/+18 | |
libwallet_api: Wallet::blockChainTargetHeight Signed-off-by: Jacob Brydolf <jacob@brydolf.net> | |||||
2016-10-01 | libwallet_api: do not use fast-refresh on recovery | Ilya Kitaev | 2 | -3/+10 | |
2016-09-30 | libwallet_api: fast-refresh in case of opening non-synced wallet | Ilya Kitaev | 2 | -6/+5 | |
2016-09-30 | libwallet_api: fix unhandled exception on address check | Ilya Kitaev | 1 | -12/+16 | |
2016-09-30 | libwallet_api: fast-refresh for new wallet | Ilya Kitaev | 2 | -9/+28 | |
2016-09-28 | libwallet_api: Wallet::setAutoRefreshInterval sanity check | Ilya Kitaev | 1 | -1/+9 | |
2016-09-28 | libwallet_api: explicitly return 0 in Wallet::daemonBlockChainHeight() | Ilya Kitaev | 1 | -0/+2 | |
on error | |||||
2016-09-26 | wallet2_api: milliseconds resolution for auto-refresh interval | Ilya Kitaev | 2 | -10/+10 | |
2016-09-26 | wallet2_api: added Wallet::daemonBlockChainHeight() | Ilya Kitaev | 2 | -2/+18 | |
2016-09-26 | libwallet_api: Wallet::blockChainHeight, WalletListener::newBlock | Ilya Kitaev | 2 | -1/+10 | |
2016-09-20 | wallet2_api: getter and setter for "refresh interval" | Ilya Kitaev | 2 | -1/+24 | |
2016-09-20 | wallet2_api: fixed deadlock while closing wallet | Ilya Kitaev | 1 | -3/+7 | |
2016-09-18 | switch wallet API from std thread/mutex to boost | Riccardo Spagni | 2 | -11/+11 | |
2016-09-16 | wallet: change priority/fee to ArticMine's recommendation | moneromooo-monero | 1 | -2/+1 | |
We keep 1, 2, 3 multipliers till the fee decrase from 0.01/kB to 0.002/kB, where we start using 1, 20, 166 multipliers. This ensures the higher multiplier will compensate for the block reward penalty when pushing past 100% of the past median. The fee-multiplier wallet setting is now rename to priority, since it keeps its [0..3] range, but maps to different multiplier values. | |||||
2016-08-28 | wallet: do not store signatures in the wallet cache | moneromooo-monero | 1 | -3/+2 | |
Saves some substantial space. Also avoid calculating tx hashes we don't need. | |||||
2016-08-28 | wallet2_api: zero amounts are now allowed with rct | moneromooo-monero | 1 | -6/+0 | |
2016-08-28 | wallet2_api: update on_money_{received,spent} prototypes for rct changes | moneromooo-monero | 1 | -4/+2 | |
2016-08-23 | libwallet_api: Wallet::amountFromString fixed | Ilya Kitaev | 1 | -1/+1 | |
2016-08-23 | libwallet_api: helper method to return maximumAllowedAmount | Ilya Kitaev | 1 | -0/+5 | |
2016-08-22 | libwallet_api: do not store wallet on close if status is not ok | Ilya Kitaev | 1 | -3/+5 | |
2016-08-11 | Fake outs set is now decided by the wallet | moneromooo-monero | 1 | -2/+2 | |
This plugs a privacy leak from the wallet to the daemon, as the daemon could previously see what input is included as a transaction input, which the daemon hadn't previously supplied. Now, the wallet requests a particular set of outputs, including the real one. This can result in transactions that can't be accepted if the wallet happens to select too many outputs with non standard unlock times. The daemon could know this and select another output, but the wallet is blind to it. It's currently very unlikely since I don't think anything uses non default unlock times. The wallet requests more outputs than necessary so it can use spares if any of the returns outputs are still locked. If there are not enough spares to reach the desired mixin, the transaction will fail. | |||||
2016-07-23 | Merge pull request #915 | Riccardo Spagni | 3 | -21/+162 | |
d7597c5 refreshing wallet even if error happened (Ilya Kitaev) 6d32a3d wallet_api: async init, Wallet::connected status, log level (Ilya Kitaev) 193d251 libwallet_api cmake: conditionally creating libwallet_merged2 only for STATIC build (Ilya Kitaev) 10c06dd wallet_api: segfault on refresh fixed (Ilya Kitaev) 9d2cb4f WalletListener functionality (Ilya Kitaev) d27b883 hack to successfull linking for MSYS2 (Ilya Kitaev) 083380c Transaction fee multiplier aka priority integraged (Ilya Kitaev) 00ed12b Wallet::paymentIdValid (Ilya Kitaev) | |||||
2016-07-18 | refreshing wallet even if error happened | Ilya Kitaev | 2 | -6/+18 | |
2016-07-18 | wallet_api: async init, Wallet::connected status, log level | Ilya Kitaev | 3 | -14/+45 | |
2016-07-18 | libwallet_api cmake: conditionally creating libwallet_merged2 only for | Ilya Kitaev | 1 | -2/+1 | |
STATIC build | |||||
2016-07-18 | wallet_api: segfault on refresh fixed | Ilya Kitaev | 1 | -2/+2 | |
2016-07-18 | WalletListener functionality | Ilya Kitaev | 2 | -12/+98 | |
2016-07-18 | Transaction fee multiplier aka priority integraged | Ilya Kitaev | 2 | -3/+10 | |
2016-07-18 | Wallet::paymentIdValid | Ilya Kitaev | 1 | -0/+6 | |
2016-07-17 | wallet2_api: use uint64_t for amounts | moneromooo-monero | 1 | -2/+2 | |
2016-07-07 | wallet2_api: make this build (smatch needs .str() for /=) | moneromooo-monero | 1 | -1/+1 | |
2016-06-23 | Merge branch 'master' of https://github.com/mbg033/bitmonero | Ilya Kitaev | 1 | -5/+3 | |
2016-06-23 | WalletManager::findWallets: searching by "keys" files instead of | Ilya Kitaev | 1 | -5/+3 | |
"address.txt" files | |||||
2016-06-23 | Wallet: payment id and integrated address | Ilya Kitaev | 2 | -9/+53 | |
2016-06-23 | PendingTransactionImpl: pointer->reference | Ilya Kitaev | 2 | -4/+4 | |
2016-06-23 | commented regex | Ilya Kitaev | 1 | -1/+1 | |
2016-06-23 | Wallet::createTransaction: added mixin_count param | Ilya Kitaev | 2 | -8/+12 | |
2016-06-23 | double/string to monero integer convertion methods | Ilya Kitaev | 1 | -0/+17 | |
2016-06-23 | wallet::default_mixin exposed to public interface as | Ilya Kitaev | 2 | -1/+12 | |
Wallet::setDefaultMixin, Wallet::defaultMixin; wallet::create_transaction_2 used in Wallet::createTransaction | |||||
2016-06-23 | Wallet::filename, Wallet::keysFilename, tests for move wallet | Ilya Kitaev | 2 | -0/+12 | |
2016-06-23 | removed unused "using" | Ilya Kitaev | 1 | -1/+0 | |
2016-06-23 | Wallet API : WalletManager::findWallets() added | Ilya Kitaev | 2 | -0/+38 | |
2016-06-23 | WalletListener::moneySpent test | Ilya Kitaev | 1 | -0/+8 | |
2016-06-23 | WalletListener::moneySpent(), WalletListener::moneyReceived() | Ilya Kitaev | 1 | -2/+21 | |
2016-06-23 | started WalletListener | Ilya Kitaev | 2 | -1/+57 | |
2016-06-23 | TransactionHistory continued | Ilya Kitaev | 3 | -11/+92 | |
2016-06-23 | merged with upstream | Ilya Kitaev | 3 | -2/+99 | |
2016-06-23 | Wallet API : transaction history in progress | Ilya Kitaev | 6 | -19/+70 | |
2016-06-23 | transaction history api in progress | Ilya Kitaev | 6 | -14/+109 | |
2016-06-23 | api implementation splitted over separate files | Ilya Kitaev | 11 | -0/+1087 | |
2016-06-22 | PendingTransactionImpl: pointer->reference | Ilya Kitaev | 2 | -4/+4 | |
2016-06-22 | commented regex | Ilya Kitaev | 1 | -1/+1 | |
2016-06-20 | Wallet::createTransaction: added mixin_count param | Ilya Kitaev | 2 | -8/+12 | |
2016-06-16 | double/string to monero integer convertion methods | Ilya Kitaev | 1 | -0/+17 | |
2016-06-10 | wallet::default_mixin exposed to public interface as | Ilya Kitaev | 2 | -1/+12 | |
Wallet::setDefaultMixin, Wallet::defaultMixin; wallet::create_transaction_2 used in Wallet::createTransaction | |||||
2016-06-10 | Wallet::filename, Wallet::keysFilename, tests for move wallet | Ilya Kitaev | 2 | -0/+12 | |
2016-06-03 | removed unused "using" | Ilya Kitaev | 1 | -1/+0 | |
2016-06-03 | Wallet API : WalletManager::findWallets() added | Ilya Kitaev | 2 | -0/+38 | |
2016-05-16 | WalletListener::moneySpent test | Ilya Kitaev | 1 | -0/+8 | |
2016-05-13 | WalletListener::moneySpent(), WalletListener::moneyReceived() | Ilya Kitaev | 1 | -2/+21 | |
2016-05-05 | started WalletListener | Ilya Kitaev | 2 | -1/+57 | |
2016-04-29 | TransactionHistory continued | Ilya Kitaev | 3 | -11/+92 | |
2016-04-26 | merged with upstream | Ilya Kitaev | 3 | -2/+99 | |
2016-04-22 | Wallet API: transaction history in progress | Ilya Kitaev | 3 | -7/+14 | |
2016-04-22 | Wallet API : transaction history in progress | Ilya Kitaev | 6 | -12/+56 | |
2016-04-20 | transaction history api in progress | Ilya Kitaev | 2 | -0/+42 | |
2016-04-20 | transaction history api in progress | Ilya Kitaev | 5 | -14/+67 | |
2016-04-20 | api implementation splitted over separate files | Ilya Kitaev | 11 | -0/+1087 | |