computed_field.install 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. /**
  3. * @file
  4. * Install, update and uninstall functions for the computed field module.
  5. */
  6. /**
  7. * Implements hook_field_schema().
  8. */
  9. function computed_field_field_schema($field) {
  10. if ($field['type'] == 'computed') {
  11. $settings = $field['settings'];
  12. if ($settings['store']) {
  13. $columns = array('value' => array());
  14. // Hardcoded 'longtext' settings.
  15. if ($settings['database']['data_type'] == 'longtext') {
  16. $columns['value']['type'] = 'text';
  17. $columns['value']['size'] = 'big';
  18. }
  19. else {
  20. $columns['value']['type'] = isset($settings['database']['data_type']) ? $settings['database']['data_type'] : 'varchar';
  21. }
  22. // 'text' and 'varchar' fields get length settings.
  23. if ($settings['database']['data_type'] == 'text' || $settings['database']['data_type'] == 'varchar') {
  24. $columns['value']['length'] = isset($settings['database']['data_length']) ? $settings['database']['data_length'] : 32;
  25. }
  26. // 'int' and 'float' fields get size settings.
  27. if ($settings['database']['data_type'] == 'int' || $settings['database']['data_type'] == 'float') {
  28. $columns['value']['size'] = isset($settings['database']['data_size']) ? $settings['database']['data_size'] : 'normal';
  29. }
  30. // 'decimal' fields get precision and scale settings.
  31. if ($settings['database']['data_type'] == 'numeric') {
  32. $columns['value']['precision'] = isset($settings['database']['data_precision']) ? $settings['database']['data_precision'] : 10;
  33. $columns['value']['scale'] = isset($settings['database']['data_scale']) ? $settings['database']['data_scale'] : 2;
  34. }
  35. // Add 'not null' settings.
  36. $columns['value']['not null'] = isset($settings['database']['data_not_NULL']) ? $settings['database']['data_not_NULL'] : TRUE;
  37. // Add default values if set.
  38. if ($settings['database']['data_default'] !== '') {
  39. $columns['value']['default'] = $settings['database']['data_default'];
  40. }
  41. // Add a simple index on the data if requested (except 'text' fields).
  42. if ($settings['database']['data_index'] && $columns['value']['type'] != 'text') {
  43. $indexes = array('value' => array('value'));
  44. }
  45. }
  46. }
  47. if (isset($columns) && isset($indexes)) {
  48. return array(
  49. 'columns' => $columns,
  50. 'indexes' => $indexes,
  51. );
  52. }
  53. elseif (isset($columns)) {
  54. return array(
  55. 'columns' => $columns,
  56. );
  57. }
  58. return;
  59. }