| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 | 
							- /* Amber package loading.
 
-   Load this script as well as require.js (works in any order;
 
-     either defines 'require', thus passing config, if loaded prior require.js;
 
-     or calls require.config, if loaded post require.js).
 
-   Usage example:
 
-     require(['amber/devel'], function(smalltalk) {
 
-         smallralk.initialize({"transport.defaultAmdNamespace": "com_example_myproject"});
 
-         smalltalk.globals.Browser._open(); // for legacy IDE
 
-         smalltalk.popupHelios(); // for Helios IDE
 
-     });
 
-   For detailed explanation of amber loading, see:
 
-   https://github.com/amber-smalltalk/amber/wiki/How-to-load-amber
 
-  */
 
- var require;
 
- require = function (require) {
 
-     // To be able to use its path and attrubutes
 
-     // to map other parts of Amber, this code must find its <script> tag.
 
-     // It first looks for id 'amber-path-mapper'.
 
-     // When loading amber.js asynchronously, you must include this id,
 
-     // or the code can not reliably find its <script>.
 
-     var me = document.getElementById("amber-path-mapper");
 
-     if (!me || me.tagName.toLowerCase() !== "script") {
 
-         // If <script> with 'amber-path-mapper' id is not present,
 
-         // (this id is not necessary for inline <script> tag in HTML),
 
-         // it uses the "find the last <script> tag present in the moment" method.
 
-         var scripts = document.getElementsByTagName("script");
 
-         me = scripts[scripts.length - 1];
 
-     }
 
-     var src = me.src;
 
-     // strip the last two elements from the URL
 
-     // e.g. http://app.com/amber/support/amber.js -> http://app.com/amber
 
-     var amber_home = resolveViaDOM(src).replace(/\/[^\/]+\/[^\/]+$/, "");
 
-     // In case of nonstandard deployment, you can specify libraries placement directly ...
 
-     var library_home = me.hasAttribute('data-libs') && me.getAttribute('data-libs');
 
-     // ... otherwise, this heuristics is used:
 
-     if (!library_home) {
 
-         // At the present moment, bower tries to have flat hierarchy,
 
-         // which leads to two possible scenarios:
 
-         // 1. amber itself was deployed via bower,
 
-         //    its libraries are at the same bower dir
 
-         //    where amber itself is placed
 
-         // 2. amber was deployed in different fashion,
 
-         //    its libraries are included by bower locally, inside amber
 
-         // The detection is done by looking for '/bower_components/' in amber path.
 
-         var match = amber_home.match(/^(.*\/bower_components)\//);
 
-         library_home = match ? match[1] : amber_home + '/bower_components';
 
-     }
 
-     function resolveViaDOM(url) {
 
-         var a = document.createElement("a");
 
-         a.href = url;
 
-         return a.href;
 
-     }
 
-     var config = {
 
-         paths: {
 
-             'amber': amber_home + '/support',
 
-             'amber_vm': amber_home + '/support',
 
-             'amber_css': amber_home + '/css',
 
-             'amber_lib': library_home,
 
-             'amber_core': amber_home + '/src',
 
-             'amber_helios/html': amber_home,
 
-             'jquery': library_home + '/jquery/jquery.min',
 
-             'jquery-ui': library_home + '/jquery-ui/ui/minified/jquery-ui.min'
 
-         },
 
-         map: {
 
-             '*': {
 
-                 'css': 'amber_lib/require-css/css'
 
-             }
 
-         },
 
-         shim: {
 
-             'jquery-ui': {
 
-                 deps: [ 'jquery' ]
 
-             },
 
-             'amber_lib/bootstrap/js/bootstrap': {
 
-                 deps: [ 'jquery', 'css!amber_lib/bootstrap/css/bootstrap' ]
 
-             },
 
-             'amber_lib/codemirror/lib/codemirror': {
 
-                 deps: [ 'css!amber_lib/codemirror/lib/codemirror' ]
 
-             },
 
-             'amber_lib/jquery-tabby/jquery.textarea': {
 
-                 deps: [ 'jquery' ]
 
-             },
 
-             'amber_core/IDE': {
 
-                 deps: [ 'amber_lib/codemirror/mode/smalltalk/smalltalk' ]
 
-             },
 
-             'amber_lib/codemirror/mode/smalltalk/smalltalk': {
 
-                 deps: [ '../../lib/codemirror' ]
 
-             },
 
-             'amber_lib/codemirror/addon/hint/show-hint': {
 
-                 deps: [ '../../lib/codemirror' ]
 
-             },
 
-             'ensure-console': {
 
-                 exports: 'console'
 
-             }
 
-         }
 
-     };
 
-     // This is to allow both alternatives of loading:
 
-     // before require.js as well as after require.js
 
-     // See http://requirejs.org/docs/api.html#config for details
 
-     // of usage of 'require' global to allow to pre-define configuration
 
-     // before require.js is loaded.
 
-     if (require) {
 
-         require.config(config);
 
-         return require;
 
-     } else {
 
-         return config;
 
-     }
 
- }(require);
 
 
  |