當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Set::check方法代碼示例

本文整理匯總了PHP中Set::check方法的典型用法代碼示例。如果您正苦於以下問題:PHP Set::check方法的具體用法?PHP Set::check怎麽用?PHP Set::check使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Set的用法示例。


在下文中一共展示了Set::check方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: returnSection

 public function returnSection($section, $locale = 'en_us')
 {
     $en_us = $this->returnEnSection($section);
     //get the us version of the section first
     if ($locale == 'en_us') {
         return $en_us;
     }
     //query up the languages
     if (Set::check(self::$sections, $section . "." . $locale)) {
         return self::$sections[$section][$locale];
     } else {
         $old_locale = $this->locale;
         $this->setLanguage($locale);
         $lang = $this->find("all", array("conditions" => array("Phrase.section" => $section)));
         $this->setLanguage($old_locale);
         foreach ($en_us as $k => $v) {
             $p = Set::extract("/Phrase[token=/" . $k . "/i]/value", $lang);
             if (count($p) > 0) {
                 $en_us[$k] = $p[0];
             }
         }
         //cache the data
         self::$sections[$section][$locale] = $en_us;
     }
     return self::$sections[$section][$locale];
 }
開發者ID:josephbergdoll,項目名稱:berrics,代碼行數:26,代碼來源:Phrase.php

示例2: index

 function index()
 {
     $this->Phrase->recursive = 0;
     $phrases = $this->paginate('Phrase');
     $this->set('phrases', $phrases);
     //get the list of locales
     $this->loadModel("Locale");
     //$locales = $this->Locale->find("list",array("fields"=>array("Locale.locale","Locale.name"),"order"=>array("name"=>"ASC")));
     $locales = Lang::localeList();
     $this->set("locales", $locales);
     //set the incoming locale to the session
     if (!empty($this->request->data)) {
         if (Set::check($this->request->data, "Phrase.selectLocale")) {
             $this->Session->write("ControlPanel.translate_locale", $this->request->data['Phrase']['selectLocale']);
         }
     }
     //get the locale from the session
     if ($this->Session->check("ControlPanel.translate_locale")) {
         $translate_locale = $this->Session->read("ControlPanel.translate_locale");
     } else {
         $translate_locale = 'en_us';
         $this->request->data['Phrase']['selectLocale'] = 'en_us';
     }
     $this->request->data['Phrase']['selectLocale'] = $translate_locale;
     $this->Phrase->setLanguage($translate_locale);
     //get the trnaslated phrases
     $ids = Set::extract("/Phrase/id", $phrases);
     //pr($this->Session->read());
     $locale_phrases = $this->Phrase->find('all', array("conditions" => array("Phrase.id" => $ids)));
     $this->set("locale_phrases", $locale_phrases);
 }
開發者ID:josephbergdoll,項目名稱:berrics,代碼行數:31,代碼來源:PhrasesController.php

示例3: specialValues

 function specialValues($fieldName, $options = array())
 {
     $this->setEntity($fieldName);
     $specialValues = array('true' => true, 'false' => false, 'null' => null, 'undefined' => null);
     $spcFieldOpt = array('label' => __('Special value', true), 'options' => array_combine(array_keys($specialValues), array_keys($specialValues)), 'empty' => __('none', true));
     $hasSpecial = null;
     $value = $this->value($fieldName);
     $view =& ClassRegistry::getObject('view');
     $entity = $view->entity();
     foreach ($this->specialValues as $spc => $val) {
         if ($value === $val) {
             $hasSpecial = $spc;
         }
     }
     if (!$hasSpecial && !empty($entity) && (empty($this->data) || !Set::check($this->data, join('.', $entity)))) {
         $hasSpecial = 'undefined';
     }
     if ($hasSpecial) {
         $options['value'] = '';
         $spcFieldOpt['value'] = $hasSpecial;
     }
     if (empty($options['after'])) {
         $options['after'] = '';
     }
     $options['after'] .= $this->Form->input($fieldName . '_spc', $spcFieldOpt);
     return $this->Form->input($fieldName, $options);
 }
開發者ID:kevthunder,項目名稱:arch,代碼行數:27,代碼來源:spark_form.php

