Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
Pyston
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
Pyston
Commits
3c62f10f
Commit
3c62f10f
authored
Apr 30, 2015
by
Kevin Modzelewski
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #474 from undingen/pycrypto3
Add a pycrypto integration test
parents
2da3998a
d4a60b26
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
193 additions
and
2 deletions
+193
-2
.gitmodules
.gitmodules
+3
-0
from_cpython/Include/longobject.h
from_cpython/Include/longobject.h
+9
-0
src/codegen/ast_interpreter.cpp
src/codegen/ast_interpreter.cpp
+10
-1
src/codegen/irgen/hooks.cpp
src/codegen/irgen/hooks.cpp
+1
-1
src/runtime/classobj.cpp
src/runtime/classobj.cpp
+22
-0
src/runtime/long.cpp
src/runtime/long.cpp
+11
-0
src/runtime/types.cpp
src/runtime/types.cpp
+1
-0
test/integration/pycrypto
test/integration/pycrypto
+1
-0
test/integration/pycrypto_0001-fastmath-Add-support-for-Pyston.patch
...ation/pycrypto_0001-fastmath-Add-support-for-Pyston.patch
+59
-0
test/integration/pycrypto_test.py
test/integration/pycrypto_test.py
+58
-0
test/tests/functions.py
test/tests/functions.py
+6
-0
test/tests/oldstyle_classes.py
test/tests/oldstyle_classes.py
+12
-0
No files found.
.gitmodules
View file @
3c62f10f
...
...
@@ -13,3 +13,6 @@
[submodule "lz4"]
path = lz4
url = git://github.com/Cyan4973/lz4.git
[submodule "test/integration/pycrypto"]
path = test/integration/pycrypto
url = https://github.com/dlitz/pycrypto.git
from_cpython/Include/longobject.h
View file @
3c62f10f
...
...
@@ -138,6 +138,15 @@ PyAPI_FUNC(PyObject *) _PyLong_FormatAdvanced(PyObject *obj,
char
*
format_spec
,
Py_ssize_t
format_spec_len
)
PYSTON_NOEXCEPT
;
// Pyston change: Pyston specific API
#define Py_HAVE_LONG_MPZ_API 1
/* _PyLongMPZ: alias for mpz_src, used to not have to pull in the GMP header. */
typedef
void
*
_PyLongMPZ
;
/* _PyLong_AsMPZ: Sets the supplied initialized GMP mpz to the value of the supplied long object. */
PyAPI_FUNC
(
void
)
_PyLong_AsMPZ
(
PyObject
*
,
_PyLongMPZ
)
PYSTON_NOEXCEPT
;
/* _PyLong_FromMPZ: Creates a python long object from the supplied GMP mpz value. */
PyAPI_FUNC
(
PyObject
*
)
_PyLong_FromMPZ
(
const
_PyLongMPZ
)
PYSTON_NOEXCEPT
;
#ifdef __cplusplus
}
#endif
...
...
src/codegen/ast_interpreter.cpp
View file @
3c62f10f
...
...
@@ -462,7 +462,7 @@ Value ASTInterpreter::visit_jump(AST_Jump* node) {
if
(
ENABLE_OSR
&&
backedge
&&
(
globals
->
cls
==
module_cls
))
{
bool
can_osr
=
!
FORCE_INTERPRETER
&&
(
globals
->
cls
==
module_cls
);
if
(
can_osr
&&
edgecount
++
>
OSR_THRESHOLD_INTERPRETER
)
{
if
(
can_osr
&&
edgecount
++
==
OSR_THRESHOLD_INTERPRETER
)
{
eraseDeadSymbols
();
const
OSREntryDescriptor
*
found_entry
=
nullptr
;
...
...
@@ -495,6 +495,15 @@ Value ASTInterpreter::visit_jump(AST_Jump* node) {
}
}
// LLVM has a limit on the number of operands a machine instruction can have (~255),
// in order to not hit the limit with the patchpoints cancel OSR when we have a high number of symbols.
if
(
sorted_symbol_table
.
size
()
>
225
)
{
static
StatCounter
times_osr_cancel
(
"num_osr_cancel_to_many_syms"
);
times_osr_cancel
.
log
();
next_block
=
node
->
target
;
return
Value
();
}
if
(
generator
)
sorted_symbol_table
[
source_info
->
getInternedStrings
().
get
(
PASSED_GENERATOR_NAME
)]
=
generator
;
...
...
src/codegen/irgen/hooks.cpp
View file @
3c62f10f
...
...
@@ -552,7 +552,7 @@ void CompiledFunction::speculationFailed() {
this
->
times_speculation_failed
++
;
if
(
this
->
times_speculation_failed
>
=
4
)
{
if
(
this
->
times_speculation_failed
=
=
4
)
{
// printf("Killing %p because it failed too many speculations\n", this);
CLFunction
*
cl
=
this
->
clfunc
;
...
...
src/runtime/classobj.cpp
View file @
3c62f10f
...
...
@@ -511,6 +511,26 @@ static PyObject* instance_index(PyObject* self) noexcept {
return
res
;
}
Box
*
instanceEq
(
Box
*
_inst
,
Box
*
other
)
{
RELEASE_ASSERT
(
_inst
->
cls
==
instance_cls
,
""
);
BoxedInstance
*
inst
=
static_cast
<
BoxedInstance
*>
(
_inst
);
Box
*
func
=
_instanceGetattribute
(
inst
,
boxStrConstant
(
"__eq__"
),
false
);
if
(
!
func
)
return
NotImplemented
;
return
runtimeCall
(
func
,
ArgPassSpec
(
1
),
other
,
NULL
,
NULL
,
NULL
,
NULL
);
}
Box
*
instanceNe
(
Box
*
_inst
,
Box
*
other
)
{
RELEASE_ASSERT
(
_inst
->
cls
==
instance_cls
,
""
);
BoxedInstance
*
inst
=
static_cast
<
BoxedInstance
*>
(
_inst
);
Box
*
func
=
_instanceGetattribute
(
inst
,
boxStrConstant
(
"__ne__"
),
false
);
if
(
!
func
)
return
NotImplemented
;
return
runtimeCall
(
func
,
ArgPassSpec
(
1
),
other
,
NULL
,
NULL
,
NULL
,
NULL
);
}
Box
*
instanceCall
(
Box
*
_inst
,
Box
*
_args
,
Box
*
_kwargs
)
{
assert
(
_inst
->
cls
==
instance_cls
);
BoxedInstance
*
inst
=
static_cast
<
BoxedInstance
*>
(
_inst
);
...
...
@@ -560,6 +580,8 @@ void setupClassobj() {
instance_cls
->
giveAttr
(
"__hash__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
instanceHash
,
UNKNOWN
,
1
)));
instance_cls
->
giveAttr
(
"__call__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
instanceCall
,
UNKNOWN
,
1
,
0
,
true
,
true
)));
instance_cls
->
giveAttr
(
"__eq__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
instanceEq
,
UNKNOWN
,
2
)));
instance_cls
->
giveAttr
(
"__ne__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
instanceNe
,
UNKNOWN
,
2
)));
instance_cls
->
freeze
();
instance_cls
->
tp_getattro
=
instance_getattro
;
...
...
src/runtime/long.cpp
View file @
3c62f10f
...
...
@@ -452,6 +452,17 @@ extern "C" PyObject* _PyLong_FromByteArray(const unsigned char* bytes, size_t n,
return
rtn
;
}
extern
"C"
void
_PyLong_AsMPZ
(
PyObject
*
obj
,
_PyLongMPZ
num
)
noexcept
{
RELEASE_ASSERT
(
obj
->
cls
==
long_cls
,
"needs a long argument"
);
mpz_set
((
mpz_ptr
)
num
,
((
BoxedLong
*
)
obj
)
->
n
);
}
extern
"C"
PyObject
*
_PyLong_FromMPZ
(
const
_PyLongMPZ
num
)
noexcept
{
BoxedLong
*
r
=
new
BoxedLong
();
mpz_init_set
(
r
->
n
,
(
mpz_srcptr
)
num
);
return
r
;
}
extern
"C"
Box
*
createLong
(
const
std
::
string
*
s
)
{
BoxedLong
*
rtn
=
new
BoxedLong
();
int
r
=
mpz_init_set_str
(
rtn
->
n
,
s
->
c_str
(),
10
);
...
...
src/runtime/types.cpp
View file @
3c62f10f
...
...
@@ -2258,6 +2258,7 @@ void setupRuntime() {
function_cls
->
giveAttr
(
"func_code"
,
new
(
pyston_getset_cls
)
BoxedGetsetDescriptor
(
functionCode
,
NULL
,
NULL
));
function_cls
->
giveAttr
(
"func_defaults"
,
new
(
pyston_getset_cls
)
BoxedGetsetDescriptor
(
functionDefaults
,
NULL
,
NULL
));
function_cls
->
giveAttr
(
"func_name"
,
function_cls
->
getattr
(
"__name__"
));
function_cls
->
freeze
();
builtin_function_or_method_cls
->
giveAttr
(
...
...
pycrypto
@
7acba5f3
Subproject commit 7acba5f3a6ff10f1424c309d0d34d2b713233019
test/integration/pycrypto_0001-fastmath-Add-support-for-Pyston.patch
0 → 100644
View file @
3c62f10f
From 7303cd6db08b41a513bbd45aad0676a47eb3820a Mon Sep 17 00:00:00 2001
From: Marius Wachtler <undingen@gmail.com>
Date: Tue, 28 Apr 2015 11:49:32 +0200
Subject: [PATCH] fastmath: Add support for Pyston
---
src/_fastmath.c | 21 +++++++++++++++++++++
1 file changed, 21 insertions(+)
diff --git a/src/_fastmath.c b/src/_fastmath.c
index e369f5a..c4cf2aa 100644
--- a/src/_fastmath.c
+++ b/src/_fastmath.c
@@ -29,7 +29,14 @@
#include "pycrypto_common.h"
#include <stdio.h>
#include <string.h>
+
+#ifdef Py_HAVE_LONG_MPZ_API
+#ifndef HAVE_LIBGMP
+#error Pyston only supports GMP.
+#endif
+#else
#include <longintrepr.h> /* for conversions */
+#endif
#if HAVE_LIBGMP
# include <gmp.h>
#elif HAVE_LIBMPIR
@@ -60,6 +67,19 @@
static unsigned int sieve_base[10000];
static int rabinMillerTest (mpz_t n, int rounds, PyObject *randfunc);
+#ifdef Py_HAVE_LONG_MPZ_API
+static void
+longObjToMPZ (mpz_t m, PyLongObject * p)
+{
+ _PyLong_AsMPZ ((PyObject*)p, m);
+}
+
+static PyObject *
+mpzToLongObj (mpz_t m)
+{
+ return _PyLong_FromMPZ (m);
+}
+#else
static void
longObjToMPZ (mpz_t m, PyLongObject * p)
{
@@ -113,6 +133,7 @@
mpzToLongObj (mpz_t m)
mpz_clear (temp);
return (PyObject *) l;
}
+#endif
typedef struct
{
--
2.1.0
test/integration/pycrypto_test.py
0 → 100644
View file @
3c62f10f
import
subprocess
,
sys
,
os
,
shutil
,
StringIO
pycrypto_dir
=
os
.
path
.
dirname
(
os
.
path
.
abspath
(
__file__
))
+
"/pycrypto"
os
.
chdir
(
pycrypto_dir
)
for
d
in
(
"build"
,
"install"
):
if
os
.
path
.
exists
(
d
):
print
"Removing the existing"
,
d
,
"directory"
shutil
.
rmtree
(
d
)
devnull
=
open
(
os
.
devnull
,
"w"
)
print
"-- Patching pycrypto"
patches
=
[
"../pycrypto_0001-fastmath-Add-support-for-Pyston.patch"
]
for
patch
in
patches
:
out
=
StringIO
.
StringIO
()
try
:
cmd
=
[
"patch"
,
"-p1"
,
"--forward"
,
"-i"
,
patch
]
subprocess
.
check_output
(
cmd
,
stderr
=
subprocess
.
STDOUT
)
except
subprocess
.
CalledProcessError
as
e
:
print
e
.
output
if
"Reversed (or previously applied) patch detected! Skipping patch"
not
in
e
.
output
:
raise
e
print
"-- Building pycrypto"
subprocess
.
check_call
([
sys
.
executable
,
"setup.py"
,
"build"
],
stdout
=
devnull
)
print
"-- Installing pycrypto"
subprocess
.
check_call
([
sys
.
executable
,
"setup.py"
,
"install"
,
"--prefix=install"
],
stdout
=
devnull
)
print
"-- Testing pycrypto"
sys
.
path
.
append
(
"install/site-packages"
)
test_string
=
"test string"
.
ljust
(
16
)
from
Crypto.Hash
import
SHA256
,
MD5
assert
SHA256
.
new
(
test_string
).
hexdigest
()
==
"edce3184097ede907d91c4069c55104785a3a989b9706e5919202d6f5fe2d814"
assert
MD5
.
new
(
test_string
).
hexdigest
()
==
"e135865bb047e78e1827b0cf83696725"
from
Crypto.Cipher
import
AES
aes1
=
AES
.
new
(
"pwd1__0123456789"
)
aes2
=
AES
.
new
(
"pwd2__0123456789"
)
enc_data
=
aes1
.
encrypt
(
test_string
)
enc_data2
=
aes2
.
encrypt
(
test_string
)
assert
enc_data
!=
enc_data2
assert
aes1
.
decrypt
(
enc_data
)
==
test_string
assert
aes2
.
decrypt
(
enc_data2
)
==
test_string
from
Crypto.PublicKey
import
RSA
from
Crypto
import
Random
key
=
RSA
.
generate
(
1024
,
Random
.
new
().
read
)
public_key
=
key
.
publickey
()
enc_data
=
public_key
.
encrypt
(
test_string
,
32
)
assert
enc_data
!=
test_string
assert
key
.
decrypt
(
enc_data
)
==
test_string
print
"-- Tests finished"
test/tests/functions.py
View file @
3c62f10f
...
...
@@ -12,4 +12,10 @@ def g():
print
type
(
f
).
__call__
(
f
)
print
type
(
f
).
__call__
(
g
)
print
f
.
__name__
,
f
.
func_name
f
.
__name__
=
"New name"
print
f
.
__name__
,
f
.
func_name
f
.
func_name
=
"f"
print
f
.
__name__
,
f
.
func_name
print
bool
(
f
)
test/tests/oldstyle_classes.py
View file @
3c62f10f
...
...
@@ -55,6 +55,14 @@ class E():
print
"f"
,
a
return
f
def
__eq__
(
self
,
other
):
print
"eq"
return
self
.
n
==
other
.
n
def
__ne__
(
self
,
other
):
print
"ne"
return
self
.
n
!=
other
.
n
e
=
E
(
1
)
print
e
print
e
.
n
...
...
@@ -63,6 +71,8 @@ print e[1]
print
e
[
1
:
2
]
print
len
(
e
)
print
e
()(
"test"
)
print
e
==
E
(
1
)
print
e
!=
E
(
1
)
def
str2
():
return
"str2"
...
...
@@ -82,6 +92,8 @@ class F:
print
bool
(
F
(
0
))
print
bool
(
F
(
1
))
print
F
(
0
)
==
F
(
0
)
print
F
(
0
)
!=
F
(
0
)
f
=
F
(
0
)
try
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment