File: isprime.adb

package info (click to toggle)
libgnatcoll-bindings 25.0.0-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 2,412 kB
  • sloc: ada: 18,696; python: 1,597; ansic: 1,422; cpp: 581; makefile: 147; sh: 114
file content (79 lines) | stat: -rw-r--r-- 3,497 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
------------------------------------------------------------------------------
--                             G N A T C O L L                              --
--                                                                          --
--                     Copyright (C) 2009-2017, AdaCore                     --
--                                                                          --
-- This library is free software;  you can redistribute it and/or modify it --
-- under terms of the  GNU General Public License  as published by the Free --
-- Software  Foundation;  either version 3,  or (at your  option) any later --
-- version. This library is distributed in the hope that it will be useful, --
-- but WITHOUT ANY WARRANTY;  without even the implied warranty of MERCHAN- --
-- TABILITY or FITNESS FOR A PARTICULAR PURPOSE.                            --
--                                                                          --
-- As a special exception under Section 7 of GPL version 3, you are granted --
-- additional permissions described in the GCC Runtime Library Exception,   --
-- version 3.1, as published by the Free Software Foundation.               --
--                                                                          --
-- You should have received a copy of the GNU General Public License and    --
-- a copy of the GCC Runtime Library Exception along with this program;     --
-- see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see    --
-- <http://www.gnu.org/licenses/>.                                          --
--                                                                          --
------------------------------------------------------------------------------

--  This program allows a user to determine whether a given (big) integer is a
--  prime number. It is based directly on the example provided by the
--  underlying C implementation of the GMP. Note that the input can be
--  expressed in bases other than base 10, if desired, by using C prefixes such
--  as "0x" and so forth.
--
--  This program also illustrates use of an underlying C library routine that
--  does not have a corresponding Ada binding already defined elsewhere.

with Ada.Text_IO;               use Ada.Text_IO;
with GNATCOLL.GMP.Integers;     use GNATCOLL.GMP.Integers;
with GNATCOLL.GMP.Integers.IO;  use GNATCOLL.GMP.Integers.IO;
with Interfaces.C;              use Interfaces.C;
with GNATCOLL.GMP.Lib;          use GNATCOLL.GMP.Lib;

procedure IsPrime is

   N : Big_Integer;

   Result : int;

   function mpz_probab_prime_p (this : access constant mpz_t; x : int)
      return int;
   pragma Import (C, mpz_probab_prime_p, "__gmpz_probab_prime_p");

begin
   loop
      Put ("Enter candidate number (return to quit): ");
      declare
         Input : constant String := Get_Line;
      begin
         if Input'Length = 0 then
            return;
         else
            Set (N, Input, 0);  -- base 0 allows the input to define the base
         end if;
      end;

      Result := mpz_probab_prime_p (As_mpz_t (N), 5);

      Put (N);

      case Result is
         when 0 =>
            Put_Line (" is not a prime");
         when 1 =>
            Put_Line (" is a probable prime");
         when 2 =>
            Put_Line (" is a prime");
         when others =>
            Put_Line ("Unexpected result from mpz_probab_prime_p:" &
                      Result'Img);
            return;
      end case;
   end loop;
end IsPrime;