fld_dup.c 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /****************************************************************************
  2. * Copyright (c) 1998 Free Software Foundation, Inc. *
  3. * *
  4. * Permission is hereby granted, free of charge, to any person obtaining a *
  5. * copy of this software and associated documentation files (the *
  6. * "Software"), to deal in the Software without restriction, including *
  7. * without limitation the rights to use, copy, modify, merge, publish, *
  8. * distribute, distribute with modifications, sublicense, and/or sell *
  9. * copies of the Software, and to permit persons to whom the Software is *
  10. * furnished to do so, subject to the following conditions: *
  11. * *
  12. * The above copyright notice and this permission notice shall be included *
  13. * in all copies or substantial portions of the Software. *
  14. * *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
  16. * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
  17. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
  18. * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
  19. * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
  20. * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
  21. * THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
  22. * *
  23. * Except as contained in this notice, the name(s) of the above copyright *
  24. * holders shall not be used in advertising or otherwise to promote the *
  25. * sale, use or other dealings in this Software without prior written *
  26. * authorization. *
  27. ****************************************************************************/
  28. /****************************************************************************
  29. * Author: Juergen Pfeifer <juergen.pfeifer@gmx.net> 1995,1997 *
  30. ****************************************************************************/
  31. #include "form.priv.h"
  32. MODULE_ID("$Id$")
  33. /*---------------------------------------------------------------------------
  34. | Facility : libnform
  35. | Function : FIELD *dup_field(FIELD *field, int frow, int fcol)
  36. |
  37. | Description : Duplicates the field at the specified position. All
  38. | field attributes and the buffers are copied.
  39. | If an error occurs, errno is set to
  40. |
  41. | E_BAD_ARGUMENT - invalid argument
  42. | E_SYSTEM_ERROR - system error
  43. |
  44. | Return Values : Pointer to the new field or NULL if failure
  45. +--------------------------------------------------------------------------*/
  46. FIELD *dup_field(FIELD * field, int frow, int fcol)
  47. {
  48. FIELD *New_Field = (FIELD *)0;
  49. int err = E_BAD_ARGUMENT;
  50. if (field && (frow>=0) && (fcol>=0) &&
  51. ((err=E_SYSTEM_ERROR) != 0) && /* trick : this resets the default error */
  52. (New_Field=(FIELD *)malloc(sizeof(FIELD))) )
  53. {
  54. *New_Field = *_nc_Default_Field;
  55. New_Field->frow = frow;
  56. New_Field->fcol = fcol;
  57. New_Field->link = New_Field;
  58. New_Field->rows = field->rows;
  59. New_Field->cols = field->cols;
  60. New_Field->nrow = field->nrow;
  61. New_Field->drows = field->drows;
  62. New_Field->dcols = field->dcols;
  63. New_Field->maxgrow = field->maxgrow;
  64. New_Field->nbuf = field->nbuf;
  65. New_Field->just = field->just;
  66. New_Field->fore = field->fore;
  67. New_Field->back = field->back;
  68. New_Field->pad = field->pad;
  69. New_Field->opts = field->opts;
  70. New_Field->usrptr = field->usrptr;
  71. if (_nc_Copy_Type(New_Field,field))
  72. {
  73. size_t len;
  74. len = Total_Buffer_Size(New_Field);
  75. if ( (New_Field->buf=(char *)malloc(len)) )
  76. {
  77. memcpy(New_Field->buf,field->buf,len);
  78. return New_Field;
  79. }
  80. }
  81. }
  82. if (New_Field)
  83. free_field(New_Field);
  84. SET_ERROR(err);
  85. return (FIELD *)0;
  86. }
  87. /* fld_dup.c ends here */