]> scripts.mit.edu Git - autoinstalls/wordpress.git/blobdiff - wp-includes/script-loader.php
Wordpress 3.3
[autoinstalls/wordpress.git] / wp-includes / script-loader.php
index 0616afca04f2e93404a096d6e029cd707157cd68..47a00fb1f4d14380143ceeae23bffd20e4290dfb 100644 (file)
@@ -37,10 +37,11 @@ require( ABSPATH . WPINC . '/class.wp-styles.php' );
 require( ABSPATH . WPINC . '/functions.wp-styles.php' );
 
 /**
- * Set up WordPress scripts to load by default for Administration Screen.
+ * Register all WordPress scripts.
  *
- * Localizes a few of the scripts.
- * $scripts->add_data( 'script-handle', 'group', 1 ); queues the script for the footer
+ * Localizes some of them.
+ * args order: $scripts->add( 'handle', 'url', 'dependencies', 'query-string', 1 );
+ * when last arg === 1 queues the script for the footer
  *
  * @since 2.6.0
  *
@@ -58,26 +59,17 @@ function wp_default_scripts( &$scripts ) {
 
        $suffix = defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ? '.dev' : '';
 
-       // Always ensure that we have the convertEntities function
-       $scripts->add( 'l10n', "/wp-includes/js/l10n$suffix.js", false, '20101110' );
-       $scripts->enqueue( 'l10n' );
-
        $scripts->add( 'utils', "/wp-admin/js/utils$suffix.js", false, '20101110' );
 
-       $scripts->add( 'common', "/wp-admin/js/common$suffix.js", array('jquery', 'hoverIntent', 'utils'), '20110610' );
-       $scripts->add_data( 'common', 'group', 1 );
+       $scripts->add( 'common', "/wp-admin/js/common$suffix.js", array('jquery', 'hoverIntent', 'utils'), '20111130', 1 );
        $scripts->localize( 'common', 'commonL10n', array(
-               'warnDelete' => __("You are about to permanently delete the selected items.\n  'Cancel' to stop, 'OK' to delete."),
-               'l10n_print_after' => 'try{convertEntities(commonL10n);}catch(e){};'
+               'warnDelete' => __("You are about to permanently delete the selected items.\n  'Cancel' to stop, 'OK' to delete.")
        ) );
 
-       $scripts->add( 'sack', "/wp-includes/js/tw-sack$suffix.js", false, '1.6.1' );
-       $scripts->add_data( 'sack', 'group', 1 );
+       $scripts->add( 'sack', "/wp-includes/js/tw-sack$suffix.js", false, '1.6.1', 1 );
 
-       $scripts->add( 'quicktags', "/wp-includes/js/quicktags$suffix.js", false, '20110502' );
-       $scripts->add_data( 'quicktags', 'group', 1 );
+       $scripts->add( 'quicktags', "/wp-includes/js/quicktags$suffix.js", false, '20111114', 1 );
        $scripts->localize( 'quicktags', 'quicktagsL10n', array(
-               'quickLinks' => __('(Quick Links)'),
                'wordLookup' => __('Enter a word to look up:'),
                'dictionaryLookup' => esc_attr(__('Dictionary lookup')),
                'lookup' => esc_attr(__('lookup')),
@@ -87,33 +79,31 @@ function wp_default_scripts( &$scripts ) {
                'enterImageURL' => __('Enter the URL of the image'),
                'enterImageDescription' => __('Enter a description of the image'),
                'fullscreen' => __('fullscreen'),
-               'toggleFullscreen' => esc_attr( __('Toggle fullscreen mode') ),
-               'l10n_print_after' => 'try{convertEntities(quicktagsL10n);}catch(e){};'
+               'toggleFullscreen' => esc_attr( __('Toggle fullscreen mode') )
        ) );
 
        $scripts->add( 'colorpicker', "/wp-includes/js/colorpicker$suffix.js", array('prototype'), '3517m' );
 
-       $scripts->add( 'editor', "/wp-admin/js/editor$suffix.js", array('utils','jquery'), '20110411' );
-       $scripts->add_data( 'editor', 'group', 1 );
+       $scripts->add( 'editor', "/wp-admin/js/editor$suffix.js", array('utils','jquery'), '20111117', 1 );
 
-       $scripts->add( 'wp-fullscreen', "/wp-admin/js/wp-fullscreen$suffix.js", array('jquery'), '20110610' );
-       $scripts->add_data( 'wp-fullscreen', 'group', 1 );
+       $scripts->add( 'wp-fullscreen', "/wp-admin/js/wp-fullscreen$suffix.js", array('jquery'), '20111116', 1 );
 
        $scripts->add( 'prototype', '/wp-includes/js/prototype.js', false, '1.6.1');
 
-       $scripts->add( 'wp-ajax-response', "/wp-includes/js/wp-ajax-response$suffix.js", array('jquery'), '20091119' );
-       $scripts->add_data( 'wp-ajax-response', 'group', 1 );
+       $scripts->add( 'wp-ajax-response', "/wp-includes/js/wp-ajax-response$suffix.js", array('jquery'), '20091119', 1 );
        $scripts->localize( 'wp-ajax-response', 'wpAjax', array(
                'noPerm' => __('You do not have permission to do that.'),
-               'broken' => __('An unidentified error has occurred.'),
-               'l10n_print_after' => 'try{convertEntities(wpAjax);}catch(e){};'
+               'broken' => __('An unidentified error has occurred.')
+       ) );
+
+       $scripts->add( 'wp-pointer', "/wp-includes/js/wp-pointer$suffix.js", array( 'jquery-ui-widget', 'jquery-ui-position' ), '20111129a', 1 );
+       $scripts->localize( 'wp-pointer', 'wpPointerL10n', array(
+               'dismiss' => __('Dismiss'),
        ) );
 
-       $scripts->add( 'autosave', "/wp-includes/js/autosave$suffix.js", array('schedule', 'wp-ajax-response'), '20110524' );
-       $scripts->add_data( 'autosave', 'group', 1 );
+       $scripts->add( 'autosave', "/wp-includes/js/autosave$suffix.js", array('schedule', 'wp-ajax-response'), '20111129', 1 );
 
-       $scripts->add( 'wp-lists', "/wp-includes/js/wp-lists$suffix.js", array('wp-ajax-response'), '20110521' );
-       $scripts->add_data( 'wp-lists', 'group', 1 );
+       $scripts->add( 'wp-lists', "/wp-includes/js/wp-lists$suffix.js", array('wp-ajax-response'), '20110521', 1 );
 
        $scripts->add( 'scriptaculous-root', '/wp-includes/js/scriptaculous/wp-scriptaculous.js', array('prototype'), '1.8.3');
        $scripts->add( 'scriptaculous-builder', '/wp-includes/js/scriptaculous/builder.js', array('scriptaculous-root'), '1.8.3');
@@ -127,71 +117,55 @@ function wp_default_scripts( &$scripts ) {
        // not used in core, replaced by Jcrop.js
        $scripts->add( 'cropper', '/wp-includes/js/crop/cropper.js', array('scriptaculous-dragdrop'), '20070118');
 
-       $scripts->add( 'jquery', '/wp-includes/js/jquery/jquery.js', false, '1.6.1');
-
-       $scripts->add( 'jquery-ui-core', '/wp-includes/js/jquery/ui.core.js', array('jquery'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-core', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-position', '/wp-includes/js/jquery/ui.position.js', array('jquery-ui-core'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-position', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-widget', '/wp-includes/js/jquery/ui.widget.js', array('jquery-ui-core'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-widget', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-mouse', '/wp-includes/js/jquery/ui.mouse.js', array('jquery-ui-widget'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-mouse', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-button', '/wp-includes/js/jquery/ui.button.js', array('jquery-ui-core', 'jquery-ui-widget'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-button', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-tabs', '/wp-includes/js/jquery/ui.tabs.js', array('jquery-ui-core', 'jquery-ui-widget'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-tabs', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-sortable', '/wp-includes/js/jquery/ui.sortable.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-sortable', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-draggable', '/wp-includes/js/jquery/ui.draggable.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-draggable', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-droppable', '/wp-includes/js/jquery/ui.droppable.js', array('jquery-ui-core', 'jquery-ui-mouse', 'jquery-ui-draggable'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-droppable', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-selectable', '/wp-includes/js/jquery/ui.selectable.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-selectable', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-resizable', '/wp-includes/js/jquery/ui.resizable.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-resizable', 'group', 1 );
-
-       $scripts->add( 'jquery-ui-dialog', '/wp-includes/js/jquery/ui.dialog.js', array('jquery-ui-resizable', 'jquery-ui-draggable', 'jquery-ui-button', 'jquery-ui-position'), '1.8.12' );
-       $scripts->add_data( 'jquery-ui-dialog', 'group', 1 );
+       $scripts->add( 'jquery', '/wp-includes/js/jquery/jquery.js', false, '1.7.1' );
+
+       // full jQuery UI
+       $scripts->add( 'jquery-ui-core', '/wp-includes/js/jquery/ui/jquery.ui.core.min.js', array('jquery'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-core', '/wp-includes/js/jquery/ui/jquery.effects.core.min.js', array('jquery'), '1.8.16', 1 );
+
+       $scripts->add( 'jquery-effects-blind', '/wp-includes/js/jquery/ui/jquery.effects.blind.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-bounce', '/wp-includes/js/jquery/ui/jquery.effects.bounce.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-clip', '/wp-includes/js/jquery/ui/jquery.effects.clip.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-drop', '/wp-includes/js/jquery/ui/jquery.effects.drop.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-explode', '/wp-includes/js/jquery/ui/jquery.effects.explode.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-fade', '/wp-includes/js/jquery/ui/jquery.effects.fade.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-fold', '/wp-includes/js/jquery/ui/jquery.effects.fold.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-highlight', '/wp-includes/js/jquery/ui/jquery.effects.highlight.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-pulsate', '/wp-includes/js/jquery/ui/jquery.effects.pulsate.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-scale', '/wp-includes/js/jquery/ui/jquery.effects.scale.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-shake', '/wp-includes/js/jquery/ui/jquery.effects.shake.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-slide', '/wp-includes/js/jquery/ui/jquery.effects.slide.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-effects-transfer', '/wp-includes/js/jquery/ui/jquery.effects.transfer.min.js', array('jquery-effects-core'), '1.8.16', 1 );
+
+       $scripts->add( 'jquery-ui-accordion', '/wp-includes/js/jquery/ui/jquery.ui.accordion.min.js', array('jquery-ui-core', 'jquery-ui-widget'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-autocomplete', '/wp-includes/js/jquery/ui/jquery.ui.autocomplete.min.js', array('jquery-ui-core', 'jquery-ui-widget', 'jquery-ui-position'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-button', '/wp-includes/js/jquery/ui/jquery.ui.button.min.js', array('jquery-ui-core', 'jquery-ui-widget'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-datepicker', '/wp-includes/js/jquery/ui/jquery.ui.datepicker.min.js', array('jquery-ui-core'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-dialog', '/wp-includes/js/jquery/ui/jquery.ui.dialog.min.js', array('jquery-ui-resizable', 'jquery-ui-draggable', 'jquery-ui-button', 'jquery-ui-position'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-draggable', '/wp-includes/js/jquery/ui/jquery.ui.draggable.min.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-droppable', '/wp-includes/js/jquery/ui/jquery.ui.droppable.min.js', array('jquery-ui-draggable'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-mouse', '/wp-includes/js/jquery/ui/jquery.ui.mouse.min.js', array('jquery-ui-widget'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-position', '/wp-includes/js/jquery/ui/jquery.ui.position.min.js', array('jquery'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-progressbar', '/wp-includes/js/jquery/ui/jquery.ui.progressbar.min.js', array('jquery-ui-widget'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-resizable', '/wp-includes/js/jquery/ui/jquery.ui.resizable.min.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-selectable', '/wp-includes/js/jquery/ui/jquery.ui.selectable.min.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-slider', '/wp-includes/js/jquery/ui/jquery.ui.slider.min.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-sortable', '/wp-includes/js/jquery/ui/jquery.ui.sortable.min.js', array('jquery-ui-core', 'jquery-ui-mouse'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-tabs', '/wp-includes/js/jquery/ui/jquery.ui.tabs.min.js', array('jquery-ui-core', 'jquery-ui-widget'), '1.8.16', 1 );
+       $scripts->add( 'jquery-ui-widget', '/wp-includes/js/jquery/ui/jquery.ui.widget.min.js', array('jquery'), '1.8.16', 1 );
 
        // deprecated, not used in core, most functionality is included in jQuery 1.3
-       $scripts->add( 'jquery-form', "/wp-includes/js/jquery/jquery.form$suffix.js", array('jquery'), '2.73');
-       $scripts->add_data( 'jquery-form', 'group', 1 );
-
-       $scripts->add( 'jquery-color', "/wp-includes/js/jquery/jquery.color$suffix.js", array('jquery'), '2.0-4561m');
-       $scripts->add_data( 'jquery-color', 'group', 1 );
-
-       $scripts->add( 'suggest', "/wp-includes/js/jquery/suggest$suffix.js", array('jquery'), '1.1-20110113');
-       $scripts->add_data( 'suggest', 'group', 1 );
-
-       $scripts->add( 'schedule', '/wp-includes/js/jquery/jquery.schedule.js', array('jquery'), '20m');
-       $scripts->add_data( 'schedule', 'group', 1 );
-
-       $scripts->add( 'jquery-query', "/wp-includes/js/jquery/jquery.query.js", array('jquery'), '2.1.7' );
-       $scripts->add_data( 'jquery-query', 'group', 1 );
-
-       $scripts->add( 'jquery-serialize-object', "/wp-includes/js/jquery/jquery.serialize-object.js", array('jquery'), '0.2' );
-       $scripts->add_data( 'jquery-serialize-object', 'group', 1 );
-
-       $scripts->add( 'jquery-hotkeys', "/wp-includes/js/jquery/jquery.hotkeys$suffix.js", array('jquery'), '0.0.2m' );
-       $scripts->add_data( 'jquery-hotkeys', 'group', 1 );
+       $scripts->add( 'jquery-form', "/wp-includes/js/jquery/jquery.form$suffix.js", array('jquery'), '2.73', 1 );
 
-       $scripts->add( 'jquery-table-hotkeys', "/wp-includes/js/jquery/jquery.table-hotkeys$suffix.js", array('jquery', 'jquery-hotkeys'), '20090102' );
-       $scripts->add_data( 'jquery-table-hotkeys', 'group', 1 );
+       $scripts->add( 'jquery-color', "/wp-includes/js/jquery/jquery.color$suffix.js", array('jquery'), '2.0-4561m', 1 );
+       $scripts->add( 'suggest', "/wp-includes/js/jquery/suggest$suffix.js", array('jquery'), '1.1-20110113', 1 );
+       $scripts->add( 'schedule', '/wp-includes/js/jquery/jquery.schedule.js', array('jquery'), '20m', 1 );
+       $scripts->add( 'jquery-query', "/wp-includes/js/jquery/jquery.query.js", array('jquery'), '2.1.7', 1 );
+       $scripts->add( 'jquery-serialize-object', "/wp-includes/js/jquery/jquery.serialize-object.js", array('jquery'), '0.2', 1 );
+       $scripts->add( 'jquery-hotkeys', "/wp-includes/js/jquery/jquery.hotkeys$suffix.js", array('jquery'), '0.0.2m', 1 );
+       $scripts->add( 'jquery-table-hotkeys', "/wp-includes/js/jquery/jquery.table-hotkeys$suffix.js", array('jquery', 'jquery-hotkeys'), '20090102', 1 );
 
-       $scripts->add( 'thickbox', "/wp-includes/js/thickbox/thickbox.js", array('jquery'), '3.1-20110528');
-       $scripts->add_data( 'thickbox', 'group', 1 );
+       $scripts->add( 'thickbox', "/wp-includes/js/thickbox/thickbox.js", array('jquery'), '3.1-20111117', 1 );
        $scripts->localize( 'thickbox', 'thickboxL10n', array(
                        'next' => __('Next >'),
                        'prev' => __('< Prev'),
@@ -200,14 +174,58 @@ function wp_default_scripts( &$scripts ) {
                        'close' => __('Close'),
                        'noiframes' => __('This feature requires inline frames. You have iframes disabled or your browser does not support them.'),
                        'loadingAnimation' => includes_url('js/thickbox/loadingAnimation.gif'),
-                       'closeImage' => includes_url('js/thickbox/tb-close.png'),
-                       'l10n_print_after' => 'try{convertEntities(thickboxL10n);}catch(e){};'
+                       'closeImage' => includes_url('js/thickbox/tb-close.png')
        ) );
 
        $scripts->add( 'jcrop', "/wp-includes/js/jcrop/jquery.Jcrop$suffix.js", array('jquery'), '0.9.8-20110113');
 
        $scripts->add( 'swfobject', "/wp-includes/js/swfobject.js", false, '2.2');
 
+       // common bits for both uploaders
+       $max_upload_size = ( (int) ( $max_up = @ini_get('upload_max_filesize') ) < (int) ( $max_post = @ini_get('post_max_size') ) ) ? $max_up : $max_post;
+
+       if ( empty($max_upload_size) )
+               $max_upload_size = __('not configured');
+
+       // error message for both plupload and swfupload
+       $uploader_l10n = array(
+               'queue_limit_exceeded' => __('You have attempted to queue too many files.'),
+               'file_exceeds_size_limit' => __('%s exceeds the maximum upload size for this site.'),
+               'zero_byte_file' => __('This file is empty. Please try another.'),
+               'invalid_filetype' => __('This file type is not allowed. Please try another.'),
+               'not_an_image' => __('This file is not an image. Please try another.'),
+               'image_memory_exceeded' => __('Memory exceeded. Please try another smaller file.'),
+               'image_dimensions_exceeded' => __('This is larger than the maximum size. Please try another.'),
+               'default_error' => __('An error occurred in the upload. Please try again later.'),
+               'missing_upload_url' => __('There was a configuration error. Please contact the server administrator.'),
+               'upload_limit_exceeded' => __('You may only upload 1 file.'),
+               'http_error' => __('HTTP error.'),
+               'upload_failed' => __('Upload failed.'),
+               'big_upload_failed' => __('Please try uploading this file with the %1$sbrowser uploader%2$s.'),
+               'big_upload_queued' => __('%s exceeds the maximum upload size for the multi-file uploader when used in your browser.'),
+               'io_error' => __('IO error.'),
+               'security_error' => __('Security error.'),
+               'file_cancelled' => __('File canceled.'),
+               'upload_stopped' => __('Upload stopped.'),
+               'dismiss' => __('Dismiss'),
+               'crunching' => __('Crunching&hellip;'),
+               'deleted' => __('moved to the trash.'),
+               'error_uploading' => __('&#8220;%s&#8221; has failed to upload.')
+       );
+
+       $scripts->add( 'plupload', '/wp-includes/js/plupload/plupload.js', false, '1511-20111112');
+       $scripts->add( 'plupload-html5', '/wp-includes/js/plupload/plupload.html5.js', array('plupload'), '1511-20111112');
+       $scripts->add( 'plupload-flash', '/wp-includes/js/plupload/plupload.flash.js', array('plupload'), '1511-20111112');
+       $scripts->add( 'plupload-silverlight', '/wp-includes/js/plupload/plupload.silverlight.js', array('plupload'), '1511-20111112');
+       $scripts->add( 'plupload-html4', '/wp-includes/js/plupload/plupload.html4.js', array('plupload'), '1511-20111112');
+
+       // cannot use the plupload.full.js, as it loads browserplus init JS from Yahoo
+       $scripts->add( 'plupload-all', false, array('plupload', 'plupload-html5', 'plupload-flash', 'plupload-silverlight', 'plupload-html4'), '1511-20111112');
+
+       $scripts->add( 'plupload-handlers', "/wp-includes/js/plupload/handlers$suffix.js", array('plupload-all', 'jquery'), '20111120');
+       $scripts->localize( 'plupload-handlers', 'pluploadL10n', $uploader_l10n );
+
+       // keep 'swfupload' for back-compat.
        $scripts->add( 'swfupload', '/wp-includes/js/swfupload/swfupload.js', false, '2201-20110113');
        $scripts->add( 'swfupload-swfobject', '/wp-includes/js/swfupload/plugins/swfupload.swfobject.js', array('swfupload', 'swfobject'), '2201a');
        $scripts->add( 'swfupload-queue', '/wp-includes/js/swfupload/plugins/swfupload.queue.js', array('swfupload'), '2201');
@@ -221,40 +239,15 @@ function wp_default_scripts( &$scripts ) {
        }
 
        $scripts->add( 'swfupload-handlers', "/wp-includes/js/swfupload/handlers$suffix.js", array('swfupload-all', 'jquery'), '2201-20110524');
-       $max_upload_size = ( (int) ( $max_up = @ini_get('upload_max_filesize') ) < (int) ( $max_post = @ini_get('post_max_size') ) ) ? $max_up : $max_post;
-       if ( empty($max_upload_size) )
-               $max_upload_size = __('not configured');
-       // these error messages came from the sample swfupload js, they might need changing.
-       $scripts->localize( 'swfupload-handlers', 'swfuploadL10n', array(
-                       'queue_limit_exceeded' => __('You have attempted to queue too many files.'),
-                       'file_exceeds_size_limit' => __('This file exceeds the maximum upload size for this site.'),
-                       'zero_byte_file' => __('This file is empty. Please try another.'),
-                       'invalid_filetype' => __('This file type is not allowed. Please try another.'),
-                       'default_error' => __('An error occurred in the upload. Please try again later.'),
-                       'missing_upload_url' => __('There was a configuration error. Please contact the server administrator.'),
-                       'upload_limit_exceeded' => __('You may only upload 1 file.'),
-                       'http_error' => __('HTTP error.'),
-                       'upload_failed' => __('Upload failed.'),
-                       'io_error' => __('IO error.'),
-                       'security_error' => __('Security error.'),
-                       'file_cancelled' => __('File canceled.'),
-                       'upload_stopped' => __('Upload stopped.'),
-                       'dismiss' => __('Dismiss'),
-                       'crunching' => __('Crunching&hellip;'),
-                       'deleted' => __('moved to the trash.'),
-                       'error_uploading' => __('&#8220;%s&#8221; has failed to upload due to an error'),
-                       'l10n_print_after' => 'try{convertEntities(swfuploadL10n);}catch(e){};',
-       ) );
+       $scripts->localize( 'swfupload-handlers', 'swfuploadL10n', $uploader_l10n );
 
        $scripts->add( 'comment-reply', "/wp-includes/js/comment-reply$suffix.js", false, '20090102');
 
        $scripts->add( 'json2', "/wp-includes/js/json2$suffix.js", false, '2011-02-23');
 
-       $scripts->add( 'imgareaselect', "/wp-includes/js/imgareaselect/jquery.imgareaselect$suffix.js", array('jquery'), '0.9.6-20110515' );
-       $scripts->add_data( 'imgareaselect', 'group', 1 );
+       $scripts->add( 'imgareaselect', "/wp-includes/js/imgareaselect/jquery.imgareaselect$suffix.js", array('jquery'), '0.9.6-20110515', 1 );
 
-       $scripts->add( 'password-strength-meter', "/wp-admin/js/password-strength-meter$suffix.js", array('jquery'), '20101027' );
-       $scripts->add_data( 'password-strength-meter', 'group', 1 );
+       $scripts->add( 'password-strength-meter', "/wp-admin/js/password-strength-meter$suffix.js", array('jquery'), '20101027', 1 );
        $scripts->localize( 'password-strength-meter', 'pwsL10n', array(
                'empty' => __('Strength indicator'),
                'short' => __('Very weak'),
@@ -262,58 +255,51 @@ function wp_default_scripts( &$scripts ) {
                /* translators: password strength */
                'good' => _x('Medium', 'password strength'),
                'strong' => __('Strong'),
