--- modules\translation\translation.module.orig	Fri Sep 10 02:01:48 2010
+++ modules\translation\translation.module	Sun Sep 12 15:24:50 2010
@@ -384,7 +384,7 @@
     if (!isset($translations[$tnid])) {
       $translations[$tnid] = array();
       $result = db_select('node', 'n')
-        ->fields('n', array('nid', 'title', 'language'))
+        ->fields('n', array('nid', 'type', 'uid', 'status', 'title', 'language'))
         ->condition('n.tnid', $tnid)
         ->addTag('node_access')
         ->execute();
@@ -435,8 +435,11 @@
  */
 function translation_language_switch_links_alter(array &$links, $type, $path) {
   if ($type == LANGUAGE_TYPE_INTERFACE && $paths = translation_path_get_translations($path)) {
+    $path = explode('/', $path);
+    $node = node_load($path[1]);
+    $translations = translation_node_get_translations($node->tnid);
     foreach ($links as $langcode => $link) {
-      if (isset($paths[$langcode])) {
+      if (isset($paths[$langcode]) && node_access('view', $translations[$langcode])) {
         // Translation in a different node.
         $links[$langcode]['href'] = $paths[$langcode];
       }
