PHPackages                             hariadi/siapa - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Parsing &amp; Serialization](/categories/parsing)
4. /
5. hariadi/siapa

ActiveLibrary[Parsing &amp; Serialization](/categories/parsing)

hariadi/siapa
=============

A simple PHP library for parsing complex Malay names into their individual components

v1.2.0(1y ago)11.0kMITPHPPHP ^8.0CI failing

Since Jun 18Pushed 1y ago1 watchersCompare

[ Source](https://github.com/hariadi/Siapa)[ Packagist](https://packagist.org/packages/hariadi/siapa)[ Docs](https://github.com/hariadi/Siapa)[ RSS](/packages/hariadi-siapa/feed)WikiDiscussions main Synced 1w ago

READMEChangelog (7)Dependencies (3)Versions (8)Used By (0)

Siapa
======

[](#siapa-)

**Malay Name Parser**A smart parser for extracting components from complex Malay names:

- ✅ Salutation
- ✅ First Name
- ✅ Last Name (excluding patronyms like "bin"/"binti")
- ✅ Gender detection

---

💡 Example Usage
---------------

[](#-example-usage)

```
use Hariadi\Siapa\Siapa;

$siapa = Siapa::name("Dato' Dr. Ir. Hj. Hariadi Bin Hinta");

echo $siapa->salutation(); // Dato' Dr. Ir. Hj.
echo $siapa->first();      // Hariadi
echo $siapa->last();       // Hinta
echo $siapa->gender();     // M
```

---

📦 Install
---------

[](#-install)

Install via Composer:

```
composer require hariadi/siapa
```

Then include the autoloader:

```
require 'vendor/autoload.php';
```

Alternatively, require the class manually:

```
require_once 'path/to/Siapa/src/Siapa.php';
```

---

🧱 Object-Oriented Usage
-----------------------

[](#-object-oriented-usage)

```
use Hariadi\Siapa\Siapa;

$siapa = Siapa::name('Hariadi Hinta', 'UTF-8');
echo $siapa->first(); // Hariadi
```

---

🧪 Methods
---------

[](#-methods)

> If `$encoding` is not provided, it defaults to `mb_internal_encoding()`.

### `salutation()`

[](#salutation)

Returns the full salutation, if detected.

```
Siapa::name('Datuk Dr. Ir. Hariadi Hinta')->salutation(); // Datuk Dr. Ir.
```

### `givenName(bool $withMiddle = false)`

[](#givennamebool-withmiddle--false)

Returns full name without salutation. Optionally excludes middle markers (e.g., bin, binti).

```
Siapa::name("Dato' Hariadi Bin Hinta")->givenName();       // Hariadi Hinta
Siapa::name("Dato' Hariadi Bin Hinta")->givenName(true);  // Hariadi Bin Hinta
```

### `first()`

[](#first)

Returns the detected first name:

```
Siapa::name('Hariadi Hinta')->first(); // Hariadi
```

### `last()`

[](#last)

Returns the last name (without bin/binti):

```
Siapa::name('Hariadi Bin Hinta')->last(); // Hinta
```

### `gender(bool $short = true)`

[](#genderbool-short--true)

Detects gender. Returns `'M'`/`'F'` or `'Male'`/`'Female'`.

```
Siapa::name('Pn. Nurul Hidayah')->gender();      // F
Siapa::name('Pn. Nurul Hidayah')->gender(false); // Female
```

#### Gender Detection Heuristics

[](#gender-detection-heuristics)

1. Defaults to **Male**
2. If last name contains any of:

    - `Binti`, `Bte`, `A/P`, `Pn.`, `Puan`, `Cik` etc.
3. If salutation contains female honorifics
4. If first name matches any name in [`female.txt`](src/Data/female.txt)

---

✅ Tests
-------

[](#-tests)

Run tests using PHPUnit:

```
git clone https://github.com/hariadi/Siapa.git
cd Siapa
vendor/bin/phpunit
```

---

📄 License
---------

[](#-license)

Released under the [MIT License](LICENSE.txt).

###  Health Score

41

—

FairBetter than 89% of packages

Maintenance49

Moderate activity, may be stable

Popularity19

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity73

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~664 days

Recently: every ~996 days

Total

7

Last Release

368d ago

Major Versions

v0.1.3 → v1.0.02020-01-21

PHP version history (4 changes)v0.1.0PHP &gt;=5.3.0

v1.0.0PHP &gt;=7.1

v1.1.0PHP ^8.0|^8.1

v1.2.0PHP ^8.0

### Community

Maintainers

![](https://www.gravatar.com/avatar/0df440312528d7737e222b654274174ee2065240dbf1a07df094d745cab41094?d=identicon)[hariadi](/maintainers/hariadi)

---

Top Contributors

[![hariadi](https://avatars.githubusercontent.com/u/376635?v=4)](https://github.com/hariadi "hariadi (21 commits)")

---

Tags

utf-8helpersparserutilsnamegenderUTFmethodsmalay

###  Code Quality

TestsPHPUnit

Static AnalysisPHPStan

Code StylePHP CS Fixer

Type Coverage Yes

### Embed Badge

![Health badge](/badges/hariadi-siapa/health.svg)

```
[![Health](https://phpackages.com/badges/hariadi-siapa/health.svg)](https://phpackages.com/packages/hariadi-siapa)
```

###  Alternatives

[danielstjules/stringy

A string manipulation library with multibyte support

2.4k26.0M191](/packages/danielstjules-stringy)[nikic/php-parser

A PHP parser written in PHP

17.4k902.6M1.8k](/packages/nikic-php-parser)[doctrine/lexer

PHP Doctrine Lexer parser library that can be used in Top-Down, Recursive Descent Parsers.

11.2k910.8M118](/packages/doctrine-lexer)[erusev/parsedown

Parser for Markdown.

15.0k151.8M732](/packages/erusev-parsedown)[voku/stringy

A string manipulation library with multibyte support

1783.8M19](/packages/voku-stringy)[masterminds/html5

An HTML5 parser and serializer.

1.8k242.8M229](/packages/masterminds-html5)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
