getArches(); // Find all the ebuilds that are missing ebuild arch $sql = "SELECT id, metadata FROM missing_arch;"; $arr = $db->getAssoc($sql); if($verbose) shell::msg(count($arr)." ebuilds to check"); // Get the arches from the database $db_arches = $db->getAssoc("SELECT name, id FROM arch;"); foreach($arr as $ebuild_id => $keywords) { if(!empty($keywords)) $arr = arrKeywords($keywords, $arr_arches); else { $arr = array(); } if(count($arr)) { foreach($arr as $arch => $status) { if($db_arches[$arch]) { $arr_insert = array( 'ebuild' => $ebuild_id, 'arch' => $db_arches[$arch], 'status' => $status, ); $db->autoExecute('ebuild_arch', $arr_insert, MDB2_AUTOQUERY_INSERT); } } } } /** * Create an array of the arch keywords * * @param string keywords * @return array */ function arrKeywords($str, $arches) { $arr = explode(' ', $str); $arr_keywords = array(); if(count($arr)) { // If it has -* at all, set them all to -arch by default if(in_array('-*', $arr)) { foreach($arches as $name) { $arr_keywords[$name] = 2; } } foreach($arr as $name) { if($name[0] == '~' || $name[0] == '-') $arch = substr($name, 1); else $arch = $name; if($name[0] == '~') { $arr_keywords[$arch] = 1; } elseif($name[0] == '-') { $arr_keywords[$arch] = 2; } else { $arr_keywords[$arch] = 0; } } } ksort($arr_keywords); return $arr_keywords; } ?>