dev-runner.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. 'use strict'
  2. const chalk = require('chalk')
  3. const electron = require('electron')
  4. const path = require('path')
  5. const { say } = require('cfonts')
  6. const { spawn } = require('child_process')
  7. const webpack = require('webpack')
  8. const WebpackDevServer = require('webpack-dev-server')
  9. const webpackHotMiddleware = require('webpack-hot-middleware')
  10. const mainConfig = require('./webpack.main.config')
  11. const rendererConfig = require('./webpack.renderer.config')
  12. let electronProcess = null
  13. let manualRestart = false
  14. let hotMiddleware
  15. function logStats (proc, data) {
  16. let log = ''
  17. log += chalk.yellow.bold(`┏ ${proc} Process ${new Array((19 - proc.length) + 1).join('-')}`)
  18. log += '\n\n'
  19. if (typeof data === 'object') {
  20. data.toString({
  21. colors: true,
  22. chunks: false
  23. }).split(/\r?\n/).forEach(line => {
  24. log += ' ' + line + '\n'
  25. })
  26. } else {
  27. log += ` ${data}\n`
  28. }
  29. log += '\n' + chalk.yellow.bold(`┗ ${new Array(28 + 1).join('-')}`) + '\n'
  30. console.log(log)
  31. }
  32. function startRenderer () {
  33. return new Promise((resolve, reject) => {
  34. rendererConfig.entry.renderer = [path.join(__dirname, 'dev-client')].concat(rendererConfig.entry.renderer)
  35. const compiler = webpack(rendererConfig)
  36. hotMiddleware = webpackHotMiddleware(compiler, {
  37. log: false,
  38. heartbeat: 2500
  39. })
  40. compiler.plugin('compilation', compilation => {
  41. compilation.plugin('html-webpack-plugin-after-emit', (data, cb) => {
  42. hotMiddleware.publish({ action: 'reload' })
  43. cb()
  44. })
  45. })
  46. compiler.plugin('done', stats => {
  47. logStats('Renderer', stats)
  48. })
  49. const server = new WebpackDevServer(
  50. compiler,
  51. {
  52. contentBase: path.join(__dirname, '../'),
  53. quiet: true,
  54. before (app, ctx) {
  55. app.use(hotMiddleware)
  56. ctx.middleware.waitUntilValid(() => {
  57. resolve()
  58. })
  59. }
  60. }
  61. )
  62. server.listen(9080)
  63. })
  64. }
  65. function startMain () {
  66. return new Promise((resolve, reject) => {
  67. mainConfig.entry.main = [path.join(__dirname, '../src/main/index.dev.js')].concat(mainConfig.entry.main)
  68. const compiler = webpack(mainConfig)
  69. compiler.plugin('watch-run', (compilation, done) => {
  70. logStats('Main', chalk.white.bold('compiling...'))
  71. hotMiddleware.publish({ action: 'compiling' })
  72. done()
  73. })
  74. compiler.watch({}, (err, stats) => {
  75. if (err) {
  76. console.log(err)
  77. return
  78. }
  79. logStats('Main', stats)
  80. if (electronProcess && electronProcess.kill) {
  81. manualRestart = true
  82. process.kill(electronProcess.pid)
  83. electronProcess = null
  84. startElectron()
  85. setTimeout(() => {
  86. manualRestart = false
  87. }, 5000)
  88. }
  89. resolve()
  90. })
  91. })
  92. }
  93. function startElectron () {
  94. electronProcess = spawn(electron, ['--inspect=5858', '.'])
  95. electronProcess.stdout.on('data', data => {
  96. electronLog(data, 'blue')
  97. })
  98. electronProcess.stderr.on('data', data => {
  99. electronLog(data, 'red')
  100. })
  101. electronProcess.on('close', () => {
  102. if (!manualRestart) process.exit()
  103. })
  104. }
  105. function electronLog (data, color) {
  106. let log = ''
  107. data = data.toString().split(/\r?\n/)
  108. data.forEach(line => {
  109. log += ` ${line}\n`
  110. })
  111. if (/[0-9A-z]+/.test(log)) {
  112. console.log(
  113. chalk[color].bold('┏ Electron -------------------') +
  114. '\n\n' +
  115. log +
  116. chalk[color].bold('┗ ----------------------------') +
  117. '\n'
  118. )
  119. }
  120. }
  121. function greeting () {
  122. const cols = process.stdout.columns
  123. let text = ''
  124. if (cols > 104) text = 'electron-vue'
  125. else if (cols > 76) text = 'electron-|vue'
  126. else text = false
  127. if (text) {
  128. say(text, {
  129. colors: ['yellow'],
  130. font: 'simple3d',
  131. space: false
  132. })
  133. } else console.log(chalk.yellow.bold('\n electron-vue'))
  134. console.log(chalk.blue(' getting ready...') + '\n')
  135. }
  136. function init () {
  137. greeting()
  138. Promise.all([startRenderer(), startMain()])
  139. .then(() => {
  140. startElectron()
  141. })
  142. .catch(err => {
  143. console.error(err)
  144. })
  145. }
  146. init()