-               'mismatch' => __('Mismatch'),
-               'l10n_print_after' => 'try{convertEntities(pwsL10n);}catch(e){};'
+               'mismatch' => __('Mismatch')
        ) );
 
-       $scripts->add( 'user-profile', "/wp-admin/js/user-profile$suffix.js", array( 'jquery', 'password-strength-meter' ), '20110628' );
-       $scripts->add_data( 'user-profile', 'group', 1 );
+       $scripts->add( 'user-profile', "/wp-admin/js/user-profile$suffix.js", array( 'jquery', 'password-strength-meter' ), '20110628', 1 );
 
-       $scripts->add( 'admin-bar', "/wp-includes/js/admin-bar$suffix.js", false, '20110131' );
-       $scripts->add_data( 'admin-bar', 'group', 1 );
+       $scripts->add( 'admin-bar', "/wp-includes/js/admin-bar$suffix.js", false, '20111130', 1 );
 
-       $scripts->add( 'wplink', "/wp-includes/js/tinymce/plugins/wplink/js/wplink$suffix.js", array( 'jquery', 'wpdialogs' ), '20110528' );
-       $scripts->add_data( 'wplink', 'group', 1 );
+       $scripts->add( 'wplink', "/wp-includes/js/wplink$suffix.js", array( 'jquery', 'wpdialogs' ), '20111128', 1 );
        $scripts->localize( 'wplink', 'wpLinkL10n', array(
                'title' => __('Insert/edit link'),
                'update' => __('Update'),
                'save' => __('Add Link'),
                'noTitle' => __('(no title)'),
-               'noMatchesFound' => __('No matches found.'),
-               'l10n_print_after' => 'try{convertEntities(wpLinkL10n);}catch(e){};',
+               'noMatchesFound' => __('No matches found.')
        ) );
 