示例4: afterFind

 function afterFind($results, $primary = false)
 {
     if ($primary == true) {
         if (Set::check($results, '0.0')) {
             $fieldName = key($results[0][0]);
             foreach ($results as $key => $value) {
                 $results[$key][$this->alias][$fieldName] = $value[0][$fieldName];
                 unset($results[$key][0]);
             }
         }
     }
     return $results;
 }
開發者ID:maverick2041,項目名稱:wpkgexpress,代碼行數:13,代碼來源:app_model.php

示例5: tagcloud

 /**
  * Return tags from database.
  *
  * @return array
  */
 function tagcloud(&$controller)
 {
     $term_id = Configure::read('Tagcloud.term');
     $query = "SELECT count(*) as tag_count, Term.title, Term.id, Term.slug\n            FROM nodes_terms as nt\n            JOIN terms as Term ON Term.id = nt.term_id\n            WHERE Term.vocabulary_id = {$term_id}\n            GROUP BY nt.term_id";
     $tags = ClassRegistry::init('Term')->query($query);
     if (Set::check($tags, '0.0')) {
         $fieldName = key($tags[0][0]);
         foreach ($tags as $key => $value) {
             $tags[$key]['Term'][$fieldName] = $value[0][$fieldName];
             unset($tags[$key][0]);
         }
     }
     return $tags;
 }
開發者ID:andruu,項目名稱:Croogo-Tagcloud-Plugin,代碼行數:19,代碼來源:tagcloud_hook.php

示例6: view

 /**
  * view method
  *
  * @throws NotFoundException
  * @param string $id
  * @return void
  */
 public function view($id = null)
 {
     if (!$this->Group->exists($id)) {
         throw new NotFoundException(__('Usuário Inválido!'));
     }
     $options = array('conditions' => array('Group.' . $this->Group->primaryKey => $id));
     $this->set('group', $this->Group->find('first', $options));
     //Obtenção do aroId do grupo selecionado.
     $aro = $this->Acl->Aro->find('first', array('conditions' => array('Aro.model' => 'Group', 'Aro.foreign_key' => $id)));
     $aroId = $aro['Aro']['id'];
     //Obtendo os membros do grupo selecionado (Pode ser usuarios e grupos).
     $members = $this->Acl->Aro->query('SELECT * FROM aros AS Aro
                                                    INNER JOIN users AS User ON Aro.foreign_key = User.id
                                                    WHERE Aro.parent_id = ' . $aroId);
     $this->set('members', $members);
     //debug($members);
     //lista de usuários.
     $this->loadModel('User');
     $users = $this->User->find('list');
     $this->set(compact('users'));
     //Obtendo as permissões do grupo.
     $this->loadModel('Page');
     $pages = $this->Page->find('all', array('conditions' => array('Page.enable' => 1), 'order' => 'Page.name'));
     //debug($pages);
     $lista = array();
     $aros_aco_id = NULL;
     $aco_parent_id = NULL;
     foreach ($pages as $page) {
         //Check permissão
         $check_permission = $this->Acl->check(array('Group' => array('id' => $id)), array('Page' => array('id' => $page['Page']['id'])));
         //.....
         $direct_permission = $this->Acl->Aco->Permission->find('first', array('conditions' => array('Aco.model' => 'Page', 'Aco.foreign_key' => $page['Page']['id'], 'Aro.model' => 'Group', 'Aro.foreign_key' => $id)));
         //debug($direct_permission);
         if (Set::check($direct_permission, 'Permission')) {
             $aco_parent_id = $direct_permission['Aco']['parent_id'];
             $aros_aco_id = $direct_permission['Permission']['id'];
             $direct_permission = true;
         }
         $page_acos = $this->Acl->Aco->find('first', array('conditions' => array('Aco.model' => 'Page', 'Aco.foreign_key' => $page['Page']['id']), 'fields' => 'Aco.parent_id'));
         $aco_parent_id = $page_acos['Aco']['parent_id'];
         //debug($aco_parent_id);
         $lista[] = array('aco_parent_id' => $aco_parent_id, 'aros_aco_id' => $aros_aco_id, 'page_id' => $page['Page']['id'], 'pageName' => $page['Page']['name'], 'check_permission' => $check_permission, 'direct_permission' => $direct_permission);
         $aros_aco_id = NULL;
         $aco_parent_id = NULL;
     }
     $this->set('permissions', $lista);
     //debug($lista);
     //debug($this->Acl->Aco->find('all'));
 }
開發者ID:dfventura,項目名稱:Kakau,代碼行數:56,代碼來源:GroupsController.php

示例7: connect

 /**
  * Connects to the database. Options are specified in the $config instance variable.
  *
  * @return boolean Connected.
  * @throws MissingConnectionException
  */
 public function connect()
 {
     if ($this->connected !== true) {
         if (Set::check($this->config, 'login')) {
             $this->config = Set::insert($this->config, 'request.uri.user', Set::get($this->config, 'login'));
         }
         if (Set::check($this->config, 'password')) {
             $this->config = Set::insert($this->config, 'request.uri.pass', Set::get($this->config, 'password'));
         }
         try {
             $this->Socket = new HttpSocket($this->config);
             $this->connected = true;
         } catch (SocketException $e) {
             throw new MissingConnectionException(array('class' => $e->getMessage()));
         }
     }
     return $this->connected;
 }
開發者ID:riddhisoni1324,項目名稱:cakephp_fxchng,代碼行數:24,代碼來源:CouchDBSource.php

示例8: view

 /**
  * view method
  *
  * @throws NotFoundException
  * @param string $id
  * @return void
  */
 public function view($id = null)
 {
     if (!$this->User->exists($id)) {
         throw new NotFoundException(__('Usuário Inválido!'));
     }
     $options = array('conditions' => array('User.' . $this->User->primaryKey => $id));
     $this->set('user', $this->User->find('first', $options));
     //Obtendo os grupos que este usuário pertence.
     $belongs = $this->Acl->Aro->query("SELECT Aro.id, Aro.parent_id, parent.image_path, parent.name\n                                                       FROM aros AS Aro\n                                                       INNER JOIN ( SELECT aros.id, all_groups.image_path, all_groups.name \n                                                                    FROM aros \n                                                                    INNER JOIN ( SELECT groups.id, groups.image_path, groups.name FROM groups ) AS all_groups \n                                                                    ON aros.foreign_key = all_groups.id ) AS parent \n                                                       ON Aro.parent_id = parent.id                                                  \n                                                       WHERE Aro.model = 'User' AND Aro.foreign_key = " . $id);
     $this->set('belongs', $belongs);
     //debug($belongs);
     //lista de grupos.
     $this->loadModel('Group');
     $groups = $this->Group->find('list');
     $this->set(compact('groups'));
     //Obtendo as permissões do usuário.
     $this->loadModel('Page');
     $pages = $this->Page->find('all', array('conditions' => array('Page.enable' => 1), 'order' => 'Page.name'));
     //debug($pages);
     $lista = array();
     $aros_aco_id = NULL;
     $aco_parent_id = NULL;
     foreach ($pages as $page) {
         //Check permissão
         $check_permission = $this->Acl->check(array('User' => array('id' => $id)), array('Page' => array('id' => $page['Page']['id'])));
         //permissões diretas
         $direct_permission = $this->Acl->Aco->Permission->find('first', array('conditions' => array('Aco.model' => 'Page', 'Aco.foreign_key' => $page['Page']['id'], 'Aro.model' => 'User', 'Aro.foreign_key' => $id)));
         //debug($direct_permission);
         if (Set::check($direct_permission, 'Permission')) {
             $aco_parent_id = $direct_permission['Aco']['parent_id'];
             $aros_aco_id = $direct_permission['Permission']['id'];
             $direct_permission = true;
         }
         $page_acos = $this->Acl->Aco->find('first', array('conditions' => array('Aco.model' => 'Page', 'Aco.foreign_key' => $page['Page']['id']), 'fields' => 'Aco.parent_id'));
         $aco_parent_id = $page_acos['Aco']['parent_id'];
         //debug($aco_parent_id);
         $lista[] = array('aco_parent_id' => $aco_parent_id, 'aros_aco_id' => $aros_aco_id, 'page_id' => $page['Page']['id'], 'pageName' => $page['Page']['name'], 'check_permission' => $check_permission, 'direct_permission' => $direct_permission);
         $aros_aco_id = NULL;
         $aco_parent_id = NULL;
     }
     $this->set('permissions', $lista);
     //debug($lista);
     //debug($this->Acl->Aco->Permission->find('all'));
 }
開發者ID:dfventura,項目名稱:Kakau,代碼行數:51,代碼來源:UsersController.php

示例9: add

 /**
  * Add a menu item
  *
  * @param string $path dot separated path in the array.
  * @param array $options menu options array
  * @return void
  */
 public static function add($path, $options)
 {
     $pathE = explode('.', $path);
     $pathE = array_splice($pathE, 0, count($pathE) - 2);
     $parent = join('.', $pathE);
     if (!empty($parent) && !Set::check(self::$_items, $parent)) {
         $title = Inflector::humanize(end($pathE));
         $o = array('title' => $title);
         self::_setupOptions($o);
         self::add($parent, $o);
     }
     self::_setupOptions($options);
     $current = Set::extract($path, self::$_items);
     if (!empty($current)) {
         self::_replace(self::$_items, $path, $options);
     } else {
         self::$_items = Set::insert(self::$_items, $path, $options);
     }
 }
開發者ID:romaing,項目名稱:croogo-rg,代碼行數:26,代碼來源:CroogoNav.php

示例10: getMinimalData

 function getMinimalData(&$model, $fields, $data = null, $findOptions = array(), $priorityRes = true)
 {
     if (is_null($data)) {
         $data = $model->data;
     }
     //debug($data);
     //////// get fields and contain ////////
     $contain = array();
     $findFields = array();
     foreach ($fields as &$field) {
         if (substr($field, 0, strlen($model->alias) + 1) == $model->alias . '.') {
             $findFields[] = $field;
             $field = $model->alias . '.' . $field;
         } elseif (($pos = strrpos($field, '.')) == false) {
             $findFields[] = $model->alias . '.' . $field;
         } else {
             $path = substr($field, 0, $pos);
             $depth = count(explode('.', $path));
             $f = substr($field, $pos + 1);
             if ($depth > 1) {
                 $contain = Set::insert($contain, $path . '.fields', array('id', $f));
             } else {
                 $contain = Set::insert($contain, $path, array());
                 if (!in_array($path . '.id', $findFields)) {
                     $findFields[] = $path . '.id';
                 }
                 $findFields[] = $field;
             }
         }
     }
     if (!in_array($model->alias . '.id', $findFields)) {
         $findFields[] = $model->alias . '.id';
     }
     //////// normalize Data ////////
     list($data, $oldFormat) = $model->unifiedResult($data, null, null, true);
     App::import('Lib', 'SetMulti');
     $data = SetMulti::group($data, $model->alias . '.id', array('singleArray' => false));
     //debug($data);
     //////// get ids ////////
     $ids = array();
     foreach ($data as $entry) {
         foreach ($fields as $field) {
             if (!Set::check($entry, $field)) {
                 $ids[] = $entry[$model->alias]['id'];
                 continue 2;
             }
         }
     }
     //////// query ////////
     $findOpt = array('fields' => $findFields, 'conditions' => array($model->alias . '.id' => $ids), 'contain' => $contain);
     $findOpt = array_merge($findOpt, $findOptions);
     //debug($findOpt);
     $completion = $model->find('all', $findOpt);
     //debug($completion);
     //////// merge data ////////
     foreach ($completion as $c) {
         $id = $c[$model->alias]['id'];
         if ($priorityRes) {
             $data[$id] = Set::merge($data[$id], $c);
         } else {
             $data[$id] = Set::merge($c, $data[$id]);
         }
     }
     $data = array_values($data);
     $data = $this->unifiedResult($model, $data, null, $oldFormat);
     //debug($data);
     return $data;
 }
開發者ID:kevthunder,項目名稱:arch,代碼行數:68,代碼來源:util.php

示例11: get_more_params

 function get_more_params($excepts = array())
 {
     $datas = $_GET;
     $excepts = am($this->excepts, array('page'));
     //On va parcourir les exemptions
     foreach ($excepts as $except) {
         if (Set::check($_GET, $except)) {
             $datas = Set::remove($datas, $except);
             $exceptPath = explode('.', $except);
             if (count(Set::classicExtract($datas, $exceptPath[0])) == 0) {
                 $datas = Set::remove($datas, $exceptPath[0]);
             }
         }
     }
     $moreParams = '';
     if (count($datas) > 0) {
         $moreParams = $this->_recursive_params($datas);
     }
     return $moreParams;
 }
開發者ID:strifefrosst,項目名稱:koeZionCMS,代碼行數:20,代碼來源:paginator_parent_helper.php

示例12: _is_valid_value

 /**
  * Cette fonction est en charge de contrôler la valeur d'un champ est valide
  *
  * @param 	varchar	$valueToCheck 	Valeur du champ à contrôler
  * @param 	varchar	$validationRule Règle de validation
  * @param 	array 	$insertErrorIn 	Indique le chemin pour l'insertion de l'erreur
  * @param 	array 	$errors 		Erreurs
  * @return 	array 	Tableau d'erreurs
  * @access	protected
  * @author	koéZionCMS
  * @version 0.1 - 20/03/2015
  */
 protected function _is_valid_value($valueToCheck, $validationRule, $insertErrorIn, $errors)
 {
     include CONFIGS . DS . 'messages.php';
     //Inclusion des éventuels messages d'erreurs
     $isValid = $this->Validation->check($valueToCheck, $validationRule['rule']);
     //Lancement de la règle
     $allowEmpty = $validationRule['allowEmpty'] && empty($valueToCheck);
     //Génération du booléen allowEmpty
     //On injecte le message en cas d'erreur
     if (!$isValid && !$allowEmpty) {
         if (Set::check($Errorsmessages, $validationRule['message'])) {
             $errors[$insertErrorIn] = Set::classicExtract($Errorsmessages, $validationRule['message']);
         } else {
             $errors[$insertErrorIn] = $validationRule['message'];
         }
     }
     return $errors;
 }
開發者ID:strifefrosst,項目名稱:koeZionCMS,代碼行數:30,代碼來源:model.php

示例13: testWritingWithFunkyKeys

 function testWritingWithFunkyKeys()
 {
     $set = new Set();
     $set->insert('Session Test', "test");
     $this->assertEqual($set->extract('Session Test'), 'test');
     $set->remove('Session Test');
     $this->assertFalse($set->check('Session Test'));
     $this->assertTrue($set->insert('Session Test.Test Case', "test"));
     $this->assertTrue($set->check('Session Test.Test Case'));
 }
開發者ID:kaz0636,項目名稱:openflp,代碼行數:10,代碼來源:set.test.php

示例14: dma_codes

 public function dma_codes()
 {
     $this->loadStuff();
     $month = false;
     $year = false;
     $domain_id = false;
     $sql_filter = '';
     if (Set::check($this->request->data, "Filters.report_month.month")) {
         $month = $this->request->data['Filters']['report_month']['month'];
     } else {
         $month = $this->request->data['Filters']['report_month']['month'] = date("m");
     }
     //get the year
     if (Set::check($this->request->data, "Filters.report_year.year")) {
         $year = $this->request->data['Filters']['report_year']['year'];
     } else {
         $year = $this->request->data['Filters']['report_year']['year'] = date("Y");
     }
     //get the domain id
     if (Set::check($this->request->data, "Filters.dim_domain_id")) {
         $domain_id = $this->request->data['Filters']['dim_domain_id'];
     }
     //make the pv report
     $report = $this->FactPageView->query("SELECT COUNT(*) AS `total`,DimDmaCode.dma_code,DimDmaCode.dma_location\n\t\t\tFROM fact_page_views AS `FactPageView` \n\t\t\tINNER JOIN dim_dates AS `DimDate` ON (DimDate.id = FactPageView.dim_date_id)\n\t\t\tINNER JOIN dim_domains AS `DimDomain` ON (DimDomain.id = FactPageView.dim_domain_id)\n\t\t\tINNER JOIN dim_dma_codes AS `DimDmaCode` ON (DimDmaCode.id = FactPageView.dim_dma_code_id)\n\t\t\tWHERE DimDate.report_month = '{$month}' AND DimDate.report_year = '{$year}' {$sql_filter}\n\t\t\tGROUP BY DimDmaCode.dma_code\n\t\t\tORDER BY total DESC");
     $uniques = $this->FactPageView->query("SELECT COUNT(*) AS `total`,dma_code\n\t\t\tFROM (\n\t\t\t\tSELECT DISTINCT(session),DimDmaCode.dma_code AS `dma_code`\n\t\t\t\tFROM fact_page_views AS `FactPageView`\n\t\t\t\tINNER JOIN dim_dates AS `DimDate` ON (DimDate.id = FactPageView.dim_date_id)\n\t\t\t\tINNER JOIN dim_domains AS `DimDomain` ON (DimDomain.id = FactPageView.dim_domain_id)\n\t\t\t\tINNER JOIN dim_dma_codes AS `DimDmaCode` ON (DimDmaCode.id = FactPageView.dim_dma_code_id)\n\t\t\t\tWHERE DimDate.report_month = '{$month}' AND DimDate.report_year = '{$year}' {$sql_filter}\n\t\t\t) AS Traffic\n\t\t\tGROUP BY dma_code");
     $berra = $this->FactPageView->query("SELECT SUM(uniques) AS `total`,dma_code\n\t\t\tFROM (\n\t\t\t\tSELECT COUNT(*) AS `uniques`,dma_code,report_hour,report_day\n\t\t\t\tFROM (\n\t\t\t\t\tSELECT DISTINCT(session),DimDmaCode.dma_code AS `dma_code`,DimDate.report_day AS `report_day`,DimDate.report_hour AS `report_hour`\n\t\t\t\t\tFROM fact_page_views AS `FactPageView`\n\t\t\t\t\tINNER JOIN dim_dates AS `DimDate` ON (DimDate.id = FactPageView.dim_date_id)\n\t\t\t\t\tINNER JOIN dim_domains AS `DimDomain` ON (DimDomain.id = FactPageView.dim_domain_id)\n\t\t\t\t\tINNER JOIN dim_dma_codes AS `DimDmaCode` ON (DimDmaCode.id = FactPageView.dim_dma_code_id)\n\t\t\t\t\tWHERE DimDate.report_month = '{$month}' AND DimDate.report_year = '{$year}' {$sql_filter}\n\t\t\t\t) AS Traffic\n\t\t\t\tGROUP BY dma_code,report_day,report_hour\n\t\t\t) AS Traffic\n\t\t\tGROUP BY dma_code");
     $unq = array();
     $b_unq = array();
     foreach ($uniques as $v) {
         $unq[$v['Traffic']['dma_code']] = $v[0]['total'];
     }
     foreach ($berra as $v) {
         $b_unq[$v['Traffic']['dma_code']] = $v[0]['total'];
     }
     //fill in the report
     foreach ($report as $k => $v) {
         $report[$k][0]['uniques'] = $unq[$v['DimDmaCode']['dma_code']];
         $report[$k][0]['berra'] = $b_unq[$v['DimDmaCode']['dma_code']];
     }
     //get some select lists
     $domainList = $this->DimDomain->selectList();
     $this->set(compact("report", "domainList"));
 }
開發者ID:josephbergdoll,項目名稱:berrics,代碼行數:43,代碼來源:TrafficReportsController.php

示例15: _multiParseAttributes

 function _multiParseAttributes($data, $keys, $default = array())
 {
     $def = array('exclude' => null, 'insertBefore' => ' ', 'insertAfter' => null, 'isolate' => false);
     $def = array_merge($def, $default);
     if ($def['isolate']) {
         $attrs = array();
     } else {
         $attrs = $data;
     }
     foreach (Set::normalize($keys) as $key => $opt) {
         $opt = array_merge($def, (array) $opt);
         if (Set::check($data, $key)) {
             $parsed = false;
             $unparsed = Set::extract($key, $data);
             if ($unparsed !== false) {
                 $parsed = $this->_parseAttributes($unparsed, $opt['exclude'], $opt['insertBefore'], $opt['insertAfter']);
             }
             $attrs = Set::insert($attrs, $key, $parsed);
         }
     }
     return $attrs;
 }
開發者ID:kevthunder,項目名稱:cake-spark-form,代碼行數:22,代碼來源:spark_form.php


注:本文中的Set::check方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。