2015-08-21 23:45:42 -04:00
|
|
|
fs = require 'fs'
|
|
|
|
crypto = require 'crypto'
|
|
|
|
{execSync} = require 'child_process'
|
|
|
|
|
|
|
|
resources = __dirname + '/resources/'
|
|
|
|
binPath = __dirname + '/node_modules/.bin/'
|
|
|
|
camelRx = /([a-z])([A-Z])/g
|
|
|
|
projNameRx = /\$PROJECT_NAME\$/g
|
|
|
|
projNameHyphRx = /\$PROJECT_NAME_HYPHENATED\$/g
|
|
|
|
projNameUnderRx = /\$PROJECT_NAME_UNDERSCORED\$/g
|
|
|
|
|
|
|
|
log = (s) ->
|
|
|
|
console.log "\x1b[32m#{ s }...\x1b[0m"
|
|
|
|
|
|
|
|
|
|
|
|
logErr = (err) ->
|
|
|
|
console.error "\x1b[31m#{ err }\x1b[0m"
|
|
|
|
|
|
|
|
|
|
|
|
editSync = (path, pairs) ->
|
|
|
|
fs.writeFileSync path, pairs.reduce (contents, [rx, replacement]) ->
|
|
|
|
contents.replace rx, replacement
|
|
|
|
, fs.readFileSync path, encoding: 'ascii'
|
|
|
|
|
|
|
|
|
|
|
|
init = (projName) ->
|
2015-08-21 23:46:38 -04:00
|
|
|
projNameHyph = projName.replace(camelRx, '$1-$2').toLowerCase()
|
|
|
|
projNameUs = projName.replace(camelRx, '$1_$2').toLowerCase()
|
|
|
|
|
|
|
|
try
|
2015-08-22 13:45:37 -04:00
|
|
|
if fs.existsSync projNameHyph
|
|
|
|
throw new Error "Directory #{ projNameHyph } already exists"
|
|
|
|
|
2015-08-21 23:46:38 -04:00
|
|
|
execSync 'type lein'
|
|
|
|
execSync 'type pod'
|
|
|
|
|
2015-08-22 11:06:30 -04:00
|
|
|
log 'Creating Leiningen project'
|
|
|
|
execSync "lein new #{ projNameHyph }"
|
|
|
|
|
|
|
|
log 'Updating Leiningen project'
|
|
|
|
process.chdir projNameHyph
|
|
|
|
execSync "cp #{ resources }project.clj project.clj"
|
|
|
|
editSync 'project.clj', [[projNameHyphRx, projNameHyph]]
|
|
|
|
corePath = "src/#{ projNameUs }/core.clj"
|
|
|
|
fs.unlinkSync corePath
|
|
|
|
corePath += 's'
|
|
|
|
execSync "cp #{ resources }core.cljs #{ corePath }"
|
|
|
|
editSync corePath, [[projNameHyphRx, projNameHyph], [projNameRx, projName]]
|
2015-08-22 11:07:06 -04:00
|
|
|
execSync "cp #{ resources }ambly.sh start.sh"
|
|
|
|
editSync 'start.sh', [[projNameUnderRx, projNameUs]]
|
2015-08-21 23:46:38 -04:00
|
|
|
|
2015-08-22 13:30:12 -04:00
|
|
|
log 'Compiling ClojureScript'
|
|
|
|
execSync 'lein cljsbuild once dev'
|
|
|
|
|
2015-08-22 13:30:42 -04:00
|
|
|
log 'Creating React Native skeleton'
|
|
|
|
execSync "#{ binPath }react-native init #{ projName }"
|
|
|
|
execSync "mv #{ projName } iOS"
|
|
|
|
|
2015-08-22 13:32:06 -04:00
|
|
|
log 'Installing Pod dependencies'
|
|
|
|
process.chdir 'iOS'
|
|
|
|
execSync "cp #{ resources }Podfile ."
|
|
|
|
execSync 'pod install'
|
|
|
|
|
2015-08-22 13:32:53 -04:00
|
|
|
log 'Updating Xcode project'
|
|
|
|
for ext in ['m', 'h']
|
|
|
|
path = "./iOS/AppDelegate.#{ ext }"
|
|
|
|
execSync "cp #{ resources }AppDelegate.#{ ext } #{ path }"
|
|
|
|
editSync path, [[projNameRx, projName], [projNameHyphRx, projNameHyph]]
|
|
|
|
|
|
|
|
uuid1 = crypto
|
|
|
|
.createHash 'md5'
|
|
|
|
.update projName, 'utf8'
|
|
|
|
.digest('hex')[...24]
|
|
|
|
.toUpperCase()
|
|
|
|
|
|
|
|
uuid2 = uuid1
|
|
|
|
.split ''
|
|
|
|
.splice 7, 1, ((parseInt(uuid1[7], 16) + 1) % 16).toString(16).toUpperCase()
|
|
|
|
.join ''
|
|
|
|
|
|
|
|
editSync \
|
|
|
|
"#{ projName }.xcodeproj/project.pbxproj",
|
|
|
|
[
|
|
|
|
[
|
|
|
|
/OTHER_LDFLAGS = "-ObjC";/g
|
|
|
|
'OTHER_LDFLAGS = "${inherited}";'
|
|
|
|
]
|
|
|
|
[
|
|
|
|
/\/\* End PBXBuildFile section \*\//
|
|
|
|
"\t\t#{ uuid2 } /* out in Resources */ =
|
|
|
|
{isa = PBXBuildFile; fileRef = #{ uuid1 } /* out */; };
|
|
|
|
\n/* End PBXBuildFile section */"
|
|
|
|
]
|
|
|
|
[
|
|
|
|
/\/\* End PBXFileReference section \*\//
|
|
|
|
"\t\t#{ uuid1 } /* out */ = {isa = PBXFileReference; lastKnownFileType
|
|
|
|
= folder; name = out; path = ../target/out;
|
|
|
|
sourceTree = \"<group>\"; };\n/* End PBXFileReference section */"
|
|
|
|
]
|
|
|
|
[
|
|
|
|
/main.jsbundle \*\/\,/
|
|
|
|
"main.jsbundle */,\n\t\t\t\t#{ uuid1 } /* out */,"
|
|
|
|
]
|
|
|
|
[
|
|
|
|
/\/\* LaunchScreen.xib in Resources \*\/\,/
|
|
|
|
"/* LaunchScreen.xib in Resources */,
|
|
|
|
\n\t\t\t\t#{ uuid2 } /* out in Resources */,"
|
|
|
|
]
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2015-08-21 23:46:38 -04:00
|
|
|
catch e
|
|
|
|
logErr e.message
|
|
|
|
|
|
|
|
process.exit 1
|