This file is part of the GNU MP Library.
The GNU MP Library is free software; you can redistribute it and/or modify
-it under the terms of the GNU Lesser General Public License as published by
-the Free Software Foundation; either version 3 of the License, or (at your
-option) any later version.
+it under the terms of either:
+
+ * the GNU Lesser General Public License as published by the Free
+ Software Foundation; either version 3 of the License, or (at your
+ option) any later version.
+
+or
+
+ * the GNU General Public License as published by the Free Software
+ Foundation; either version 2 of the License, or (at your option) any
+ later version.
+
+or both in parallel, as here.
The GNU MP Library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
-or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
-License for more details.
+or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+for more details.
-You should have received a copy of the GNU Lesser General Public License
-along with the GNU MP Library. If not, see http://www.gnu.org/licenses/. */
+You should have received copies of the GNU General Public License and the
+GNU Lesser General Public License along with the GNU MP Library. If not,
+see https://www.gnu.org/licenses/. */
#include "gmp.h"
#include "gmp-impl.h"
mp_size_t usize, vsize;
mp_size_t ualloc, valloc;
- ualloc = u->_mp_num._mp_alloc;
- valloc = v->_mp_num._mp_alloc;
- v->_mp_num._mp_alloc = ualloc;
- u->_mp_num._mp_alloc = valloc;
+ ualloc = ALLOC(NUM(u));
+ valloc = ALLOC(NUM(v));
+ ALLOC(NUM(v)) = ualloc;
+ ALLOC(NUM(u)) = valloc;
- usize = u->_mp_num._mp_size;
- vsize = v->_mp_num._mp_size;
- v->_mp_num._mp_size = usize;
- u->_mp_num._mp_size = vsize;
+ usize = SIZ(NUM(u));
+ vsize = SIZ(NUM(v));
+ SIZ(NUM(v)) = usize;
+ SIZ(NUM(u)) = vsize;
- up = u->_mp_num._mp_d;
- vp = v->_mp_num._mp_d;
- v->_mp_num._mp_d = up;
- u->_mp_num._mp_d = vp;
+ up = PTR(NUM(u));
+ vp = PTR(NUM(v));
+ PTR(NUM(v)) = up;
+ PTR(NUM(u)) = vp;
- ualloc = u->_mp_den._mp_alloc;
- valloc = v->_mp_den._mp_alloc;
- v->_mp_den._mp_alloc = ualloc;
- u->_mp_den._mp_alloc = valloc;
+ ualloc = ALLOC(DEN(u));
+ valloc = ALLOC(DEN(v));
+ ALLOC(DEN(v)) = ualloc;
+ ALLOC(DEN(u)) = valloc;
- usize = u->_mp_den._mp_size;
- vsize = v->_mp_den._mp_size;
- v->_mp_den._mp_size = usize;
- u->_mp_den._mp_size = vsize;
+ usize = SIZ(DEN(u));
+ vsize = SIZ(DEN(v));
+ SIZ(DEN(v)) = usize;
+ SIZ(DEN(u)) = vsize;
- up = u->_mp_den._mp_d;
- vp = v->_mp_den._mp_d;
- v->_mp_den._mp_d = up;
- u->_mp_den._mp_d = vp;
+ up = PTR(DEN(u));
+ vp = PTR(DEN(v));
+ PTR(DEN(v)) = up;
+ PTR(DEN(u)) = vp;
}