Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
8baf7694
Commit
8baf7694
authored
Feb 12, 2016
by
Devon Carew
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update gitignore and analysis_options
parent
1cbd61d3
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
42 additions
and
51 deletions
+42
-51
create.dart
packages/flutter_tools/lib/src/commands/create.dart
+22
-7
ios.dart
packages/flutter_tools/lib/src/commands/ios.dart
+20
-44
No files found.
packages/flutter_tools/lib/src/commands/create.dart
View file @
8baf7694
...
@@ -13,6 +13,7 @@ import '../android/android.dart' as android;
...
@@ -13,6 +13,7 @@ import '../android/android.dart' as android;
import
'../artifacts.dart'
;
import
'../artifacts.dart'
;
import
'../base/globals.dart'
;
import
'../base/globals.dart'
;
import
'../base/process.dart'
;
import
'../base/process.dart'
;
import
'ios.dart'
;
class
CreateCommand
extends
Command
{
class
CreateCommand
extends
Command
{
final
String
name
=
'create'
;
final
String
name
=
'create'
;
...
@@ -108,7 +109,7 @@ abstract class Template {
...
@@ -108,7 +109,7 @@ abstract class Template {
final
String
name
;
final
String
name
;
final
String
description
;
final
String
description
;
Map
<
String
,
String
>
files
=
{};
Map
<
String
,
String
>
files
=
<
String
,
String
>
{};
Template
(
this
.
name
,
this
.
description
);
Template
(
this
.
name
,
this
.
description
);
...
@@ -119,9 +120,11 @@ abstract class Template {
...
@@ -119,9 +120,11 @@ abstract class Template {
dir
.
createSync
(
recursive:
true
);
dir
.
createSync
(
recursive:
true
);
String
relativeFlutterPackagePath
=
path
.
relative
(
flutterPackagePath
,
from:
dirPath
);
String
relativeFlutterPackagePath
=
path
.
relative
(
flutterPackagePath
,
from:
dirPath
);
Iterable
<
String
>
paths
=
files
.
keys
.
toList
()..
sort
();
files
.
forEach
((
String
filePath
,
String
contents
)
{
for
(
String
filePath
in
paths
)
{
Map
m
=
{
String
contents
=
files
[
filePath
];
Map
m
=
<
String
,
String
>{
'projectName'
:
projectName
,
'projectName'
:
projectName
,
'description'
:
description
,
'description'
:
description
,
'flutterPackagePath'
:
relativeFlutterPackagePath
'flutterPackagePath'
:
relativeFlutterPackagePath
...
@@ -129,10 +132,10 @@ abstract class Template {
...
@@ -129,10 +132,10 @@ abstract class Template {
contents
=
mustache
.
render
(
contents
,
m
);
contents
=
mustache
.
render
(
contents
,
m
);
filePath
=
filePath
.
replaceAll
(
'/'
,
Platform
.
pathSeparator
);
filePath
=
filePath
.
replaceAll
(
'/'
,
Platform
.
pathSeparator
);
File
file
=
new
File
(
path
.
join
(
dir
.
path
,
filePath
));
File
file
=
new
File
(
path
.
join
(
dir
.
path
,
filePath
));
file
.
parent
.
createSync
();
file
.
parent
.
createSync
(
recursive:
true
);
file
.
writeAsStringSync
(
contents
);
file
.
writeAsStringSync
(
contents
);
printStatus
(
'
${file.path}
'
);
printStatus
(
'
${file.path}
'
);
}
);
}
}
}
String
toString
()
=>
name
;
String
toString
()
=>
name
;
...
@@ -145,8 +148,15 @@ class FlutterSimpleTemplate extends Template {
...
@@ -145,8 +148,15 @@ class FlutterSimpleTemplate extends Template {
files
[
'flutter.yaml'
]
=
_flutterYaml
;
files
[
'flutter.yaml'
]
=
_flutterYaml
;
files
[
'pubspec.yaml'
]
=
_pubspec
;
files
[
'pubspec.yaml'
]
=
_pubspec
;
files
[
'README.md'
]
=
_readme
;
files
[
'README.md'
]
=
_readme
;
files
[
'android/AndroidManifest.xml'
]
=
_apkManifest
;
files
[
'lib/main.dart'
]
=
_libMain
;
files
[
'lib/main.dart'
]
=
_libMain
;
// Android files.
files
[
'android/AndroidManifest.xml'
]
=
_apkManifest
;
// Create a file here, so we create the directory for the user and it gets committed with git.
files
[
'android/res/README.md'
]
=
_androidResReadme
;
// iOS files.
files
.
addAll
(
iosTemplateFiles
);
}
}
}
}
...
@@ -161,7 +171,7 @@ String _normalizeProjectName(String name) {
...
@@ -161,7 +171,7 @@ String _normalizeProjectName(String name) {
const
String
_analysis_options
=
r''
'
const
String
_analysis_options
=
r''
'
analyzer:
analyzer:
exclude:
exclude:
- '
ios
/
buil
d
/**
'
- '
ios
/
.
generate
d
/**
'
'''
;
'''
;
const
String
_gitignore
=
r''
'
const
String
_gitignore
=
r''
'
...
@@ -171,6 +181,7 @@ const String _gitignore = r'''
...
@@ -171,6 +181,7 @@ const String _gitignore = r'''
.packages
.packages
.pub/
.pub/
build/
build/
ios/.generated/
packages
packages
pubspec.lock
pubspec.lock
'''
;
'''
;
...
@@ -273,3 +284,7 @@ final String _apkManifest = '''
...
@@ -273,3 +284,7 @@ final String _apkManifest = '''
</application>
</application>
</manifest>
</manifest>
'''
;
'''
;
final
String
_androidResReadme
=
'''
Place Android resources here (http://developer.android.com/guide/topics/resources/overview.html).
'''
;
packages/flutter_tools/lib/src/commands/ios.dart
View file @
8baf7694
...
@@ -13,6 +13,13 @@ import "../base/process.dart";
...
@@ -13,6 +13,13 @@ import "../base/process.dart";
import
"../runner/flutter_command.dart"
;
import
"../runner/flutter_command.dart"
;
import
"../runner/flutter_command_runner.dart"
;
import
"../runner/flutter_command_runner.dart"
;
/// A map from file path to file contents.
final
Map
<
String
,
String
>
iosTemplateFiles
=
<
String
,
String
>{
'ios/Info.plist'
:
_infoPlistInitialContents
,
'ios/LaunchScreen.storyboard'
:
_launchScreenInitialContents
,
'ios/Assets.xcassets/AppIcon.appiconset/Contents.json'
:
_iconAssetInitialContents
};
class
IOSCommand
extends
FlutterCommand
{
class
IOSCommand
extends
FlutterCommand
{
final
String
name
=
"ios"
;
final
String
name
=
"ios"
;
final
String
description
=
"Commands for creating and updating Flutter iOS projects."
;
final
String
description
=
"Commands for creating and updating Flutter iOS projects."
;
...
@@ -93,46 +100,23 @@ class IOSCommand extends FlutterCommand {
...
@@ -93,46 +100,23 @@ class IOSCommand extends FlutterCommand {
return
true
;
return
true
;
}
}
void
_writeUserEditableFilesIfNecessary
(
String
directory
)
{
void
_writeUserEditableFilesIfNecessary
(
String
directory
)
{
printStatus
(
"Checking if user editable files need updates"
);
iosTemplateFiles
.
forEach
((
String
filePath
,
String
contents
)
{
File
file
=
new
File
(
filePath
);
// Step 1: Check if the Info.plist exists and write one if not
File
infoPlist
=
new
File
(
path
.
join
(
directory
,
"Info.plist"
));
if
(!
infoPlist
.
existsSync
())
{
printStatus
(
"Did not find an existing Info.plist. Creating one."
);
infoPlist
.
writeAsStringSync
(
_infoPlistInitialContents
);
}
else
{
printStatus
(
"Info.plist present. Using existing."
);
}
// Step 2: Check if the LaunchScreen.storyboard exists and write one if not
if
(!
file
.
existsSync
())
{
File
launchScreen
=
new
File
(
path
.
join
(
directory
,
"LaunchScreen.storyboard"
));
file
.
parent
.
createSync
(
recursive:
true
);
if
(!
launchScreen
.
existsSync
())
{
file
.
writeAsStringSync
(
contents
);
printStatus
(
"Did not find an existing LaunchScreen.storyboard. Creating one."
);
printStatus
(
'Created
$filePath
.'
);
launchScreen
.
writeAsStringSync
(
_launchScreenInitialContents
);
}
else
{
printStatus
(
"LaunchScreen.storyboard present. Using existing."
);
}
// Step 3: Check if the Assets.xcassets exists and write one if not
Directory
xcassets
=
new
Directory
(
path
.
join
(
directory
,
"Assets.xcassets"
));
if
(!
xcassets
.
existsSync
())
{
printStatus
(
"Did not find an existing Assets.xcassets. Creating one."
);
Directory
iconsAssetsDir
=
new
Directory
(
path
.
join
(
xcassets
.
path
,
"AppIcon.appiconset"
));
iconsAssetsDir
.
createSync
(
recursive:
true
);
File
iconContents
=
new
File
(
path
.
join
(
iconsAssetsDir
.
path
,
"Contents.json"
));
iconContents
.
writeAsStringSync
(
_iconAssetInitialContents
);
}
else
{
printStatus
(
"Assets.xcassets present. Using existing."
);
}
}
});
}
}
void
_setupXcodeProjXcconfig
(
String
filePath
)
{
void
_setupXcodeProjXcconfig
(
String
filePath
)
{
StringBuffer
localsBuffer
=
new
StringBuffer
();
StringBuffer
localsBuffer
=
new
StringBuffer
();
localsBuffer
.
writeln
(
"// Generated. Do not edit or check into version control!"
);
localsBuffer
.
writeln
(
"// Generated. Do not edit or check into version control!"
);
localsBuffer
.
writeln
(
"// Recreate using `flutter ios`."
);
localsBuffer
.
writeln
(
"// Recreate using `flutter ios
--init
`."
);
String
flutterRoot
=
path
.
normalize
(
Platform
.
environment
[
kFlutterRootEnvironmentVariableName
]);
String
flutterRoot
=
path
.
normalize
(
Platform
.
environment
[
kFlutterRootEnvironmentVariableName
]);
localsBuffer
.
writeln
(
"FLUTTER_ROOT=
$flutterRoot
"
);
localsBuffer
.
writeln
(
"FLUTTER_ROOT=
$flutterRoot
"
);
...
@@ -167,27 +151,19 @@ class IOSCommand extends FlutterCommand {
...
@@ -167,27 +151,19 @@ class IOSCommand extends FlutterCommand {
return
1
;
return
1
;
}
}
// Step 3: The generated project should NOT be checked into the users
// Step 3: Setup default user editable files if this is the first run of
// version control system. Be nice and write a gitignore for them if
// one does not exist.
File
generatedGitignore
=
new
File
(
path
.
join
(
iosFilesPath
,
".gitignore"
));
if
(!
generatedGitignore
.
existsSync
())
{
generatedGitignore
.
writeAsStringSync
(
".generated/
\n
"
);
}
// Step 4: Setup default user editable files if this is the first run of
// the init command.
// the init command.
_writeUserEditableFilesIfNecessary
(
iosFilesPath
);
_writeUserEditableFilesIfNecessary
(
iosFilesPath
);
// Step
5
: Populate the Local.xcconfig with project specific paths
// Step
4
: Populate the Local.xcconfig with project specific paths
_setupXcodeProjXcconfig
(
path
.
join
(
xcodeprojPath
,
"Local.xcconfig"
));
_setupXcodeProjXcconfig
(
path
.
join
(
xcodeprojPath
,
"Local.xcconfig"
));
// Step
6
: Write the REVISION file
// Step
5
: Write the REVISION file
File
revisionFile
=
new
File
(
path
.
join
(
xcodeprojPath
,
"REVISION"
));
File
revisionFile
=
new
File
(
path
.
join
(
xcodeprojPath
,
"REVISION"
));
revisionFile
.
createSync
();
revisionFile
.
createSync
();
revisionFile
.
writeAsStringSync
(
ArtifactStore
.
engineRevision
);
revisionFile
.
writeAsStringSync
(
ArtifactStore
.
engineRevision
);
// Step
7
: Tell the user the location of the generated project.
// Step
6
: Tell the user the location of the generated project.
printStatus
(
"An Xcode project has been placed in 'ios/'."
);
printStatus
(
"An Xcode project has been placed in 'ios/'."
);
printStatus
(
"You may edit it to modify iOS specific configuration."
);
printStatus
(
"You may edit it to modify iOS specific configuration."
);
return
0
;
return
0
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment