Initial compile API and Fiddle container/pres components

This commit is contained in:
emizzle 2018-08-07 14:28:26 +10:00
parent b3917fcf97
commit d40d44a3df
7 changed files with 144 additions and 74 deletions

View File

@ -20,8 +20,6 @@ export const accounts = {
failure: (error) => action(ACCOUNTS[FAILURE], {error})
};
// Fiddle
export const FIDDLE_CODE_CHANGE = 'FIDDLE_CODE_CHANGE';
export const ACCOUNT = createRequestTypes('ACCOUNT');
export const account = {
request: (address) => action(ACCOUNT[REQUEST], {address}),
@ -145,8 +143,30 @@ export function listenToContractLogs() {
};
}
export function fiddleCodeChange(){
// Fiddle
export const FETCH_COMPILE_CODE = 'FETCH_COMPILE_CODE';
export const RECEIVE_COMPILE_CODE = 'RECEIVE_COMPILE_CODE';
export const RECEIVE_COMPILE_CODE_ERROR = 'RECEIVE_COMPILE_CODE_ERROR';
export function fetchCodeCompilation(codeToCompile){
return {
type: FIDDLE_CODE_CHANGE
type: FETCH_COMPILE_CODE,
codeToCompile
};
}
export function receiveCodeCompilation(compilationResult){
return {
type: RECEIVE_COMPILE_CODE,
compilationResult
};
}
export function receiveCodeCompilationError(){
return {
type: RECEIVE_COMPILE_CODE_ERROR
};
}

View File

@ -95,3 +95,7 @@ export function webSocketContractLogs() {
export function webSocketBlockHeader() {
return new WebSocket(`${constants.wsEndpoint}/blockchain/blockHeader`);
}
export function fetchCodeCompilation() {
return axios.post('http://localhost:8000/embark-api/contract/compile');
}

View File

@ -1,15 +1,11 @@
import React from 'react';
import AceEditor from 'react-ace';
import 'brace/mode/javascript';
import 'brace/theme/tomorrow_night_blue';
import 'ace-mode-solidity/build/remix-ide/mode-solidity';
const Fiddle = ({code, options, editorDidMount, onChange}) => {
options = options || {
selectOnLineNumbers: true
};
const Fiddle = ({onCodeChange}) => {
return (
<React.Fragment>
<h1>Fiddle</h1>
@ -20,10 +16,10 @@ const Fiddle = ({code, options, editorDidMount, onChange}) => {
name="blah1"
height="60em"
width="100%"
onChange={(e) => onCodeChange(e)}
/>
</React.Fragment>
);
};
export default Fiddle;

View File

@ -1,41 +1,35 @@
import React, {Component} from 'react';
import {connect} from 'react-redux';
import {fiddleCodeChange} from '../actions';
import {fetchCodeCompilation} from '../actions';
import Fiddle from '../components/Fiddle';
class FiddleContainer extends Component {
componentWillMount() {
//this.props.fetchAccounts();
}
render() {
// const { accounts } = this.props;
// if (!accounts.data) {
// return (
// <h1>
// <i>Loading accounts...</i>
// </h1>
// )
// }
// if (accounts.error) {
// return (
// <h1>
// <i>Error API...</i>
// </h1>
// )
// }
const options = {
selectOnLineNumbers: true,
roundedSelection: false,
readOnly: false,
cursorStyle: 'line',
automaticLayout: false,
};
render() {
const { compilationResult } = this.props;
const code = 'hello world';
return (
<Fiddle options={options} code={code} />
<React.Fragment>
<Fiddle code={code} onCodeChange={this.props.fetchCodeCompilation} />
<h2>Result</h2>
{
!compilationResult
?
'No compilation results yet'
:
compilationResult.error
?
<i>Error API...</i>
:
compilationResult
}
</React.Fragment>
);
}
}
@ -49,6 +43,6 @@ function mapStateToProps(state) {
export default connect(
mapStateToProps,
{
fiddleCodeChange
fetchCodeCompilation
},
)(FiddleContainer);

View File

@ -0,0 +1,12 @@
import {RECEIVE_COMPILE_CODE, RECEIVE_COMPILE_CODE_ERROR} from "../actions";
export default function processes(state = {}, action) {
switch (action.type) {
case RECEIVE_COMPILE_CODE:
return Object.assign({}, state, {data: action.compilationResult});
case RECEIVE_COMPILE_CODE_ERROR:
return Object.assign({}, state, {error: true});
default:
return state;
}
}

View File

@ -157,6 +157,19 @@ export function *watchCommunicationVersion() {
yield takeEvery(actions.MESSAGE_VERSION[actions.REQUEST], fetchCommunicationVersion);
}
export function* fetchCodeCompilation() {
try {
const codeCompilationResult = yield call(api.fetchCodeCompilation);
yield put(actions.receiveCodeCompilation(codeCompilationResult));
} catch (e) {
yield put(actions.receiveCodeCompilationError(e));
}
}
export function* watchFetchCodeCompilation() {
yield takeEvery(actions.FETCH_COMPILE_CODE, fetchCodeCompilation);
}
export default function *root() {
yield all([
fork(watchInitBlockHeader),
@ -177,7 +190,8 @@ export default function *root() {
fork(watchSendMessage),
fork(watchFetchContract),
fork(watchFetchTransaction),
fork(watchFetchContractProfile)
fork(watchFetchContractProfile),
fork(watchFetchCodeCompilation)
]);
}

View File

@ -13,43 +13,30 @@ class Solidity {
this.useDashboard = options.useDashboard;
embark.registerCompiler(".sol", this.compile_solidity.bind(this));
this.events.setCommandHandler("contract:compile", (contractCode, cb) => {
let input = [];
input['fiddler'] = {content: contractCode.replace(/\r\n/g, '\n')};
this.compile_solidity_code(input, cb);
});
embark.registerAPICall(
'post',
'/embark-api/contract/compile',
(req, res) => {
this.events.request("contract:compile", req.body.contractCode, (compilationResult) => {
res.send(JSON.stringify({compilationResult: compilationResult}));
});
}
);
}
compile_solidity(contractFiles, cb) {
if (!contractFiles.length) {
return cb();
}
let self = this;
let input = {};
let originalFilepath = {};
compile_solidity_code(codeInputs, originalFilepaths, cb){
const self = this;
async.waterfall([
function prepareInput(callback) {
async.each(contractFiles,
function(file, fileCb) {
let filename = file.filename;
for (let directory of self.contractDirectories) {
let match = new RegExp("^" + directory);
filename = filename.replace(match, '');
}
originalFilepath[filename] = file.filename;
file.content(function(fileContent) {
if (!fileContent) {
self.logger.error(__('Error while loading the content of ') + filename);
return fileCb();
}
input[filename] = {content: fileContent.replace(/\r\n/g, '\n')};
fileCb();
});
},
function (err) {
callback(err);
}
);
},
function loadCompiler(callback) {
if (self.solcAlreadyLoaded) {
return callback();
@ -66,7 +53,7 @@ class Solidity {
self.logger.info(__("compiling solidity contracts") + "...");
let jsonObj = {
language: 'Solidity',
sources: input,
sources: codeInputs,
settings: {
optimizer: {
enabled: true,
@ -126,7 +113,7 @@ class Solidity {
compiled_object[className].functionHashes = contract.evm.methodIdentifiers;
compiled_object[className].abiDefinition = contract.abi;
compiled_object[className].filename = filename;
compiled_object[className].originalFilename = originalFilepath[filename];
compiled_object[className].originalFilename = originalFilepaths[filename];
}
}
@ -137,6 +124,49 @@ class Solidity {
});
}
compile_solidity(contractFiles, cb) {
if (!contractFiles.length) {
return cb();
}
let self = this;
let input = {};
let originalFilepath = {};
async.waterfall([
function prepareInput(callback) {
async.each(contractFiles,
function(file, fileCb) {
let filename = file.filename;
for (let directory of self.contractDirectories) {
let match = new RegExp("^" + directory);
filename = filename.replace(match, '');
}
originalFilepath[filename] = file.filename;
file.content(function(fileContent) {
if (!fileContent) {
self.logger.error(__('Error while loading the content of ') + filename);
return fileCb();
}
input[filename] = {content: fileContent.replace(/\r\n/g, '\n')};
fileCb();
});
},
function (err) {
callback(err);
}
);
},
function compile(callback) {
self.compile_solidity_code(input, originalFilepath, callback);
}
], function (err, result) {
cb(err, result);
});
}
}
module.exports = Solidity;