Commit 0e7e1e5f authored by ioedeveloper's avatar ioedeveloper

Added error code and handlers

parent 56a09c94
...@@ -23,7 +23,7 @@ const profile = { ...@@ -23,7 +23,7 @@ const profile = {
icon: '', icon: '',
permission: true, permission: true,
version: packageJson.version, version: packageJson.version,
methods: ['getCurrentFile', 'getFile', 'setFile', 'switchFile', 'file', 'exists', 'open', 'writeFile', 'readFile', 'copyFile', 'unlink', 'rename', 'readdir', 'rmdir'], methods: ['setFile', 'switchFile', 'file', 'exists', 'open', 'writeFile', 'readFile', 'copyFile', 'unlink', 'rename', 'readdir', 'rmdir'],
kind: 'file-system' kind: 'file-system'
} }
...@@ -60,7 +60,7 @@ class FileManager extends Plugin { ...@@ -60,7 +60,7 @@ class FileManager extends Plugin {
*/ */
_handleIsFile (path, message) { _handleIsFile (path, message) {
if (!this.isFile(path)) { if (!this.isFile(path)) {
this._handleError({ message: `Path ${path} is not a file: ${message}.` }) this._handleError({ code: 'EISDIR', message })
} }
} }
...@@ -71,7 +71,7 @@ class FileManager extends Plugin { ...@@ -71,7 +71,7 @@ class FileManager extends Plugin {
*/ */
_handleIsDir (path, message) { _handleIsDir (path, message) {
if (this.isFile(path)) { if (this.isFile(path)) {
throw new Error(`Path ${path} is not a directory: ${message}.`) throw new Error({ code: 'ENOTDIR', message })
} }
} }
...@@ -80,24 +80,26 @@ class FileManager extends Plugin { ...@@ -80,24 +80,26 @@ class FileManager extends Plugin {
* @param {object} error error { code, message } * @param {object} error error { code, message }
*/ */
_handleError (error) { _handleError (error) {
if (error.message) { const message = error.message ? `: ${error.message}` : ''
throw new Error(message)
}
if (error.code === 'ENOENT') { if (error.code === 'ENOENT') {
throw new Error('No such file or directory') throw new Error('No such file or directory' + message)
} }
if (error.code === 'EISDIR') { if (error.code === 'EISDIR') {
throw new Error('Invalid operation on a directory') throw new Error('Path is a directory' + message)
}
if (error.code === 'ENOTDIR') {
throw new Error('Path is not on a directory' + message)
} }
if (error.code === 'EEXIST') { if (error.code === 'EEXIST') {
throw new Error('File already exists') throw new Error('File already exists' + message)
} }
if (error.code === 'EPERM' || error.code === 'EACCESS') { if (error.code === 'EPERM' || error.code === 'EACCESS') {
throw new Error('Permission denied') throw new Error('Permission denied' + message)
} }
return error return error
...@@ -105,7 +107,10 @@ class FileManager extends Plugin { ...@@ -105,7 +107,10 @@ class FileManager extends Plugin {
/** The current opened file */ /** The current opened file */
file () { file () {
return this.currentFile() const file = this.currentFile()
if (!file) this._handleError({ code: 'ENOENT', message: 'No file selected' })
return file
} }
/** /**
...@@ -125,7 +130,9 @@ class FileManager extends Plugin { ...@@ -125,7 +130,9 @@ class FileManager extends Plugin {
*/ */
isFile (path) { isFile (path) {
const extension = path.split('.').pop() const extension = path.split('.').pop()
return !!extension && extension.split('/').length === 0 const splitExtension = extension.split('/')
return !!extension && splitExtension.length === 1 && splitExtension[0] === extension
} }
/** /**
...@@ -134,8 +141,8 @@ class FileManager extends Plugin { ...@@ -134,8 +141,8 @@ class FileManager extends Plugin {
* @returns {void} * @returns {void}
*/ */
open (path) { open (path) {
this._handleExists(path, 'Cannot open file') this._handleExists(path, `Cannot open file ${path}`)
this._handleIsFile(path, 'Cannot open file') this._handleIsFile(path, `Cannot open file ${path}`)
this.switchFile(path) this.switchFile(path)
} }
...@@ -146,7 +153,7 @@ class FileManager extends Plugin { ...@@ -146,7 +153,7 @@ class FileManager extends Plugin {
* @returns {void} * @returns {void}
*/ */
writeFile (path, data) { writeFile (path, data) {
this._handleIsFile(path, 'Cannot write file') this._handleIsFile(path, `Cannot write file ${path}`)
this.setFile(path, data) this.setFile(path, data)
} }
...@@ -156,8 +163,8 @@ class FileManager extends Plugin { ...@@ -156,8 +163,8 @@ class FileManager extends Plugin {
* @returns {string} content of the file * @returns {string} content of the file
*/ */
readFile (path) { readFile (path) {
this._handleExists(path, 'Cannot read file') this._handleExists(path, `Cannot read file ${path}`)
this._handleIsFile(path, 'Cannot read file') this._handleIsFile(path, `Cannot read file ${path}`)
this.getFile(path) this.getFile(path)
} }
...@@ -168,9 +175,9 @@ class FileManager extends Plugin { ...@@ -168,9 +175,9 @@ class FileManager extends Plugin {
* @returns {void} * @returns {void}
*/ */
copyFile (src, dest) { copyFile (src, dest) {
this._handleExists(src, 'Cannot copy from it') this._handleExists(src, `Cannot copy from ${src}`)
this._handleIsFile(src, 'Cannot copy from it') this._handleIsFile(src, `Cannot copy from ${src}`)
this._handleIsFile(dest, 'Cannot paste content into it') this._handleIsFile(dest, `Cannot paste content into ${dest}`)
const content = this.readFile(src) const content = this.readFile(src)
this.writeFile(dest, content) this.writeFile(dest, content)
} }
...@@ -182,8 +189,8 @@ class FileManager extends Plugin { ...@@ -182,8 +189,8 @@ class FileManager extends Plugin {
* @returns {void} * @returns {void}
*/ */
unlink(path) { unlink(path) {
this._handleExists(path, 'Cannot remove file') this._handleExists(path, `Cannot remove file ${path}`)
this._handleIsDir(path, 'Cannot remove file') this._handleIsDir(path, `Cannot remove file ${path}`)
} }
/** /**
...@@ -193,7 +200,7 @@ class FileManager extends Plugin { ...@@ -193,7 +200,7 @@ class FileManager extends Plugin {
* @returns {void} * @returns {void}
*/ */
rename (oldPath, newPath) { rename (oldPath, newPath) {
this.__handleExists(oldPath, 'Cannot rename') this.__handleExists(oldPath, `Cannot rename ${oldPath}`)
// todo: should we verify if newPath exists here ? // todo: should we verify if newPath exists here ?
const isFile = this.isFile(oldPath) const isFile = this.isFile(oldPath)
this.fileRenamedEvent(oldPath, newPath, !isFile) this.fileRenamedEvent(oldPath, newPath, !isFile)
...@@ -206,7 +213,7 @@ class FileManager extends Plugin { ...@@ -206,7 +213,7 @@ class FileManager extends Plugin {
*/ */
mkdir (path) { mkdir (path) {
if (this.exists(path)) { if (this.exists(path)) {
throw new Error(`Path ${path} already exists: Cannot create a directory`) this._handleError({ code: 'EEXIST', message: `Cannot create directory ${path}` })
} }
// To implement // To implement
} }
...@@ -237,8 +244,8 @@ class FileManager extends Plugin { ...@@ -237,8 +244,8 @@ class FileManager extends Plugin {
* @returns {void} * @returns {void}
*/ */
rmdir(path) { rmdir(path) {
this._handleExists(path, 'Cannot remove directory') this._handleExists(path, `Cannot remove directory ${path}`)
this._handleIsDir(path, 'Cannot remove directory') this._handleIsDir(path, `Cannot remove directory ${path}`)
// To implement // To implement
} }
...@@ -329,15 +336,10 @@ class FileManager extends Plugin { ...@@ -329,15 +336,10 @@ class FileManager extends Plugin {
return path ? path[1] : null return path ? path[1] : null
} }
getCurrentFile () {
const path = this.currentFile()
if (!path) throw new Error('No file selected')
return path
}
getFile (path) { getFile (path) {
const provider = this.fileProviderOf(path) const provider = this.fileProviderOf(path)
if (!provider) throw new Error(`${path} not available`)
if (!provider) this._handleError({ code: 'ENOENT', message: `${path} not available` })
// TODO: change provider to Promise // TODO: change provider to Promise
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
if (this.currentFile() === path) return resolve(this.editor.currentContent()) if (this.currentFile() === path) return resolve(this.editor.currentContent())
...@@ -372,7 +374,7 @@ class FileManager extends Plugin { ...@@ -372,7 +374,7 @@ class FileManager extends Plugin {
_setFileInternal (path, content) { _setFileInternal (path, content) {
const provider = this.fileProviderOf(path) const provider = this.fileProviderOf(path)
if (!provider) throw new Error(`${path} not availble`) if (!provider) this._handleError({ code: 'ENOENT', message: `${path} not available` })
// TODO : Add permission // TODO : Add permission
// TODO : Change Provider to Promise // TODO : Change Provider to Promise
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
...@@ -389,7 +391,6 @@ class FileManager extends Plugin { ...@@ -389,7 +391,6 @@ class FileManager extends Plugin {
if (fileProvider) { if (fileProvider) {
helper.createNonClashingNameWithPrefix(path, fileProvider, '', (error, copyName) => { helper.createNonClashingNameWithPrefix(path, fileProvider, '', (error, copyName) => {
if (error) { if (error) {
console.log('createNonClashingNameWithPrefix', error)
copyName = path + '.' + this.currentRequest.from copyName = path + '.' + this.currentRequest.from
} }
this._setFileInternal(copyName, content) this._setFileInternal(copyName, content)
......
...@@ -141,7 +141,7 @@ class CompilerContainer { ...@@ -141,7 +141,7 @@ class CompilerContainer {
// Load solc compiler version according to pragma in contract file // Load solc compiler version according to pragma in contract file
_setCompilerVersionFromPragma (filename) { _setCompilerVersionFromPragma (filename) {
if (!this.data.allversions) return if (!this.data.allversions) return
this.compileTabLogic.fileManager.getFile(filename).then(data => { this.compileTabLogic.fileManager.readFile(filename).then(data => {
const pragmaArr = data.match(/(pragma solidity (.+?);)/g) const pragmaArr = data.match(/(pragma solidity (.+?);)/g)
if (pragmaArr && pragmaArr.length === 1) { if (pragmaArr && pragmaArr.length === 1) {
const pragmaStr = pragmaArr[0].replace('pragma solidity', '').trim() const pragmaStr = pragmaArr[0].replace('pragma solidity', '').trim()
......
...@@ -289,7 +289,7 @@ module.exports = class TestTab extends ViewPlugin { ...@@ -289,7 +289,7 @@ module.exports = class TestTab extends ViewPlugin {
} }
async testFromPath (path) { async testFromPath (path) {
const fileContent = await this.fileManager.getFile(path) const fileContent = await this.fileManager.readFile(path)
return this.testFromSource(fileContent, path) return this.testFromSource(fileContent, path)
} }
...@@ -323,7 +323,7 @@ module.exports = class TestTab extends ViewPlugin { ...@@ -323,7 +323,7 @@ module.exports = class TestTab extends ViewPlugin {
return return
} }
this.resultStatistics.hidden = false this.resultStatistics.hidden = false
this.fileManager.getFile(testFilePath).then((content) => { this.fileManager.readFile(testFilePath).then((content) => {
const runningTest = {} const runningTest = {}
runningTest[testFilePath] = { content } runningTest[testFilePath] = { content }
const {currentVersion, evmVersion, optimize} = this.compileTab.getCurrentCompilerConfig() const {currentVersion, evmVersion, optimize} = this.compileTab.getCurrentCompilerConfig()
......
...@@ -34,6 +34,7 @@ class Toaster { ...@@ -34,6 +34,7 @@ class Toaster {
} }
render (tooltipText, actionElement, opts) { render (tooltipText, actionElement, opts) {
console.log('tooltipText: ', tooltipText)
opts = defaultOptions(opts) opts = defaultOptions(opts)
let canShorten = true let canShorten = true
if (tooltipText instanceof Element) { if (tooltipText instanceof Element) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment