diff -up --new-file better_formats.6.x-1.2/better_formats.features.inc better_formats_modified.6.x-1.2/better_formats.features.inc --- better_formats.6.x-1.2/better_formats.features.inc 1969-12-31 19:00:00.000000000 -0500 +++ better_formats_modified.6.x-1.2/better_formats.features.inc 2011-02-24 13:55:07.034977000 -0500 @@ -0,0 +1,109 @@ +type, (array) $export['features']['better_formats'])) { + continue; + } + + if (in_array($role->type, $data)) { + $export['features']['better_formats'][$role->type] = $role->type; + } + } + + $export['dependencies'][] = 'better_formats'; + return $pipe; +} + +/** + * Implementation of hook_features_export_render(). + */ +function better_formats_features_export_render($module, $data) { + // @todo - without this there is an undefined function features_var_export(). + module_load_include('inc', 'features', 'features.export'); + $code = array(); + $code[] = ' $defaults = array();'; + $code[] = ''; + + $result = db_query("SELECT * FROM {better_formats_defaults}"); + while ($row = db_fetch_array($result)) { + $code[] = ' $defaults[] = '. features_var_export($row, ' ') .';'; + $code[] = ''; + } + + $code[] = ' return $defaults;'; + $code = implode("\n", $code); + return array('better_formats_default' => $code); +} + +/** + * Implementation of hook_features_export_revert(). + */ +function better_formats_features_revert($module) { + better_formats_features_rebuild($module); +} + +/** + * Implementation of hook_features_export_rebuild(). + */ +function better_formats_features_rebuild($module) { + $defaults = module_invoke($module, 'better_formats_default'); + if (!empty($defaults)) { + foreach ($defaults as $default) { + db_query("UPDATE {better_formats_defaults} SET rid = %d, type = '%s', format = %d, type_weight = %d, weight = %d WHERE rid = %d AND type = '%s'", $default['rid'], $default['type'], $default['format'], $default['type_weight'], $default['weight'], $default['rid'], $default['type']); + if (!db_affected_rows()) { + db_query("INSERT INTO {better_formats_defaults} (rid, type, format, type_weight, weight) VALUES (%d, '%s', %d, %d, %d)", $default['rid'], $default['type'], $default['format'], $default['type_weight'], $default['weight']); + } + } + } +} diff -up --new-file better_formats.6.x-1.2/better_formats.module better_formats_modified.6.x-1.2/better_formats.module --- better_formats.6.x-1.2/better_formats.module 2010-02-05 08:59:18.000000000 -0500 +++ better_formats_modified.6.x-1.2/better_formats.module 2011-02-24 14:51:43.994978002 -0500 @@ -132,6 +132,22 @@ function better_formats_form_alter(&$for } /** + * Implementation of hook_features_api(). + * + * Allow exporting of Better formats profiles by the Features module + */ +function better_formats_features_api() { + return array( + 'better_formats' => array( + 'name' => t('Better formats'), + 'default_hook' => 'better_formats_default', + 'features_source' => TRUE, + 'file' => drupal_get_path('module', 'better_formats') .'/better_formats.features.inc', + ), + ); +} + +/** * FAPI form to add to the content type edit form. * * @see better_formats_node_type_form_validate() Common subdirectories: better_formats.6.x-1.2/tests and better_formats_modified.6.x-1.2/tests Common subdirectories: better_formats.6.x-1.2/translations and better_formats_modified.6.x-1.2/translations