Overview
Project | Path | Errors | Warnings | Messages | |
---|---|---|---|---|---|
Xero Browser Setup | Xero Browser Setup\Xero Browser Setup.vdproj | 1 | 0 | 0 | |
Solution Items | Solution Items | 0 | 0 | 0 | |
Solution | XeroBrowser.sln | 0 | 0 | 1 |
diff --git a/UpgradeLog3.htm b/UpgradeLog3.htm new file mode 100644 index 0000000..e5374fe --- /dev/null +++ b/UpgradeLog3.htm @@ -0,0 +1,274 @@ + + +
Project | Path | Errors | Warnings | Messages | |
---|---|---|---|---|---|
Xero Browser Setup | Xero Browser Setup\Xero Browser Setup.vdproj | 1 | 0 | 0 | |
Solution Items | Solution Items | 0 | 0 | 0 | |
Solution | XeroBrowser.sln | 0 | 0 | 1 |
+ // create the 'example' global object if it doesn't already exist. + if (!example) + example = {}; + // create the 'example.test' global object if it doesn't already exist. + if (!example.test) + example.test = {}; + (function() { + // Define the function 'example.test.myfunction'. + example.test.myfunction = function() { + // Call CefV8Handler::Execute() with the function name 'MyFunction' + // and no arguments. + native function MyFunction(); + return MyFunction(); + }; + // Define the getter function for parameter 'example.test.myparam'. + example.test.__defineGetter__('myparam', function() { + // Call CefV8Handler::Execute() with the function name 'GetMyParam' + // and no arguments. + native function GetMyParam(); + return GetMyParam(); + }); + // Define the setter function for parameter 'example.test.myparam'. + example.test.__defineSetter__('myparam', function(b) { + // Call CefV8Handler::Execute() with the function name 'SetMyParam' + // and a single argument. + native function SetMyParam(); + if(b) SetMyParam(b); + }); + + // Extension definitions can also contain normal JavaScript variables + // and functions. + var myint = 0; + example.test.increment = function() { + myint += 1; + return myint; + }; + })(); ++ +Example usage in the page: +
+ // Call the function. + example.test.myfunction(); + // Set the parameter. + example.test.myparam = value; + // Get the parameter. + value = example.test.myparam; + // Call another function. + example.test.increment(); +
+ [scheme]://[username]:[password]@[host]:[port]/[url-path] +Standard scheme URLs must have a host component that is a fully +qualified domain name as defined in Section 3.5 of RFC 1034 [13] and +Section 2.1 of RFC 1123. These URLs will be canonicalized to +"scheme://host/path" in the simplest case and +"scheme://username:password@host:port/path" in the most explicit case. For +example, "scheme:host/path" and "scheme:///host/path" will both be +canonicalized to "scheme://host/path". The origin of a standard scheme URL +is the combination of scheme, host and port (i.e., "scheme://host:port" in +the most explicit case). +For non-standard scheme URLs only the "scheme:" component is parsed and +canonicalized. The remainder of the URL will be passed to the handler as- +is. For example, "scheme:///some%20text" will remain the same. +Non-standard scheme URLs cannot be used as a target for form submission. + +
+ class MyClass { + public: + void Foo() { + DCHECK(thread_checker_.CalledOnValidThread()); + ... (do stuff) ... + } + + private: + ThreadChecker thread_checker_; + } ++ +In Release mode, CalledOnValidThread will always return true. + +
+ // create the 'example' global object if it doesn't already exist. + if (!example) + example = {}; + // create the 'example.test' global object if it doesn't already exist. + if (!example.test) + example.test = {}; + (function() { + // Define the function 'example.test.myfunction'. + example.test.myfunction = function() { + // Call CefV8Handler::Execute() with the function name 'MyFunction' + // and no arguments. + native function MyFunction(); + return MyFunction(); + }; + // Define the getter function for parameter 'example.test.myparam'. + example.test.__defineGetter__('myparam', function() { + // Call CefV8Handler::Execute() with the function name 'GetMyParam' + // and no arguments. + native function GetMyParam(); + return GetMyParam(); + }); + // Define the setter function for parameter 'example.test.myparam'. + example.test.__defineSetter__('myparam', function(b) { + // Call CefV8Handler::Execute() with the function name 'SetMyParam' + // and a single argument. + native function SetMyParam(); + if(b) SetMyParam(b); + }); + + // Extension definitions can also contain normal JavaScript variables + // and functions. + var myint = 0; + example.test.increment = function() { + myint += 1; + return myint; + }; + })(); ++ +Example usage in the page: +
+ // Call the function. + example.test.myfunction(); + // Set the parameter. + example.test.myparam = value; + // Get the parameter. + value = example.test.myparam; + // Call another function. + example.test.increment(); +
+ [scheme]://[username]:[password]@[host]:[port]/[url-path] +Standard scheme URLs must have a host component that is a fully +qualified domain name as defined in Section 3.5 of RFC 1034 [13] and +Section 2.1 of RFC 1123. These URLs will be canonicalized to +"scheme://host/path" in the simplest case and +"scheme://username:password@host:port/path" in the most explicit case. For +example, "scheme:host/path" and "scheme:///host/path" will both be +canonicalized to "scheme://host/path". The origin of a standard scheme URL +is the combination of scheme, host and port (i.e., "scheme://host:port" in +the most explicit case). +For non-standard scheme URLs only the "scheme:" component is parsed and +canonicalized. The remainder of the URL will be passed to the handler as- +is. For example, "scheme:///some%20text" will remain the same. +Non-standard scheme URLs cannot be used as a target for form submission. + +
+ class MyClass { + public: + void Foo() { + DCHECK(thread_checker_.CalledOnValidThread()); + ... (do stuff) ... + } + + private: + ThreadChecker thread_checker_; + } ++ +In Release mode, CalledOnValidThread will always return true. + +
+ [scheme]://[username]:[password]@[host]:[port]/[url-path] ++ Standard scheme URLs must have a host component that is a fully qualified + domain name as defined in Section 3.5 of RFC 1034 [13] and Section 2.1 of + RFC 1123. These URLs will be canonicalized to "scheme://host/path" in the + simplest case and "scheme://username:password@host:port/path" in the most + explicit case. For example, "scheme:host/path" and "scheme:///host/path" + will both be canonicalized to "scheme://host/path". The origin of a + standard scheme URL is the combination of scheme, host and port (i.e., + "scheme://host:port" in the most explicit case). + + For non-standard scheme URLs only the "scheme:" component is parsed and + canonicalized. The remainder of the URL will be passed to the handler + as-is. For example, "scheme:///some%20text" will remain the same. + Non-standard scheme URLs cannot be used as a target for form submission. +
+ [scheme]://[username]:[password]@[host]:[port]/[url-path] +Standard scheme URLs must have a host component that is a fully + qualified domain name as defined in Section 3.5 of RFC 1034 [13] and + Section 2.1 of RFC 1123. These URLs will be canonicalized to + "scheme://host/path" in the simplest case and + "scheme://username:password@host:port/path" in the most explicit case. For + example, "scheme:host/path" and "scheme:///host/path" will both be + canonicalized to "scheme://host/path". The origin of a standard scheme URL + is the combination of scheme, host and port (i.e., "scheme://host:port" in + the most explicit case). + + For non-standard scheme URLs only the "scheme:" component is parsed and + canonicalized. The remainder of the URL will be passed to the handler as- + is. For example, "scheme:///some%20text" will remain the same. Non-standard + scheme URLs cannot be used as a target for form submission. +
+ JavascriptMessageReceivedEventArgs.SetBinder(new DefaultBinder(new CamelCaseJavascriptNameConverter()));
+
+
+ browser.DialogHandler = new TempFileDialogHandler();
+
+ Example URL to use for file browsing http://www.cs.tut.fi/~jkorpela/forms/file.html#example
+ Simply click browse, the space next to the browse button should be populated with a randomly generated filename.
+
+ browser.DialogHandler = new TempFileDialogHandler();
+
+ Example URL to use for file browsing http://www.cs.tut.fi/~jkorpela/forms/file.html#example
+ Simply click browse, the space next to the browse button should be populated with a randomly generated filename.
+
+
+
+
+ var headers = request.Headers;
+ var userAgent = headers["User-Agent"];
+ headers["User-Agent"] = userAgent + " CefSharp";
+ request.Headers = headers;
+
+
+ propertyGetter, string propertyName)
+ {
+ object result = propertyGetter();
+ Debug.WriteLine("InterceptGet " + propertyName);
+ return result;
+ }
+ ]]>
+
+
+ propertySetter, object parameter, string propertName)
+ {
+ Debug.WriteLine("InterceptSet " + propertName);
+ propertySetter(parameter);
+ }
+ ]]>
+
+
+
+
+
+
+
+