-       $scripts->add( 'wpdialogs', "/wp-includes/js/tinymce/plugins/wpdialogs/js/wpdialog$suffix.js", array( 'jquery-ui-dialog' ), '20110528' );
-       $scripts->add_data( 'wpdialogs', 'group', 1 );
+       $scripts->add( 'wpdialogs', "/wp-includes/js/tinymce/plugins/wpdialogs/js/wpdialog$suffix.js", array( 'jquery-ui-dialog' ), '20110528', 1 );
+
+       $scripts->add( 'wpdialogs-popup', "/wp-includes/js/tinymce/plugins/wpdialogs/js/popup$suffix.js", array( 'wpdialogs' ), '20110421', 1 );
+
+       $scripts->add( 'word-count', "/wp-admin/js/word-count$suffix.js", array( 'jquery' ), '20110515', 1 );
 
-       $scripts->add( 'wpdialogs-popup', "/wp-includes/js/tinymce/plugins/wpdialogs/js/popup$suffix.js", array( 'wpdialogs' ), '20110421' );
-       $scripts->add_data( 'wpdialogs-popup', 'group', 1 );
+       $scripts->add( 'media-upload', "/wp-admin/js/media-upload$suffix.js", array( 'thickbox' ), '20110930', 1 );
+
+       $scripts->add( 'hoverIntent', "/wp-includes/js/hoverIntent$suffix.js", array('jquery'), '20090102', 1 );
 
        if ( is_admin() ) {
                $scripts->add( 'ajaxcat', "/wp-admin/js/cat$suffix.js", array( 'wp-lists' ), '20090102' );
                $scripts->add_data( 'ajaxcat', 'group', 1 );
                $scripts->localize( 'ajaxcat', 'catL10n', array(
                        'add' => esc_attr(__('Add')),
-                       'how' => __('Separate multiple categories with commas.'),
-                       'l10n_print_after' => 'try{convertEntities(catL10n);}catch(e){};'
+                       'how' => __('Separate multiple categories with commas.')
                ) );
 
-               $scripts->add( 'admin-categories', "/wp-admin/js/categories$suffix.js", array('wp-lists'), '20091201' );
-               $scripts->add_data( 'admin-categories', 'group', 1 );
+               $scripts->add( 'admin-categories', "/wp-admin/js/categories$suffix.js", array('wp-lists'), '20091201', 1 );
 
-               $scripts->add( 'admin-tags', "/wp-admin/js/tags$suffix.js", array('jquery', 'wp-ajax-response'), '20110429' );
-               $scripts->add_data( 'admin-tags', 'group', 1 );
+               $scripts->add( 'admin-tags', "/wp-admin/js/tags$suffix.js", array('jquery', 'wp-ajax-response'), '20110429', 1 );
                $scripts->localize( 'admin-tags', 'tagsl10n', array(
                        'noPerm' => __('You do not have permission to do that.'),
-                       'broken' => __('An unidentified error has occurred.'),
-                       'l10n_print_after' => 'try{convertEntities(tagsl10n);}catch(e){};'
+                       'broken' => __('An unidentified error has occurred.')
                ));
 
-               $scripts->add( 'admin-custom-fields', "/wp-admin/js/custom-fields$suffix.js", array('wp-lists'), '20110429' );
-               $scripts->add_data( 'admin-custom-fields', 'group', 1 );
+               $scripts->add( 'admin-custom-fields', "/wp-admin/js/custom-fields$suffix.js", array('wp-lists'), '20110429', 1 );
 
-               $scripts->add( 'admin-comments', "/wp-admin/js/edit-comments$suffix.js", array('wp-lists', 'jquery-ui-resizable', 'quicktags', 'jquery-query'), '20110602' );
-               $scripts->add_data( 'admin-comments', 'group', 1 );
+               $scripts->add( 'admin-comments', "/wp-admin/js/edit-comments$suffix.js", array('wp-lists', 'quicktags', 'jquery-query'), '20111115', 1 );
                $scripts->localize( 'admin-comments', 'adminCommentsL10n', array(
                        'hotkeys_highlight_first' => isset($_GET['hotkeys_highlight_first']),
                        'hotkeys_highlight_last' => isset($_GET['hotkeys_highlight_last']),
@@ -321,22 +307,14 @@ function wp_default_scripts( &$scripts ) {
                        'reply' => __( 'Reply' )
                ) );
 
-               $scripts->add( 'xfn', "/wp-admin/js/xfn$suffix.js", array('jquery'), '20110524' );
-               $scripts->add_data( 'xfn', 'group', 1 );
+               $scripts->add( 'xfn', "/wp-admin/js/xfn$suffix.js", array('jquery'), '20110524', 1 );
 
-               $scripts->add( 'postbox', "/wp-admin/js/postbox$suffix.js", array('jquery-ui-sortable'), '20110612' );
-               $scripts->add_data( 'postbox', 'group', 1 );
+               $scripts->add( 'postbox', "/wp-admin/js/postbox$suffix.js", array('jquery-ui-sortable'), '20111009a', 1 );
 
-               $scripts->add( 'post', "/wp-admin/js/post$suffix.js", array('suggest', 'wp-lists', 'postbox'), '20110524' );
-               $scripts->add_data( 'post', 'group', 1 );
+               $scripts->add( 'post', "/wp-admin/js/post$suffix.js", array('suggest', 'wp-lists', 'postbox'), '20111124', 1 );
                $scripts->localize( 'post', 'postL10n', array(
-                       'tagsUsed' =>  __('Tags used on this post:'),
-                       'add' => esc_attr(__('Add')),
-                       'addTag' => esc_attr(__('Add new Tag')),
-                       'separate' => __('Separate tags with commas'),
                        'ok' => __('OK'),
                        'cancel' => __('Cancel'),
-                       'edit' => __('Edit'),
                        'publishOn' => __('Publish on:'),
                        'publishOnFuture' =>  __('Schedule for:'),
                        'publishOnPast' => __('Published on:'),
@@ -352,100 +330,73 @@ function wp_default_scripts( &$scripts ) {
                        'publicSticky' => __('Public, Sticky'),
                        'password' => __('Password Protected'),
                        'privatelyPublished' => __('Privately Published'),
-                       'published' => __('Published'),
-                       'l10n_print_after' => 'try{convertEntities(postL10n);}catch(e){};'
+                       'published' => __('Published')
                ) );
 
-               $scripts->add( 'link', "/wp-admin/js/link$suffix.js", array('wp-lists', 'postbox'), '20110524' );
-               $scripts->add_data( 'link', 'group', 1 );
+               $scripts->add( 'link', "/wp-admin/js/link$suffix.js", array('wp-lists', 'postbox'), '20110524', 1 );
 
                $scripts->add( 'comment', "/wp-admin/js/comment$suffix.js", array('jquery'), '20110429' );
                $scripts->add_data( 'comment', 'group', 1 );
                $scripts->localize( 'comment', 'commentL10n', array(
-                       'cancel' => __('Cancel'),
-                       'edit' => __('Edit'),
-                       'submittedOn' => __('Submitted on:'),
-                       'l10n_print_after' => 'try{convertEntities(commentL10n);}catch(e){};'
+                       'submittedOn' => __('Submitted on:')
                ) );
 
-               $scripts->add( 'admin-gallery', "/wp-admin/js/gallery$suffix.js", array( 'jquery-ui-sortable' ), '20110414' );
-
-               $scripts->add( 'media-upload', "/wp-admin/js/media-upload$suffix.js", array( 'thickbox' ), '20110425' );
-               $scripts->add_data( 'media-upload', 'group', 1 );
-
-               $scripts->add( 'admin-widgets', "/wp-admin/js/widgets$suffix.js", array( 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-ui-droppable' ), '20110601' );
-               $scripts->add_data( 'admin-widgets', 'group', 1 );
+               $scripts->add( 'admin-gallery', "/wp-admin/js/gallery$suffix.js", array( 'jquery-ui-sortable' ), '20110930' );
 
-               $scripts->add( 'word-count', "/wp-admin/js/word-count$suffix.js", array( 'jquery' ), '20110515' );
-               $scripts->add_data( 'word-count', 'group', 1 );
+               $scripts->add( 'admin-widgets', "/wp-admin/js/widgets$suffix.js", array( 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-ui-droppable' ), '20110925', 1 );
 
-               $scripts->add( 'theme', "/wp-admin/js/theme$suffix.js", array( 'thickbox' ), '20110118' );
-               $scripts->add_data( 'theme', 'group', 1 );
+               $scripts->add( 'theme', "/wp-admin/js/theme$suffix.js", array( 'thickbox' ), '20110118', 1 );
 
-               $scripts->add( 'theme-preview', "/wp-admin/js/theme-preview$suffix.js", array( 'thickbox', 'jquery' ), '20100407' );
-               $scripts->add_data( 'theme-preview', 'group', 1 );
+               $scripts->add( 'theme-preview', "/wp-admin/js/theme-preview$suffix.js", array( 'thickbox', 'jquery' ), '20100407', 1 );
 
-               $scripts->add( 'inline-edit-post', "/wp-admin/js/inline-edit-post$suffix.js", array( 'jquery', 'suggest' ), '20110609' );
-               $scripts->add_data( 'inline-edit-post', 'group', 1 );
+               $scripts->add( 'inline-edit-post', "/wp-admin/js/inline-edit-post$suffix.js", array( 'jquery', 'suggest' ), '20111129', 1 );
                $scripts->localize( 'inline-edit-post', 'inlineEditL10n', array(
                        'error' => __('Error while saving the changes.'),
                        'ntdeltitle' => __('Remove From Bulk Edit'),
-                       'notitle' => __('(no title)'),
-                       'l10n_print_after' => 'try{convertEntities(inlineEditL10n);}catch(e){};'
+                       'notitle' => __('(no title)')
                ) );
 
-               $scripts->add( 'inline-edit-tax', "/wp-admin/js/inline-edit-tax$suffix.js", array( 'jquery' ), '20110609' );
-               $scripts->add_data( 'inline-edit-tax', 'group', 1 );
+               $scripts->add( 'inline-edit-tax', "/wp-admin/js/inline-edit-tax$suffix.js", array( 'jquery' ), '20110609', 1 );
                $scripts->localize( 'inline-edit-tax', 'inlineEditL10n', array(
-                       'error' => __('Error while saving the changes.'),
-                       'l10n_print_after' => 'try{convertEntities(inlineEditL10n);}catch(e){};'
+                       'error' => __('Error while saving the changes.')
                ) );
 
-               $scripts->add( 'plugin-install', "/wp-admin/js/plugin-install$suffix.js", array( 'jquery', 'thickbox' ), '20110113' );
-               $scripts->add_data( 'plugin-install', 'group', 1 );
+               $scripts->add( 'plugin-install', "/wp-admin/js/plugin-install$suffix.js", array( 'jquery', 'thickbox' ), '20110113', 1 );
                $scripts->localize( 'plugin-install', 'plugininstallL10n', array(
                        'plugin_information' => __('Plugin Information:'),
-                       'ays' => __('Are you sure you want to install this plugin?'),
-                       'l10n_print_after' => 'try{convertEntities(plugininstallL10n);}catch(e){};'
+                       'ays' => __('Are you sure you want to install this plugin?')
                ) );
 
                $scripts->add( 'farbtastic', '/wp-admin/js/farbtastic.js', array('jquery'), '1.2' );
 
-               $scripts->add( 'dashboard', "/wp-admin/js/dashboard$suffix.js", array( 'jquery', 'admin-comments', 'postbox' ), '20110524' );
-               $scripts->add_data( 'dashboard', 'group', 1 );
-
-               $scripts->add( 'hoverIntent', "/wp-includes/js/hoverIntent$suffix.js", array('jquery'), '20090102' );
-               $scripts->add_data( 'hoverIntent', 'group', 1 );
+               $scripts->add( 'dashboard', "/wp-admin/js/dashboard$suffix.js", array( 'jquery', 'admin-comments', 'postbox' ), '20111123', 1 );
 
                $scripts->add( 'list-revisions', "/wp-includes/js/wp-list-revisions$suffix.js", null, '20091223' );
 
-               $scripts->add( 'media', "/wp-admin/js/media$suffix.js", array( 'jquery-ui-draggable' ), '20101022' );
-               $scripts->add_data( 'media', 'group', 1 );
+               $scripts->add( 'media', "/wp-admin/js/media$suffix.js", array( 'jquery-ui-draggable' ), '20101022', 1 );
 
-               $scripts->add( 'image-edit', "/wp-admin/js/image-edit$suffix.js", array('jquery', 'json2', 'imgareaselect'), '20110524' );
-               $scripts->add_data( 'image-edit', 'group', 1 );
+               $scripts->add( 'image-edit', "/wp-admin/js/image-edit$suffix.js", array('jquery', 'json2', 'imgareaselect'), '20110927', 1 );
+               $scripts->localize( 'image-edit', 'imageEditL10n', array(
+                       'error' => __( 'Could not load the preview image. Please reload the page and try again.' )
+               ));
 
-               $scripts->add( 'set-post-thumbnail', "/wp-admin/js/set-post-thumbnail$suffix.js", array( 'jquery' ), '20100518' );
-               $scripts->add_data( 'set-post-thumbnail', 'group', 1 );
+               $scripts->add( 'set-post-thumbnail', "/wp-admin/js/set-post-thumbnail$suffix.js", array( 'jquery' ), '20100518', 1 );
                $scripts->localize( 'set-post-thumbnail', 'setPostThumbnailL10n', array(
                        'setThumbnail' => __( 'Use as featured image' ),
                        'saving' => __( 'Saving...' ),
                        'error' => __( 'Could not set that as the thumbnail image. Try a different attachment.' ),
-                       'done' => __( 'Done' ),
-                       'l10n_print_after' => 'try{convertEntities(setPostThumbnailL10n);}catch(e){};'
+                       'done' => __( 'Done' )
                ) );
 
                // Navigation Menus
-               $scripts->add( 'nav-menu', "/wp-admin/js/nav-menu$suffix.js", array('jquery-ui-sortable'), '20110524' );
+               $scripts->add( 'nav-menu', "/wp-admin/js/nav-menu$suffix.js", array('jquery-ui-sortable'), '20111115' );
                $scripts->localize( 'nav-menu', 'navMenuL10n', array(
                        'noResultsFound' => _x('No results found.', 'search results'),
                        'warnDeleteMenu' => __( "You are about to permanently delete this menu. \n 'Cancel' to stop, 'OK' to delete." ),
-                       'saveAlert' => __('The changes you made will be lost if you navigate away from this page.'),
-                       'l10n_print_after' => 'try{convertEntities(navMenuL10n);}catch(e){};'
+                       'saveAlert' => __('The changes you made will be lost if you navigate away from this page.')
                ) );
 
-               $scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array('farbtastic'), '20110511' );
-               $scripts->add_data( 'custom-background', 'group', 1 );
+               $scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array('farbtastic'), '20110511', 1 );
        }
 }
 
@@ -474,48 +425,39 @@ function wp_default_styles( &$styles ) {
        $styles->content_url = defined('WP_CONTENT_URL')? WP_CONTENT_URL : '';
        $styles->default_version = get_bloginfo( 'version' );
        $styles->text_direction = function_exists( 'is_rtl' ) && is_rtl() ? 'rtl' : 'ltr';
-       $styles->default_dirs = array('/wp-admin/');
+       $styles->default_dirs = array('/wp-admin/', '/wp-includes/css/');
 
        $suffix = defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ? '.dev' : '';
 
-       $rtl_styles = array( 'wp-admin', 'global', 'colors', 'colors-fresh', 'colors-classic', 'dashboard', 'ie', 'install', 'login', 'media', 'theme-editor', 'upload', 'widgets', 'press-this', 'plugin-install', 'nav-menu', 'farbtastic', 'admin-bar', 'wplink', 'theme-install' );
+       $rtl_styles = array( 'wp-admin', 'ie', 'media', 'admin-bar', 'wplink' );
        // Any rtl stylesheets that don't have a .dev version for ltr
        $no_suffix = array( 'farbtastic' );
 
-       $styles->add( 'wp-admin', "/wp-admin/css/wp-admin$suffix.css", array(), '20110627' );
+       $styles->add( 'wp-admin', "/wp-admin/css/wp-admin$suffix.css", array(), '20111208' );
 
-       $styles->add( 'ie', "/wp-admin/css/ie$suffix.css", array(), '20110627' );
+       $styles->add( 'ie', "/wp-admin/css/ie$suffix.css", array(), '20111130' );
        $styles->add_data( 'ie', 'conditional', 'lte IE 7' );
 
        // all colors stylesheets need to have the same query strings (cache manifest compat)
-       $colors_version = '20110703';
+       $colors_version = '20111206';
 
        // Register "meta" stylesheet for admin colors. All colors-* style sheets should have the same version string.
-       $styles->add( 'colors', true, array(), $colors_version );
+       $styles->add( 'colors', true, array('wp-admin'), $colors_version );
 
        // do not refer to these directly, the right one is queued by the above "meta" colors handle
-       $styles->add( 'colors-fresh', "/wp-admin/css/colors-fresh$suffix.css", array(), $colors_version );
-       $styles->add( 'colors-classic', "/wp-admin/css/colors-classic$suffix.css", array(), $colors_version );
-
-       $styles->add( 'ms', "/wp-admin/css/ms$suffix.css", array(), '20110623' );
-       $styles->add( 'global', "/wp-admin/css/global$suffix.css", array(), '20110627' );
-       $styles->add( 'media', "/wp-admin/css/media$suffix.css", array(), '20110614' );
-       $styles->add( 'widgets', "/wp-admin/css/widgets$suffix.css", array(), '20110606' );
-       $styles->add( 'dashboard', "/wp-admin/css/dashboard$suffix.css", array(), '20110627' );
-       $styles->add( 'install', "/wp-admin/css/install$suffix.css", array(), '20110602' ); // Readme as well
-       $styles->add( 'theme-editor', "/wp-admin/css/theme-editor$suffix.css", array(), '20110602' );
-       $styles->add( 'press-this', "/wp-admin/css/press-this$suffix.css", array(), '20110611a' );
-       $styles->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css', array(), '20090514' );
-       $styles->add( 'login', "/wp-admin/css/login$suffix.css", array(), '20110610' );
-       $styles->add( 'plugin-install', "/wp-admin/css/plugin-install$suffix.css", array(), '20110628' );
-       $styles->add( 'theme-install', "/wp-admin/css/theme-install$suffix.css", array(), '20110506' );
-       $styles->add( 'farbtastic', '/wp-admin/css/farbtastic.css', array(), '1.3u' );
+       $styles->add( 'colors-fresh', "/wp-admin/css/colors-fresh$suffix.css", array('wp-admin'), $colors_version );
+       $styles->add( 'colors-classic', "/wp-admin/css/colors-classic$suffix.css", array('wp-admin'), $colors_version );
+
+       $styles->add( 'media', "/wp-admin/css/media$suffix.css", array(), '20111119' );
+       $styles->add( 'install', "/wp-admin/css/install$suffix.css", array(), '20111117' ); // Readme as well
+       $styles->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css', array(), '20111117' );
+       $styles->add( 'farbtastic', '/wp-admin/css/farbtastic.css', array(), '1.3u1' );
        $styles->add( 'jcrop', '/wp-includes/js/jcrop/jquery.Jcrop.css', array(), '0.9.8' );
        $styles->add( 'imgareaselect', '/wp-includes/js/imgareaselect/imgareaselect.css', array(), '0.9.1' );
-       $styles->add( 'nav-menu', "/wp-admin/css/nav-menu$suffix.css", array(), '20110611' );
-       $styles->add( 'admin-bar', "/wp-includes/css/admin-bar$suffix.css", array(), '20110622' );
-       $styles->add( 'wp-jquery-ui-dialog', "/wp-includes/css/jquery-ui-dialog$suffix.css", array(), '20101224' );
-       $styles->add( 'wplink', "/wp-includes/js/tinymce/plugins/wplink/css/wplink$suffix.css", array(), '20101224' );
+       $styles->add( 'admin-bar', "/wp-includes/css/admin-bar$suffix.css", array(), '20111209' );
+       $styles->add( 'wp-jquery-ui-dialog', "/wp-includes/css/jquery-ui-dialog$suffix.css", array(), '20111107' );
+       $styles->add( 'editor-buttons', "/wp-includes/css/editor-buttons$suffix.css", array(), '20111114' );
+       $styles->add( 'wp-pointer', "/wp-includes/css/wp-pointer$suffix.css", array(), '20111205' );
 
        foreach ( $rtl_styles as $rtl_style ) {
                $styles->add_data( $rtl_style, 'rtl', true );
@@ -529,7 +471,7 @@ function wp_default_styles( &$styles ) {
  *
  * @since 2.3.1
  *
- * @param array $js_array JavaScript scripst array
+ * @param array $js_array JavaScript scripts array
  * @return array Reordered array, if needed.
  */
 function wp_prototype_before_jquery( $js_array ) {
@@ -561,8 +503,7 @@ function wp_just_in_time_script_localization() {
        wp_localize_script( 'autosave', 'autosaveL10n', array(
                'autosaveInterval' => AUTOSAVE_INTERVAL,
                'savingText' => __('Saving Draft&#8230;'),
-               'saveAlert' => __('The changes you made will be lost if you navigate away from this page.'),
-               'l10n_print_after' => 'try{convertEntities(autosaveL10n);}catch(e){};'
+               'saveAlert' => __('The changes you made will be lost if you navigate away from this page.')
        ) );
 
 }
@@ -635,7 +576,6 @@ function print_head_scripts() {
                $wp_scripts = new WP_Scripts();
 
        script_concat_settings();
-       $wp_scripts->do_items( 'l10n' );
        $wp_scripts->do_concat = $concatenate_scripts;
        $wp_scripts->do_head_items();
 
@@ -647,16 +587,13 @@ function print_head_scripts() {
 }
 
 /**
- * Prints the scripts that were queued for the footer on admin pages.
+ * Prints the scripts that were queued for the footer or too late for the HTML head.
  *
  * @since 2.8
  */
 function print_footer_scripts() {
        global $wp_scripts, $concatenate_scripts;
 
-       if ( ! did_action('wp_print_footer_scripts') )
-               do_action('wp_print_footer_scripts');
-
        if ( !is_a($wp_scripts, 'WP_Scripts') )
                return array(); // No need to run if not instantiated.
 
@@ -671,6 +608,9 @@ function print_footer_scripts() {
        return $wp_scripts->done;
 }
 
+/**
+ * @internal use
+ */
 function _print_scripts() {
        global $wp_scripts, $compress_scripts;
 
@@ -681,8 +621,8 @@ function _print_scripts() {
        if ( !empty($wp_scripts->concat) ) {
 
                if ( !empty($wp_scripts->print_code) ) {
-                       echo "<script type='text/javascript'>\n";
-                       echo "/* <![CDATA[ */\n";
+                       echo "\n<script type='text/javascript'>\n";
+                       echo "/* <![CDATA[ */\n"; // not needed in HTML 5
                        echo $wp_scripts->print_code;
                        echo "/* ]]> */\n";
                        echo "</script>\n";
@@ -718,12 +658,22 @@ function wp_print_head_scripts() {
 }
 
 /**
- * Prints the scripts that were queued for the footer on the front end.
+ * Private, for use in *_footer_scripts hooks
+ *
+ * @since 3.3
+ */
+function _wp_footer_scripts() {
+       print_late_styles();
+       print_footer_scripts();
+}
+
+/**
+ * Hooks to print the scripts and styles in the footer.
  *
  * @since 2.8
  */
 function wp_print_footer_scripts() {
-       return print_footer_scripts();
+       do_action('wp_print_footer_scripts');
 }
 
 /**
@@ -738,6 +688,11 @@ function wp_enqueue_scripts() {
        do_action('wp_enqueue_scripts');
 }
 
+/**
+ * Prints the styles queue in the HTML head on admin pages.
+ *
+ * @since 2.8
+ */
 function print_admin_styles() {
        global $wp_styles, $concatenate_scripts, $compress_css;
 
@@ -752,23 +707,66 @@ function print_admin_styles() {
 
        $wp_styles->do_items(false);
 
-       if ( apply_filters('print_admin_styles', true) ) {
-               if ( !empty($wp_styles->concat) ) {
-                       $dir = $wp_styles->text_direction;
-                       $ver = md5("$wp_styles->concat_version{$dir}");
-                       $href = $wp_styles->base_url . "/wp-admin/load-styles.php?c={$zip}&dir={$dir}&load=" . trim($wp_styles->concat, ', ') . "&ver=$ver";
-                       echo "<link rel='stylesheet' href='" . esc_attr($href) . "' type='text/css' media='all' />\n";
-               }
+       if ( apply_filters('print_admin_styles', true) )
+               _print_styles();
 
-               if ( !empty($wp_styles->print_html) )
-                       echo $wp_styles->print_html;
-       }
+       $wp_styles->reset();
+       return $wp_styles->done;
+}
+
+/**
+ * Prints the styles that were queued too late for the HTML head.
+ *
+ * @since 3.3
+ */
+function print_late_styles() {
+       global $wp_styles, $concatenate_scripts;
+
+       if ( !is_a($wp_styles, 'WP_Styles') )
+               return;
 
-       $wp_styles->do_concat = false;
-       $wp_styles->concat = $wp_styles->concat_version = $wp_styles->print_html = '';
+       $wp_styles->do_concat = $concatenate_scripts;
+       $wp_styles->do_footer_items();
+
+       if ( apply_filters('print_late_styles', true) )
+               _print_styles();
+
+       $wp_styles->reset();
        return $wp_styles->done;
 }
 
+/**
+ * @internal use
+ */
+function _print_styles() {
+       global $wp_styles, $compress_css;
+
+       $zip = $compress_css ? 1 : 0;
+       if ( $zip && defined('ENFORCE_GZIP') && ENFORCE_GZIP )
+               $zip = 'gzip';
+
+       if ( !empty($wp_styles->concat) ) {
+               $dir = $wp_styles->text_direction;
+               $ver = md5("$wp_styles->concat_version{$dir}");
+               $href = $wp_styles->base_url . "/wp-admin/load-styles.php?c={$zip}&dir={$dir}&load=" . trim($wp_styles->concat, ', ') . "&ver=$ver";
+               echo "<link rel='stylesheet' href='" . esc_attr($href) . "' type='text/css' media='all' />\n";
+
+               if ( !empty($wp_styles->print_code) ) {
+                       echo "<style type='text/css'>\n";
+                       echo $wp_styles->print_code;
+                       echo "\n</style>\n";
+               }
+       }
+
+       if ( !empty($wp_styles->print_html) )
+               echo $wp_styles->print_html;
+}
+
+/**
+ * Determine the concatenation and compression settings for scripts and styles.
+ *
+ * @since 2.8
+ */
 function script_concat_settings() {
        global $concatenate_scripts, $compress_scripts, $compress_css;