Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
9206976f
Commit
9206976f
authored
Oct 10, 2012
by
Vicent Martí
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #971 from arrbee/base64-encoder
Add git_buf_put_base64 to buffer API
parents
aeba5e17
2d3579be
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
68 additions
and
0 deletions
+68
-0
src/buffer.c
+40
-0
src/buffer.h
+3
-0
tests-clar/core/buffer.c
+25
-0
No files found.
src/buffer.c
View file @
9206976f
...
@@ -186,6 +186,46 @@ int git_buf_puts_escaped(
...
@@ -186,6 +186,46 @@ int git_buf_puts_escaped(
return
0
;
return
0
;
}
}
static
const
char
b64str
[
64
]
=
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
;
int
git_buf_put_base64
(
git_buf
*
buf
,
const
char
*
data
,
size_t
len
)
{
size_t
extra
=
len
%
3
;
uint8_t
*
write
,
a
,
b
,
c
;
const
uint8_t
*
read
=
(
const
uint8_t
*
)
data
;
ENSURE_SIZE
(
buf
,
buf
->
size
+
((
len
*
4
+
3
)
/
3
)
+
1
);
write
=
(
uint8_t
*
)
&
buf
->
ptr
[
buf
->
size
];
/* convert each run of 3 bytes into 4 output bytes */
for
(
len
-=
extra
;
len
>
0
;
len
-=
3
)
{
a
=
*
read
++
;
b
=
*
read
++
;
c
=
*
read
++
;
*
write
++
=
b64str
[
a
>>
2
];
*
write
++
=
b64str
[(
a
&
0x03
)
<<
4
|
b
>>
4
];
*
write
++
=
b64str
[(
b
&
0x0f
)
<<
2
|
c
>>
6
];
*
write
++
=
b64str
[
c
&
0x3f
];
}
if
(
extra
>
0
)
{
a
=
*
read
++
;
b
=
(
extra
>
1
)
?
*
read
++
:
0
;
*
write
++
=
b64str
[
a
>>
2
];
*
write
++
=
b64str
[(
a
&
0x03
)
<<
4
|
b
>>
4
];
*
write
++
=
(
extra
>
1
)
?
b64str
[(
b
&
0x0f
)
<<
2
]
:
'='
;
*
write
++
=
'='
;
}
buf
->
size
=
((
char
*
)
write
)
-
buf
->
ptr
;
buf
->
ptr
[
buf
->
size
]
=
'\0'
;
return
0
;
}
int
git_buf_vprintf
(
git_buf
*
buf
,
const
char
*
format
,
va_list
ap
)
int
git_buf_vprintf
(
git_buf
*
buf
,
const
char
*
format
,
va_list
ap
)
{
{
int
len
;
int
len
;
...
...
src/buffer.h
View file @
9206976f
...
@@ -154,4 +154,7 @@ bool git_buf_is_binary(const git_buf *buf);
...
@@ -154,4 +154,7 @@ bool git_buf_is_binary(const git_buf *buf);
/* Unescape all characters in a buffer */
/* Unescape all characters in a buffer */
void
git_buf_unescape
(
git_buf
*
buf
);
void
git_buf_unescape
(
git_buf
*
buf
);
/* Write data as base64 encoded in buffer */
int
git_buf_put_base64
(
git_buf
*
buf
,
const
char
*
data
,
size_t
len
);
#endif
#endif
tests-clar/core/buffer.c
View file @
9206976f
...
@@ -678,3 +678,28 @@ void test_core_buffer__unescape(void)
...
@@ -678,3 +678,28 @@ void test_core_buffer__unescape(void)
assert_unescape
(
"
\\
"
,
"
\\\\
"
);
assert_unescape
(
"
\\
"
,
"
\\\\
"
);
assert_unescape
(
""
,
""
);
assert_unescape
(
""
,
""
);
}
}
void
test_core_buffer__base64
(
void
)
{
git_buf
buf
=
GIT_BUF_INIT
;
/* t h i s
* 0x 74 68 69 73
* 0b 01110100 01101000 01101001 01110011
* 0b 011101 000110 100001 101001 011100 110000
* 0x 1d 06 21 29 1c 30
* d G h p c w
*/
cl_git_pass
(
git_buf_put_base64
(
&
buf
,
"this"
,
4
));
cl_assert_equal_s
(
"dGhpcw=="
,
buf
.
ptr
);
git_buf_clear
(
&
buf
);
cl_git_pass
(
git_buf_put_base64
(
&
buf
,
"this!"
,
5
));
cl_assert_equal_s
(
"dGhpcyE="
,
buf
.
ptr
);
git_buf_clear
(
&
buf
);
cl_git_pass
(
git_buf_put_base64
(
&
buf
,
"this!
\n
"
,
6
));
cl_assert_equal_s
(
"dGhpcyEK"
,
buf
.
ptr
);
git_buf_free
(
&
buf
);
}
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