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
1e5eb74c
Commit
1e5eb74c
authored
Mar 04, 2016
by
Ian Hickson
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2415 from Hixie/random-changes
Random fixes to dartdocs, http lib, analyzer
parents
3cb49849
047276a6
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
185 additions
and
83 deletions
+185
-83
http.dart
packages/flutter/lib/http.dart
+5
-4
http.dart
packages/flutter/lib/src/http/http.dart
+75
-50
mojo_client.dart
packages/flutter/lib/src/http/mojo_client.dart
+90
-24
shadows.dart
packages/flutter/lib/src/material/shadows.dart
+11
-2
debug.dart
packages/flutter/lib/src/rendering/debug.dart
+1
-1
ticker.dart
packages/flutter/lib/src/scheduler/ticker.dart
+2
-1
analyze.dart
packages/flutter_tools/lib/src/commands/analyze.dart
+1
-1
No files found.
packages/flutter/lib/http.dart
View file @
1e5eb74c
...
@@ -2,14 +2,15 @@
...
@@ -2,14 +2,15 @@
// Use of this source code is governed by a BSD-style license that can be
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// found in the LICENSE file.
/// Service exposed to Flutter apps that implements a subset of Dart's
/// A [Future]-based library for making HTTP requests.
/// http package API.
///
///
/// This library will probably be moved into a separate package eventually.
/// This library is based on Dart's `http` package, but differs in that it is a
/// `mojo`-based HTTP client and does not have a dependency on mirrors.
///
///
/// This library depends only on core Dart libraries as well as the `mojo`,
/// This library depends only on core Dart libraries as well as the `mojo`,
/// `mojo_services`, and `sky_services`
and
packages.
/// `mojo_services`, and `sky_services` packages.
library
http
;
library
http
;
export
'src/http/http.dart'
;
export
'src/http/http.dart'
;
export
'src/http/mojo_client.dart'
;
export
'src/http/response.dart'
;
export
'src/http/response.dart'
;
packages/flutter/lib/src/http/http.dart
View file @
1e5eb74c
...
@@ -2,12 +2,6 @@
...
@@ -2,12 +2,6 @@
// for details. All rights reserved. Use of this source code is governed by a
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
// BSD-style license that can be found in the LICENSE file.
/// A [Future]-based library for making HTTP requests.
///
/// This library is based on Dart's `http` package, but we have removed the
/// dependency on mirrors and added a `mojo`-based HTTP client.
library
http
;
import
'dart:async'
;
import
'dart:async'
;
import
'dart:convert'
;
import
'dart:convert'
;
import
'dart:typed_data'
;
import
'dart:typed_data'
;
...
@@ -18,28 +12,48 @@ import 'response.dart';
...
@@ -18,28 +12,48 @@ import 'response.dart';
/// Sends an HTTP HEAD request with the given headers to the given URL, which
/// Sends an HTTP HEAD request with the given headers to the given URL, which
/// can be a [Uri] or a [String].
/// can be a [Uri] or a [String].
///
///
/// This automatically initializes a new [Client] and closes that client once
/// This automatically initializes a new [
Mojo
Client] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [Client] for all of those requests.
/// the same server, you should use a single [MojoClient] for all of those requests.
Future
<
Response
>
head
(
url
)
=>
Future
<
Response
>
head
(
dynamic
url
)
{
_withClient
((
client
)
=>
client
.
head
(
url
));
return
_withClient
/*<Response>*/
((
MojoClient
client
)
=>
client
.
head
(
url
));
}
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// be a [Uri] or a [String].
/// be a [Uri] or a [String].
///
///
/// This automatically initializes a new [Client] and closes that client once
/// This automatically initializes a new [
Mojo
Client] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [Client] for all of those requests.
/// the same server, you should use a single [MojoClient] for all of those requests.
Future
<
Response
>
get
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
Future
<
Response
>
get
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
_withClient
((
client
)
=>
client
.
get
(
url
,
headers:
headers
));
return
_withClient
/*<Response>*/
((
MojoClient
client
)
=>
client
.
get
(
url
,
headers:
headers
));
}
/// Sends an HTTP POST request with the given headers and body to the given URL,
/// Sends an HTTP POST request with the given headers and body to the given URL,
/// which can be a [Uri] or a [String].
/// which can be a [Uri] or a [String].
///
///
/// [body] sets the body of the request.
/// [body] sets the body of the request. It can be a [String], a [List<int>] or
Future
<
Response
>
post
(
url
,
{
Map
<
String
,
String
>
headers
,
body
})
=>
/// a [Map<String, String>]. If it's a String, it's encoded using [encoding] and
_withClient
((
client
)
=>
client
.
post
(
url
,
/// used as the body of the request. The content-type of the request will
headers:
headers
,
body:
body
));
/// default to "text/plain".
///
/// If [body] is a List, it's used as a list of bytes for the body of the
/// request.
///
/// If [body] is a Map, it's encoded as form fields using [encoding]. The
/// content-type of the request will be set to
/// `"application/x-www-form-urlencoded"`; this cannot be overridden.
///
/// [encoding] defaults to [UTF8].
///
/// This automatically initializes a new [MojoClient] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [MojoClient] for all of those requests.
Future
<
Response
>
post
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
,
dynamic
body
,
Encoding
encoding:
UTF8
})
{
return
_withClient
/*<Response>*/
((
MojoClient
client
)
{
return
client
.
post
(
url
,
headers:
headers
,
body:
body
,
encoding:
encoding
);
});
}
/// Sends an HTTP PUT request with the given headers and body to the given URL,
/// Sends an HTTP PUT request with the given headers and body to the given URL,
/// which can be a [Uri] or a [String].
/// which can be a [Uri] or a [String].
...
@@ -48,9 +62,24 @@ Future<Response> post(url, {Map<String, String> headers, body}) =>
...
@@ -48,9 +62,24 @@ Future<Response> post(url, {Map<String, String> headers, body}) =>
/// a [Map<String, String>]. If it's a String, it's encoded using [encoding] and
/// a [Map<String, String>]. If it's a String, it's encoded using [encoding] and
/// used as the body of the request. The content-type of the request will
/// used as the body of the request. The content-type of the request will
/// default to "text/plain".
/// default to "text/plain".
Future
<
Response
>
put
(
url
,
{
Map
<
String
,
String
>
headers
,
body
})
=>
///
_withClient
((
client
)
=>
client
.
put
(
url
,
/// If [body] is a List, it's used as a list of bytes for the body of the
headers:
headers
,
body:
body
));
/// request.
///
/// If [body] is a Map, it's encoded as form fields using [encoding]. The
/// content-type of the request will be set to
/// `"application/x-www-form-urlencoded"`; this cannot be overridden.
///
/// [encoding] defaults to [UTF8].
///
/// This automatically initializes a new [MojoClient] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [MojoClient] for all of those requests.
Future
<
Response
>
put
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
,
dynamic
body
,
Encoding
encoding:
UTF8
})
{
return
_withClient
/*<Response>*/
((
MojoClient
client
)
{
return
client
.
put
(
url
,
headers:
headers
,
body:
body
,
encoding:
encoding
);
});
}
/// Sends an HTTP PATCH request with the given headers and body to the given
/// Sends an HTTP PATCH request with the given headers and body to the given
/// URL, which can be a [Uri] or a [String].
/// URL, which can be a [Uri] or a [String].
...
@@ -69,22 +98,24 @@ Future<Response> put(url, {Map<String, String> headers, body}) =>
...
@@ -69,22 +98,24 @@ Future<Response> put(url, {Map<String, String> headers, body}) =>
///
///
/// [encoding] defaults to [UTF8].
/// [encoding] defaults to [UTF8].
///
///
/// For more fine-grained control over the request, use [Request] or
/// This automatically initializes a new [MojoClient] and closes that client once
/// [StreamedRequest] instead.
/// the request is complete. If you're planning on making multiple requests to
Future
<
Response
>
patch
(
url
,
{
Map
<
String
,
String
>
headers
,
body
})
=>
/// the same server, you should use a single [MojoClient] for all of those requests.
_withClient
((
client
)
=>
client
.
patch
(
url
,
Future
<
Response
>
patch
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
,
dynamic
body
,
Encoding
encoding:
UTF8
})
{
headers:
headers
,
body:
body
));
return
_withClient
/*<Response>*/
((
MojoClient
client
)
{
return
client
.
patch
(
url
,
headers:
headers
,
body:
body
,
encoding:
encoding
);
});
}
/// Sends an HTTP DELETE request with the given headers to the given URL, which
/// Sends an HTTP DELETE request with the given headers to the given URL, which
/// can be a [Uri] or a [String].
/// can be a [Uri] or a [String].
///
///
/// This automatically initializes a new [Client] and closes that client once
/// This automatically initializes a new [
Mojo
Client] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [Client] for all of those requests.
/// the same server, you should use a single [MojoClient] for all of those requests.
///
Future
<
Response
>
delete
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
/// For more fine-grained control over the request, use [Request] instead.
return
_withClient
/*<Response>*/
((
MojoClient
client
)
=>
client
.
delete
(
url
,
headers:
headers
));
Future
<
Response
>
delete
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
}
_withClient
((
client
)
=>
client
.
delete
(
url
,
headers:
headers
));
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// be a [Uri] or a [String], and returns a Future that completes to the body of
/// be a [Uri] or a [String], and returns a Future that completes to the body of
...
@@ -93,14 +124,12 @@ Future<Response> delete(url, {Map<String, String> headers}) =>
...
@@ -93,14 +124,12 @@ Future<Response> delete(url, {Map<String, String> headers}) =>
/// The Future will emit a [ClientException] if the response doesn't have a
/// The Future will emit a [ClientException] if the response doesn't have a
/// success status code.
/// success status code.
///
///
/// This automatically initializes a new [Client] and closes that client once
/// This automatically initializes a new [
Mojo
Client] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [Client] for all of those requests.
/// the same server, you should use a single [MojoClient] for all of those requests.
///
Future
<
String
>
read
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
/// For more fine-grained control over the request and response, use [Request]
return
_withClient
/*<String>*/
((
MojoClient
client
)
=>
client
.
read
(
url
,
headers:
headers
));
/// instead.
}
Future
<
String
>
read
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
_withClient
((
client
)
=>
client
.
read
(
url
,
headers:
headers
));
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// be a [Uri] or a [String], and returns a Future that completes to the body of
/// be a [Uri] or a [String], and returns a Future that completes to the body of
...
@@ -109,17 +138,13 @@ Future<String> read(url, {Map<String, String> headers}) =>
...
@@ -109,17 +138,13 @@ Future<String> read(url, {Map<String, String> headers}) =>
/// The Future will emit a [ClientException] if the response doesn't have a
/// The Future will emit a [ClientException] if the response doesn't have a
/// success status code.
/// success status code.
///
///
/// This automatically initializes a new [Client] and closes that client once
/// This automatically initializes a new [
Mojo
Client] and closes that client once
/// the request is complete. If you're planning on making multiple requests to
/// the request is complete. If you're planning on making multiple requests to
/// the same server, you should use a single [Client] for all of those requests.
/// the same server, you should use a single [MojoClient] for all of those requests.
///
Future
<
Uint8List
>
readBytes
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
/// For more fine-grained control over the request and response, use [Request]
return
_withClient
/*<Uint8List>*/
((
MojoClient
client
)
=>
client
.
readBytes
(
url
,
headers:
headers
));
/// instead.
}
Future
<
Uint8List
>
readBytes
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
_withClient
((
client
)
=>
client
.
readBytes
(
url
,
headers:
headers
));
Future
_withClient
(
Future
fn
(
MojoClient
client
))
{
Future
/*<T>*/
_withClient
/*<T>*/
(
Future
/*<T>*/
fn
(
MojoClient
client
))
{
var
client
=
new
MojoClient
();
return
fn
(
new
MojoClient
());
var
future
=
fn
(
client
);
return
future
.
whenComplete
(
client
.
close
);
}
}
packages/flutter/lib/src/http/mojo_client.dart
View file @
1e5eb74c
...
@@ -19,43 +19,111 @@ import 'response.dart';
...
@@ -19,43 +19,111 @@ import 'response.dart';
/// A `mojo`-based HTTP client.
/// A `mojo`-based HTTP client.
class
MojoClient
{
class
MojoClient
{
Future
<
Response
>
head
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
/// Sends an HTTP HEAD request with the given headers to the given URL, which
_send
(
"HEAD"
,
url
,
headers
);
/// can be a [Uri] or a [String].
Future
<
Response
>
head
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
return
_send
(
"HEAD"
,
url
,
headers
);
}
Future
<
Response
>
get
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
/// Sends an HTTP GET request with the given headers to the given URL, which can
_send
(
"GET"
,
url
,
headers
);
/// be a [Uri] or a [String].
Future
<
Response
>
get
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
return
_send
(
"GET"
,
url
,
headers
);
}
Future
<
Response
>
post
(
url
,
{
Map
<
String
,
String
>
headers
,
body
,
/// Sends an HTTP POST request with the given headers and body to the given URL,
Encoding
encoding
})
=>
/// which can be a [Uri] or a [String].
_send
(
"POST"
,
url
,
headers
,
body
,
encoding
);
///
/// [body] sets the body of the request. It can be a [String], a [List<int>] or
/// a [Map<String, String>]. If it's a String, it's encoded using [encoding] and
/// used as the body of the request. The content-type of the request will
/// default to "text/plain".
///
/// If [body] is a List, it's used as a list of bytes for the body of the
/// request.
///
/// If [body] is a Map, it's encoded as form fields using [encoding]. The
/// content-type of the request will be set to
/// `"application/x-www-form-urlencoded"`; this cannot be overridden.
///
/// [encoding] defaults to [UTF8].
Future
<
Response
>
post
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
,
dynamic
body
,
Encoding
encoding:
UTF8
})
{
return
_send
(
"POST"
,
url
,
headers
,
body
,
encoding
);
}
Future
<
Response
>
put
(
url
,
{
Map
<
String
,
String
>
headers
,
body
,
/// Sends an HTTP PUT request with the given headers and body to the given URL,
Encoding
encoding
})
=>
/// which can be a [Uri] or a [String].
_send
(
"PUT"
,
url
,
headers
,
body
,
encoding
);
///
/// [body] sets the body of the request. It can be a [String], a [List<int>] or
/// a [Map<String, String>]. If it's a String, it's encoded using [encoding] and
/// used as the body of the request. The content-type of the request will
/// default to "text/plain".
///
/// If [body] is a List, it's used as a list of bytes for the body of the
/// request.
///
/// If [body] is a Map, it's encoded as form fields using [encoding]. The
/// content-type of the request will be set to
/// `"application/x-www-form-urlencoded"`; this cannot be overridden.
///
/// [encoding] defaults to [UTF8].
Future
<
Response
>
put
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
,
dynamic
body
,
Encoding
encoding:
UTF8
})
{
return
_send
(
"PUT"
,
url
,
headers
,
body
,
encoding
);
}
Future
<
Response
>
patch
(
url
,
{
Map
<
String
,
String
>
headers
,
body
,
/// Sends an HTTP PATCH request with the given headers and body to the given
Encoding
encoding
})
=>
/// URL, which can be a [Uri] or a [String].
_send
(
"PATCH"
,
url
,
headers
,
body
,
encoding
);
///
/// [body] sets the body of the request. It can be a [String], a [List<int>] or
/// a [Map<String, String>]. If it's a String, it's encoded using [encoding] and
/// used as the body of the request. The content-type of the request will
/// default to "text/plain".
///
/// If [body] is a List, it's used as a list of bytes for the body of the
/// request.
///
/// If [body] is a Map, it's encoded as form fields using [encoding]. The
/// content-type of the request will be set to
/// `"application/x-www-form-urlencoded"`; this cannot be overridden.
///
/// [encoding] defaults to [UTF8].
Future
<
Response
>
patch
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
,
dynamic
body
,
Encoding
encoding:
UTF8
})
{
return
_send
(
"PATCH"
,
url
,
headers
,
body
,
encoding
);
}
Future
<
Response
>
delete
(
url
,
{
Map
<
String
,
String
>
headers
})
=>
/// Sends an HTTP DELETE request with the given headers to the given URL, which
_send
(
"DELETE"
,
url
,
headers
);
/// can be a [Uri] or a [String].
Future
<
Response
>
delete
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
return
_send
(
"DELETE"
,
url
,
headers
);
}
Future
<
String
>
read
(
url
,
{
Map
<
String
,
String
>
headers
})
{
/// Sends an HTTP GET request with the given headers to the given URL, which can
return
get
(
url
,
headers:
headers
).
then
((
response
)
{
/// be a [Uri] or a [String], and returns a Future that completes to the body of
/// the response as a [String].
///
/// The Future will emit a [ClientException] if the response doesn't have a
/// success status code.
Future
<
String
>
read
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
return
get
(
url
,
headers:
headers
).
then
((
Response
response
)
{
_checkResponseSuccess
(
url
,
response
);
_checkResponseSuccess
(
url
,
response
);
return
response
.
body
;
return
response
.
body
;
});
});
}
}
Future
<
Uint8List
>
readBytes
(
url
,
{
Map
<
String
,
String
>
headers
})
{
/// Sends an HTTP GET request with the given headers to the given URL, which can
/// be a [Uri] or a [String], and returns a Future that completes to the body of
/// the response as a list of bytes.
///
/// The Future will emit a [ClientException] if the response doesn't have a
/// success status code.
Future
<
Uint8List
>
readBytes
(
dynamic
url
,
{
Map
<
String
,
String
>
headers
})
{
return
get
(
url
,
headers:
headers
).
then
((
Response
response
)
{
return
get
(
url
,
headers:
headers
).
then
((
Response
response
)
{
_checkResponseSuccess
(
url
,
response
);
_checkResponseSuccess
(
url
,
response
);
return
response
.
bodyBytes
;
return
response
.
bodyBytes
;
});
});
}
}
Future
<
Response
>
_send
(
String
method
,
url
,
Future
<
Response
>
_send
(
String
method
,
dynamic
url
,
Map
<
String
,
String
>
headers
,
[
dynamic
body
,
Encoding
encoding
=
UTF8
])
async
{
Map
<
String
,
String
>
headers
,
[
body
,
Encoding
encoding
])
async
{
mojo
.
UrlLoaderProxy
loader
=
new
mojo
.
UrlLoaderProxy
.
unbound
();
mojo
.
UrlLoaderProxy
loader
=
new
mojo
.
UrlLoaderProxy
.
unbound
();
List
<
mojo
.
HttpHeader
>
mojoHeaders
=
<
mojo
.
HttpHeader
>[];
List
<
mojo
.
HttpHeader
>
mojoHeaders
=
<
mojo
.
HttpHeader
>[];
headers
?.
forEach
((
String
name
,
String
value
)
{
headers
?.
forEach
((
String
name
,
String
value
)
{
...
@@ -71,7 +139,7 @@ class MojoClient {
...
@@ -71,7 +139,7 @@ class MojoClient {
if
(
body
!=
null
)
{
if
(
body
!=
null
)
{
mojo
.
MojoDataPipe
pipe
=
new
mojo
.
MojoDataPipe
();
mojo
.
MojoDataPipe
pipe
=
new
mojo
.
MojoDataPipe
();
request
.
body
=
<
mojo
.
MojoDataPipeConsumer
>[
pipe
.
consumer
];
request
.
body
=
<
mojo
.
MojoDataPipeConsumer
>[
pipe
.
consumer
];
Uint8List
encodedBody
=
UTF8
.
encode
(
body
);
Uint8List
encodedBody
=
encoding
.
encode
(
body
);
ByteData
data
=
new
ByteData
.
view
(
encodedBody
.
buffer
);
ByteData
data
=
new
ByteData
.
view
(
encodedBody
.
buffer
);
mojo
.
DataPipeFiller
.
fillHandle
(
pipe
.
producer
,
data
);
mojo
.
DataPipeFiller
.
fillHandle
(
pipe
.
producer
,
data
);
}
}
...
@@ -90,14 +158,12 @@ class MojoClient {
...
@@ -90,14 +158,12 @@ class MojoClient {
}
}
}
}
void
_checkResponseSuccess
(
url
,
Response
response
)
{
void
_checkResponseSuccess
(
dynamic
url
,
Response
response
)
{
if
(
response
.
statusCode
<
400
)
if
(
response
.
statusCode
<
400
)
return
;
return
;
throw
new
Exception
(
"Request to
$url
failed with status
${response.statusCode}
."
);
throw
new
Exception
(
"Request to
$url
failed with status
${response.statusCode}
."
);
}
}
void
close
()
{}
static
mojo
.
NetworkServiceProxy
_initNetworkService
()
{
static
mojo
.
NetworkServiceProxy
_initNetworkService
()
{
mojo
.
NetworkServiceProxy
proxy
=
new
mojo
.
NetworkServiceProxy
.
unbound
();
mojo
.
NetworkServiceProxy
proxy
=
new
mojo
.
NetworkServiceProxy
.
unbound
();
shell
.
connectToService
(
"mojo:authenticated_network_service"
,
proxy
);
shell
.
connectToService
(
"mojo:authenticated_network_service"
,
proxy
);
...
...
packages/flutter/lib/src/material/shadows.dart
View file @
1e5eb74c
...
@@ -10,11 +10,20 @@ import 'package:flutter/painting.dart';
...
@@ -10,11 +10,20 @@ import 'package:flutter/painting.dart';
// Currently, only the elevation values that are bound to one or more components are
// Currently, only the elevation values that are bound to one or more components are
// defined here.
// defined here.
/// Map of elevation offsets used by material design to [BoxShadow] definitions.
///
/// The following elevations have defined shadows: 1, 2, 3, 4, 6, 8, 9, 12, 16, 24
///
/// Each entry has three shadows which must be combined to obtain the defined
/// effect for that elevation.
///
/// See also: <https://www.google.com/design/spec/what-is-material/elevation-shadows.html>
const
Map
<
int
,
List
<
BoxShadow
>>
elevationToShadow
=
_elevationToShadow
;
// to hide the literal from the docs
const
Color
_kKeyUmbraOpacity
=
const
Color
(
0x33000000
);
// alpha = 0.2
const
Color
_kKeyUmbraOpacity
=
const
Color
(
0x33000000
);
// alpha = 0.2
const
Color
_kKeyPenumbraOpacity
=
const
Color
(
0x24000000
);
// alpha = 0.14
const
Color
_kKeyPenumbraOpacity
=
const
Color
(
0x24000000
);
// alpha = 0.14
const
Color
_kAmbientShadowOpacity
=
const
Color
(
0x1F000000
);
// alpha = 0.12
const
Color
_kAmbientShadowOpacity
=
const
Color
(
0x1F000000
);
// alpha = 0.12
const
Map
<
int
,
List
<
BoxShadow
>>
_elevationToShadow
=
const
<
int
,
List
<
BoxShadow
>>{
const
Map
<
int
,
List
<
BoxShadow
>>
elevationToShadow
=
const
<
int
,
List
<
BoxShadow
>>{
1
:
const
<
BoxShadow
>[
1
:
const
<
BoxShadow
>[
const
BoxShadow
(
offset:
const
Offset
(
0.0
,
2.0
),
blurRadius:
1.0
,
spreadRadius:
-
1.0
,
color:
_kKeyUmbraOpacity
),
const
BoxShadow
(
offset:
const
Offset
(
0.0
,
2.0
),
blurRadius:
1.0
,
spreadRadius:
-
1.0
,
color:
_kKeyUmbraOpacity
),
const
BoxShadow
(
offset:
const
Offset
(
0.0
,
1.0
),
blurRadius:
1.0
,
spreadRadius:
0.0
,
color:
_kKeyPenumbraOpacity
),
const
BoxShadow
(
offset:
const
Offset
(
0.0
,
1.0
),
blurRadius:
1.0
,
spreadRadius:
0.0
,
color:
_kKeyPenumbraOpacity
),
...
...
packages/flutter/lib/src/rendering/debug.dart
View file @
1e5eb74c
...
@@ -53,7 +53,7 @@ bool debugPaintPointersEnabled = false;
...
@@ -53,7 +53,7 @@ bool debugPaintPointersEnabled = false;
/// The color to use when reporting pointers.
/// The color to use when reporting pointers.
int
debugPaintPointersColorValue
=
0x00BBBB
;
int
debugPaintPointersColorValue
=
0x00BBBB
;
/// The color to use when painting
RenderError boxe
s in checked mode.
/// The color to use when painting
[RenderErrorBox] object
s in checked mode.
Color
debugErrorBoxColor
=
const
Color
(
0xFFFF0000
);
Color
debugErrorBoxColor
=
const
Color
(
0xFFFF0000
);
/// Overlay a rotating set of colors when repainting layers in checked mode.
/// Overlay a rotating set of colors when repainting layers in checked mode.
...
...
packages/flutter/lib/src/scheduler/ticker.dart
View file @
1e5eb74c
...
@@ -6,11 +6,12 @@ import 'dart:async';
...
@@ -6,11 +6,12 @@ import 'dart:async';
import
'scheduler.dart'
;
import
'scheduler.dart'
;
/// Signature for the [onTick] constructor argument of the [Ticker] class.
typedef
void
TickerCallback
(
Duration
elapsed
);
typedef
void
TickerCallback
(
Duration
elapsed
);
/// Calls its callback once per animation frame.
/// Calls its callback once per animation frame.
class
Ticker
{
class
Ticker
{
/// Constructs a ticker that will call
onTick once per frame while running
/// Constructs a ticker that will call
[onTick] once per frame while running.
Ticker
(
TickerCallback
onTick
)
:
_onTick
=
onTick
;
Ticker
(
TickerCallback
onTick
)
:
_onTick
=
onTick
;
final
TickerCallback
_onTick
;
final
TickerCallback
_onTick
;
...
...
packages/flutter_tools/lib/src/commands/analyze.dart
View file @
1e5eb74c
...
@@ -334,7 +334,7 @@ linter:
...
@@ -334,7 +334,7 @@ linter:
if
(
dartFiles
.
length
==
1
)
{
if
(
dartFiles
.
length
==
1
)
{
printStatus
(
'Analyzing
${dartFiles.first}
...'
);
printStatus
(
'Analyzing
${dartFiles.first}
...'
);
}
else
{
}
else
{
printStatus
(
'Analyzing
${dartFiles.length}
file
s...'
);
printStatus
(
'Analyzing
${dartFiles.length}
entry point
s...'
);
}
}
for
(
String
file
in
dartFiles
)
for
(
String
file
in
dartFiles
)
printTrace
(
file
);
printTrace
(
file
);
...
...
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